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
use crate::transactions::{Sign, Transaction};
use scsys::crypto::hash::{hasher, Hashable, H256};
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, Default, Deserialize, Eq, Hash, PartialEq, Serialize)]
pub struct SignedTransaction {
pub sign: Sign,
pub transaction: Transaction,
}
impl SignedTransaction {
pub fn new(sign: Sign, transaction: Transaction) -> Self {
Self { sign, transaction }
}
}
impl std::fmt::Display for SignedTransaction {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
write!(f, "({}, {})", self.sign, self.transaction)
}
}
impl Hashable for SignedTransaction {
fn hash(&self) -> H256 {
hasher(self).as_slice().to_owned().into()
}
}