diff --git a/src/bank.rs b/src/bank.rs index 35aa30aacbcb59..19fb47f5b6ef7c 100644 --- a/src/bank.rs +++ b/src/bank.rs @@ -170,7 +170,7 @@ impl Bank { return Err(BankError::AccountNotFound); } - if !self.reserve_signature_with_last_id(&tr.sig, &tr.data.last_id) { + if !self.reserve_signature_with_last_id(&tr.sig, &tr.last_id) { return Err(BankError::InvalidTransferSignature); } @@ -179,7 +179,7 @@ impl Bank { let current = bal.load(Ordering::Relaxed) as i64; if current < tr.data.tokens { - self.forget_signature_with_last_id(&tr.sig, &tr.data.last_id); + self.forget_signature_with_last_id(&tr.sig, &tr.last_id); return Err(BankError::InsufficientFunds); } diff --git a/src/transaction.rs b/src/transaction.rs index ef2acccae45bb4..25c1db8f6862ce 100644 --- a/src/transaction.rs +++ b/src/transaction.rs @@ -14,7 +14,6 @@ pub const PUB_KEY_OFFSET: usize = 80; #[derive(Serialize, Deserialize, Debug, PartialEq, Eq, Clone)] pub struct TransactionData { pub tokens: i64, - pub last_id: Hash, pub plan: Plan, } @@ -23,6 +22,7 @@ pub struct Transaction { pub sig: Signature, pub from: PublicKey, pub data: TransactionData, + pub last_id: Hash, } impl Transaction { @@ -32,12 +32,9 @@ impl Transaction { let plan = Plan::Pay(Payment { tokens, to }); let mut tr = Transaction { sig: Signature::default(), - data: TransactionData { - plan, - tokens, - last_id, - }, - from: from, + data: TransactionData { plan, tokens }, + last_id, + from, }; tr.sign(from_keypair); tr @@ -57,12 +54,9 @@ impl Transaction { (Condition::Signature(from), Payment { tokens, to: from }), ); let mut tr = Transaction { - data: TransactionData { - plan, - tokens, - last_id, - }, - from: from, + data: TransactionData { plan, tokens }, + from, + last_id, sig: Signature::default(), }; tr.sign(from_keypair); @@ -70,7 +64,10 @@ impl Transaction { } fn get_sign_data(&self) -> Vec { - serialize(&(&self.data)).expect("serialize TransactionData in fn get_sign_data") + let mut data = serialize(&(&self.data)).expect("serialize TransactionData"); + let last_id_data = serialize(&(&self.last_id)).expect("serialize last_id"); + data.extend_from_slice(&last_id_data); + data } /// Sign this transaction. @@ -153,12 +150,9 @@ mod tests { to: Default::default(), }); let claim0 = Transaction { - data: TransactionData { - plan, - tokens: 0, - last_id: Default::default(), - }, + data: TransactionData { plan, tokens: 0 }, from: Default::default(), + last_id: Default::default(), sig: Default::default(), }; let buf = serialize(&claim0).unwrap();