use super::embedded_transaction_builder::*;
use super::embedded_transaction_helper::*;
use super::entity_type_dto::*;
use super::generator_utils::*;
use super::hash256_dto::*;
use super::key_dto::*;
use super::lock_hash_algorithm_dto::*;
use super::network_type_dto::*;
use super::secret_proof_transaction_body_builder::*;
use super::unresolved_address_dto::*;
#[derive(Debug, Clone)]
pub struct EmbeddedSecretProofTransactionBuilder {
pub super_object: EmbeddedTransactionBuilder,
pub body: SecretProofTransactionBodyBuilder,
}
impl EmbeddedSecretProofTransactionBuilder {
const VERSION: u8 = 1;
const ENTITY_TYPE: u16 = 0x4252;
pub fn from_binary(payload: &[u8]) -> Self {
let mut _bytes = payload.to_vec();
let super_object = EmbeddedTransactionBuilder::from_binary(&_bytes);
assert_eq!(Self::VERSION, super_object.version, "Invalid entity version ({})", super_object.version);
assert_eq!(Self::ENTITY_TYPE, super_object._type.get_value(), "Invalid entity type ({:?})", super_object._type);
let mut _bytes = _bytes[super_object.get_size()..].to_vec();
let secret_proof_transaction_body = SecretProofTransactionBodyBuilder::from_binary(&_bytes); _bytes = _bytes[secret_proof_transaction_body.get_size()..].to_vec();
EmbeddedSecretProofTransactionBuilder { super_object, body: secret_proof_transaction_body } }
pub fn get_recipient_address(&self) -> UnresolvedAddressDto {
self.body.recipient_address.clone()
}
pub fn set_recipient_address(&mut self, recipient_address: UnresolvedAddressDto) {
self.body.recipient_address = recipient_address; }
pub fn get_secret(&self) -> Hash256Dto {
self.body.secret.clone()
}
pub fn set_secret(&mut self, secret: Hash256Dto) {
self.body.secret = secret; }
pub fn get_hash_algorithm(&self) -> LockHashAlgorithmDto {
self.body.hash_algorithm.clone()
}
pub fn set_hash_algorithm(&mut self, hash_algorithm: LockHashAlgorithmDto) {
self.body.hash_algorithm = hash_algorithm; }
pub fn get_proof(&self) -> Vec<u8> {
self.body.proof.clone()
}
pub fn set_proof(&mut self, proof: Vec<u8>) {
self.body.proof = proof; }
pub fn get_size(&self) -> usize {
let mut size = self.super_object.get_size();
size += self.body.get_size();
size
}
pub fn serializer(&self) -> Vec<u8> {
let mut buf: Vec<u8> = vec![];
buf.append(&mut (self.get_size() as u32).to_le_bytes().to_vec());
buf.append(&mut self.super_object.serializer());
buf.append(&mut self.body.serializer()); buf
}
}
impl EmbeddedTransactionHelper for EmbeddedSecretProofTransactionBuilder {
fn box_clone(&self) -> Box<dyn EmbeddedTransactionHelper> {
Box::new((*self).clone())
}
fn get_size(&self) -> usize {
self.get_size()
}
fn serializer(&self) -> Vec<u8> {
self.serializer()
}
}