catbuffer_rust/
secret_proof_transaction_builder.rs1use super::amount_dto::*;
23use super::entity_type_dto::*;
24use super::generator_utils::*;
25use super::hash256_dto::*;
26use super::key_dto::*;
27use super::lock_hash_algorithm_dto::*;
28use super::network_type_dto::*;
29use super::secret_proof_transaction_body_builder::*;
30use super::signature_dto::*;
31use super::timestamp_dto::*;
32use super::transaction_builder::*;
33use super::unresolved_address_dto::*;
34
35#[derive(Debug, Clone)]
37pub struct SecretProofTransactionBuilder {
38 pub super_object: TransactionBuilder,
40 pub body: SecretProofTransactionBodyBuilder,
42}
43
44impl SecretProofTransactionBuilder {
45 const VERSION: u8 = 1;
46 const ENTITY_TYPE: u16 = 0x4252;
47
48
49 pub fn from_binary(payload: &[u8]) -> Self {
54 let mut _bytes = payload.to_vec();
55 let super_object = TransactionBuilder::from_binary(&_bytes);
56 assert_eq!(Self::VERSION, super_object.version, "Invalid entity version ({})", super_object.version);
57 assert_eq!(Self::ENTITY_TYPE, super_object._type.get_value(), "Invalid entity type ({:?})", super_object._type);
58 let mut _bytes = _bytes[super_object.get_size()..].to_vec();
59 let secret_proof_transaction_body = SecretProofTransactionBodyBuilder::from_binary(&_bytes); _bytes = _bytes[secret_proof_transaction_body.get_size()..].to_vec();
61 SecretProofTransactionBuilder { super_object, body: secret_proof_transaction_body } }
64
65
66 pub fn get_recipient_address(&self) -> UnresolvedAddressDto {
67 self.body.recipient_address.clone()
68 }
69 pub fn set_recipient_address(&mut self, recipient_address: UnresolvedAddressDto) {
70 self.body.recipient_address = recipient_address; }
72
73
74 pub fn get_secret(&self) -> Hash256Dto {
75 self.body.secret.clone()
76 }
77 pub fn set_secret(&mut self, secret: Hash256Dto) {
78 self.body.secret = secret; }
80
81
82 pub fn get_hash_algorithm(&self) -> LockHashAlgorithmDto {
83 self.body.hash_algorithm.clone()
84 }
85 pub fn set_hash_algorithm(&mut self, hash_algorithm: LockHashAlgorithmDto) {
86 self.body.hash_algorithm = hash_algorithm; }
88
89
90 pub fn get_proof(&self) -> Vec<u8> {
91 self.body.proof.clone()
92 }
93 pub fn set_proof(&mut self, proof: Vec<u8>) {
94 self.body.proof = proof; }
96
97 pub fn get_size(&self) -> usize {
102 let mut size = self.super_object.get_size();
103 size += self.body.get_size();
104 size
105 }
106
107 pub fn serializer(&self) -> Vec<u8> {
112 let mut buf: Vec<u8> = vec![];
113 buf.append(&mut (self.get_size() as u32).to_le_bytes().to_vec());
114 buf.append(&mut self.super_object.serializer());
115 buf.append(&mut self.body.serializer()); buf
117 }
118}
119