@@ -319,6 +319,19 @@ impl FromRow<StackStxOp> for StackStxOp {
319
319
let stacked_ustx = u128:: from_str_radix ( & stacked_ustx_str, 10 )
320
320
. expect ( "CORRUPTION: bad u128 written to sortdb" ) ;
321
321
let num_cycles = row. get_unwrap ( "num_cycles" ) ;
322
+ let signing_key_str_opt: Option < String > = row. get ( "signer_key" ) ?;
323
+ let signer_key = match signing_key_str_opt {
324
+ Some ( key_str) => serde_json:: from_str ( & key_str) . ok ( ) ,
325
+ None => None ,
326
+ } ;
327
+ let max_amount_str_opt: Option < String > = row. get ( "max_amount" ) ?;
328
+ let max_amount = match max_amount_str_opt {
329
+ Some ( max_amount_str) => u128:: from_str_radix ( & max_amount_str, 10 )
330
+ . map_err ( |_| db_error:: ParseError )
331
+ . ok ( ) ,
332
+ None => None ,
333
+ } ;
334
+ let auth_id = row. get ( "auth_id" ) ?;
322
335
323
336
Ok ( StackStxOp {
324
337
txid,
@@ -329,6 +342,9 @@ impl FromRow<StackStxOp> for StackStxOp {
329
342
reward_addr,
330
343
stacked_ustx,
331
344
num_cycles,
345
+ signer_key,
346
+ max_amount,
347
+ auth_id,
332
348
} )
333
349
}
334
350
}
@@ -702,6 +718,9 @@ const SORTITION_DB_SCHEMA_8: &'static [&'static str] = &[
702
718
block_hash TEXT NOT NULL,
703
719
block_height INTEGER NOT NULL
704
720
);"# ,
721
+ r#"ALTER TABLE stack_stx ADD signer_key TEXT DEFAULT NULL;"# ,
722
+ r#"ALTER TABLE stack_stx ADD max_amount TEXT DEFAULT NULL;"# ,
723
+ r#"ALTER TABLE stack_stx ADD auth_id INTEGER DEFAULT NULL;"# ,
705
724
r#"
706
725
-- table definition for `vote-for-aggregate-key` burn op
707
726
CREATE TABLE vote_for_aggregate_key (
@@ -5420,9 +5439,12 @@ impl<'a> SortitionHandleTx<'a> {
5420
5439
& op. reward_addr . to_db_string ( ) ,
5421
5440
& op. stacked_ustx . to_string ( ) ,
5422
5441
& op. num_cycles ,
5442
+ & serde_json:: to_string ( & op. signer_key ) . unwrap ( ) ,
5443
+ & serde_json:: to_string ( & op. max_amount ) . unwrap ( ) ,
5444
+ & op. auth_id ,
5423
5445
] ;
5424
5446
5425
- self . execute ( "REPLACE INTO stack_stx (txid, vtxindex, block_height, burn_header_hash, sender_addr, reward_addr, stacked_ustx, num_cycles) VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7, ?8)" , args) ?;
5447
+ self . execute ( "REPLACE INTO stack_stx (txid, vtxindex, block_height, burn_header_hash, sender_addr, reward_addr, stacked_ustx, num_cycles, signer_key, max_amount, auth_id ) VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7, ?8, ?9, ?10, ?11 )" , args) ?;
5426
5448
5427
5449
Ok ( ( ) )
5428
5450
}
@@ -10133,6 +10155,9 @@ pub mod tests {
10133
10155
reward_addr: PoxAddress :: Standard ( StacksAddress :: new( 4 , Hash160 ( [ 4u8 ; 20 ] ) ) , None ) ,
10134
10156
stacked_ustx: 456 ,
10135
10157
num_cycles: 6 ,
10158
+ signer_key: Some ( StacksPublicKeyBuffer ( [ 0x02 ; 33 ] ) ) ,
10159
+ max_amount: Some ( u128 :: MAX ) ,
10160
+ auth_id: Some ( 0u32 ) ,
10136
10161
10137
10162
txid: Txid ( [ 0x02 ; 32 ] ) ,
10138
10163
vtxindex: 2 ,
@@ -10225,6 +10250,9 @@ pub mod tests {
10225
10250
reward_addr: PoxAddress :: Standard ( StacksAddress :: new( 4 , Hash160 ( [ 4u8 ; 20 ] ) ) , None ) ,
10226
10251
stacked_ustx: 456 ,
10227
10252
num_cycles: 6 ,
10253
+ signer_key: None ,
10254
+ max_amount: None ,
10255
+ auth_id: None ,
10228
10256
10229
10257
txid: Txid ( [ 0x02 ; 32 ] ) ,
10230
10258
vtxindex: 2 ,
0 commit comments