catbuffer_rust/
embedded_secret_proof_transaction_builder.rs1use super::embedded_transaction_builder::*;
23use super::embedded_transaction_helper::*;
24use super::entity_type_dto::*;
25use super::generator_utils::*;
26use super::hash256_dto::*;
27use super::key_dto::*;
28use super::lock_hash_algorithm_dto::*;
29use super::network_type_dto::*;
30use super::secret_proof_transaction_body_builder::*;
31use super::unresolved_address_dto::*;
32
33#[derive(Debug, Clone)]
35pub struct EmbeddedSecretProofTransactionBuilder {
36 pub super_object: EmbeddedTransactionBuilder,
38 pub body: SecretProofTransactionBodyBuilder,
40}
41
42impl EmbeddedSecretProofTransactionBuilder {
43 const VERSION: u8 = 1;
44 const ENTITY_TYPE: u16 = 0x4252;
45
46
47 pub fn from_binary(payload: &[u8]) -> Self {
52 let mut _bytes = payload.to_vec();
53 let super_object = EmbeddedTransactionBuilder::from_binary(&_bytes);
54 assert_eq!(Self::VERSION, super_object.version, "Invalid entity version ({})", super_object.version);
55 assert_eq!(Self::ENTITY_TYPE, super_object._type.get_value(), "Invalid entity type ({:?})", super_object._type);
56 let mut _bytes = _bytes[super_object.get_size()..].to_vec();
57 let secret_proof_transaction_body = SecretProofTransactionBodyBuilder::from_binary(&_bytes); _bytes = _bytes[secret_proof_transaction_body.get_size()..].to_vec();
59 EmbeddedSecretProofTransactionBuilder { super_object, body: secret_proof_transaction_body } }
63
64
65 pub fn get_recipient_address(&self) -> UnresolvedAddressDto {
66 self.body.recipient_address.clone()
67 }
68 pub fn set_recipient_address(&mut self, recipient_address: UnresolvedAddressDto) {
69 self.body.recipient_address = recipient_address; }
71
72
73 pub fn get_secret(&self) -> Hash256Dto {
74 self.body.secret.clone()
75 }
76 pub fn set_secret(&mut self, secret: Hash256Dto) {
77 self.body.secret = secret; }
79
80
81 pub fn get_hash_algorithm(&self) -> LockHashAlgorithmDto {
82 self.body.hash_algorithm.clone()
83 }
84 pub fn set_hash_algorithm(&mut self, hash_algorithm: LockHashAlgorithmDto) {
85 self.body.hash_algorithm = hash_algorithm; }
87
88
89 pub fn get_proof(&self) -> Vec<u8> {
90 self.body.proof.clone()
91 }
92 pub fn set_proof(&mut self, proof: Vec<u8>) {
93 self.body.proof = proof; }
95
96 pub fn get_size(&self) -> usize {
101 let mut size = self.super_object.get_size();
102 size += self.body.get_size();
103 size
104 }
105
106 pub fn serializer(&self) -> Vec<u8> {
111 let mut buf: Vec<u8> = vec![];
112 buf.append(&mut (self.get_size() as u32).to_le_bytes().to_vec());
113 buf.append(&mut self.super_object.serializer());
114 buf.append(&mut self.body.serializer()); buf
116 }
117}
118
119impl EmbeddedTransactionHelper for EmbeddedSecretProofTransactionBuilder {
120 fn box_clone(&self) -> Box<dyn EmbeddedTransactionHelper> {
121 Box::new((*self).clone())
122 }
123
124 fn get_size(&self) -> usize {
125 self.get_size()
126 }
127
128 fn serializer(&self) -> Vec<u8> {
129 self.serializer()
130 }
131}
132