use super::amount_dto::*;
use super::block_duration_dto::*;
use super::entity_type_dto::*;
use super::generator_utils::*;
use super::key_dto::*;
use super::mosaic_definition_transaction_body_builder::*;
use super::mosaic_flags_dto::*;
use super::mosaic_id_dto::*;
use super::mosaic_nonce_dto::*;
use super::network_type_dto::*;
use super::signature_dto::*;
use super::timestamp_dto::*;
use super::transaction_builder::*;
#[derive(Debug, Clone)]
pub struct MosaicDefinitionTransactionBuilder {
pub super_object: TransactionBuilder,
pub body: MosaicDefinitionTransactionBodyBuilder,
}
impl MosaicDefinitionTransactionBuilder {
const VERSION: u8 = 1;
const ENTITY_TYPE: u16 = 0x414d;
pub fn from_binary(payload: &[u8]) -> Self {
let mut _bytes = payload.to_vec();
let super_object = TransactionBuilder::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 mosaic_definition_transaction_body = MosaicDefinitionTransactionBodyBuilder::from_binary(&_bytes); _bytes = _bytes[mosaic_definition_transaction_body.get_size()..].to_vec();
MosaicDefinitionTransactionBuilder { super_object, body: mosaic_definition_transaction_body } }
pub fn get_id(&self) -> MosaicIdDto {
self.body.id.clone()
}
pub fn set_id(&mut self, id: MosaicIdDto) {
self.body.id = id; }
pub fn get_duration(&self) -> BlockDurationDto {
self.body.duration.clone()
}
pub fn set_duration(&mut self, duration: BlockDurationDto) {
self.body.duration = duration; }
pub fn get_nonce(&self) -> MosaicNonceDto {
self.body.nonce.clone()
}
pub fn set_nonce(&mut self, nonce: MosaicNonceDto) {
self.body.nonce = nonce; }
pub fn get_flags(&self) -> Vec<MosaicFlagsDto> {
self.body.flags.clone()
}
pub fn set_flags(&mut self, flags: Vec<MosaicFlagsDto>) {
self.body.flags = flags; }
pub fn get_divisibility(&self) -> u8 {
self.body.divisibility.clone()
}
pub fn set_divisibility(&mut self, divisibility: u8) {
self.body.divisibility = divisibility; }
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
}
}