/** *** Copyright (c) 2016-2019, Jaguar0625, gimre, BloodyRookie, Tech Bureau, Corp. *** Copyright (c) 2020-present, Jaguar0625, gimre, BloodyRookie. *** All rights reserved. *** *** This file is part of Catapult. *** *** Catapult is free software: you can redistribute it and/or modify *** it under the terms of the GNU Lesser General Public License as published by *** the Free Software Foundation, either version 3 of the License, or *** (at your option) any later version. *** *** Catapult is distributed in the hope that it will be useful, *** but WITHOUT ANY WARRANTY; without even the implied warranty of *** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *** GNU Lesser General Public License for more details. *** *** You should have received a copy of the GNU Lesser General Public License *** along with Catapult. If not, see . **/ import { GeneratorUtils } from './GeneratorUtils'; import { Serializer } from './Serializer'; /** Multiplier applied to the size of a transaction to obtain its fee, in [absolute units](/concepts/mosaic.html#divisibility). See the [fees documentation](/concepts/fees.html).. */ export class BlockFeeMultiplierDto implements Serializer { /** Multiplier applied to the size of a transaction to obtain its fee, in [absolute units](/concepts/mosaic.html#divisibility). See the [fees documentation](/concepts/fees.html).. */ readonly blockFeeMultiplier: number; /** * Constructor. * * @param blockFeeMultiplier Multiplier applied to the size of a transaction to obtain its fee, in [absolute units](/concepts/mosaic.html#divisibility). See the [fees documentation](/concepts/fees.html).. */ constructor(blockFeeMultiplier: number) { this.blockFeeMultiplier = blockFeeMultiplier; } /** * Creates an instance of BlockFeeMultiplierDto from binary payload. * * @param payload Byte payload to use to serialize the object. * @return Instance of BlockFeeMultiplierDto. */ public static loadFromBinary(payload: Uint8Array): BlockFeeMultiplierDto { const blockFeeMultiplier = GeneratorUtils.bufferToUint32(Uint8Array.from(payload)); return new BlockFeeMultiplierDto(blockFeeMultiplier); } /** * Gets Multiplier applied to the size of a transaction to obtain its fee, in [absolute units](/concepts/mosaic.html#divisibility). See the [fees documentation](/concepts/fees.html).. * * @return Multiplier applied to the size of a transaction to obtain its fee, in [absolute units](/concepts/mosaic.html#divisibility). See the [fees documentation](/concepts/fees.html).. */ public getBlockFeeMultiplier(): number { return this.blockFeeMultiplier; } /** * Gets the size of the object. * * @return Size in bytes. */ public getSize(): number { return 4; } /** * Serializes an object to bytes. * * @return Serialized bytes. */ public serialize(): Uint8Array { return GeneratorUtils.uint32ToBuffer(this.getBlockFeeMultiplier()); } }