use crate::transactions::SignedTransaction;
use scsys::crypto::hash::H256;
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, Default, Deserialize, Eq, Hash, PartialEq, Serialize)]
pub struct SpamId {
pub nonce: usize,
pub pubk: String,
}
impl SpamId {
pub fn new(nonce: usize, pubk: String) -> Self {
Self { nonce, pubk }
}
}
impl std::convert::From<&SignedTransaction> for SpamId {
fn from(t: &SignedTransaction) -> Self {
let hash: H256 = t.sign.pubk.clone().into();
SpamId {
nonce: t.transaction.nonce,
pubk: hash.to_string(),
}
}
}
impl std::fmt::Display for SpamId {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{}", serde_json::to_string(&self).unwrap())
}
}