1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
use beserial::{Deserialize, Serialize}; use primitives::coin::Coin; use transaction::Transaction; use crate::Account; use crate::AccountError; use crate::AccountTransactionInteraction; use crate::AccountType; #[derive(Clone, PartialEq, PartialOrd, Eq, Ord, Debug, Serialize, Deserialize)] pub struct BasicAccount { pub balance: Coin } impl AccountTransactionInteraction for BasicAccount { fn new_contract(_account_type: AccountType, _balance: Coin, _transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { Err(AccountError::InvalidForRecipient) } fn create(_balance: Coin, _transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { Err(AccountError::InvalidForRecipient) } fn with_incoming_transaction(&self, transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { let balance: Coin = Account::balance_add(self.balance, transaction.value)?; Ok(BasicAccount { balance }) } fn without_incoming_transaction(&self, transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { let balance: Coin = Account::balance_sub(self.balance, transaction.value)?; Ok(BasicAccount { balance }) } fn with_outgoing_transaction(&self, transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { let balance: Coin = Account::balance_sub(self.balance, transaction.value.checked_add(transaction.fee).ok_or(AccountError::InvalidCoinValue)?)?; Ok(BasicAccount { balance }) } fn without_outgoing_transaction(&self, transaction: &Transaction, _block_height: u32) -> Result<Self, AccountError> { let balance: Coin = Account::balance_add(self.balance, transaction.value.checked_add(transaction.fee).ok_or(AccountError::InvalidCoinValue)?)?; Ok(BasicAccount { balance }) } }