/** *** 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'; /** Either an Address or a NamespaceId. The **least**-significant bit of the first byte is 0 for Addresses and 1 for NamespaceId's.. */ export class UnresolvedAddressDto implements Serializer { /** Either an Address or a NamespaceId. The **least**-significant bit of the first byte is 0 for Addresses and 1 for NamespaceId's.. */ readonly unresolvedAddress: Uint8Array; /** * Constructor. * * @param unresolvedAddress Either an Address or a NamespaceId. The **least**-significant bit of the first byte is 0 for Addresses and 1 for NamespaceId's.. */ constructor(unresolvedAddress: Uint8Array) { this.unresolvedAddress = unresolvedAddress; } /** * Creates an instance of UnresolvedAddressDto from binary payload. * * @param payload Byte payload to use to serialize the object. * @return Instance of UnresolvedAddressDto. */ public static loadFromBinary(payload: Uint8Array): UnresolvedAddressDto { const unresolvedAddress = GeneratorUtils.getBytes(Uint8Array.from(payload), 24); return new UnresolvedAddressDto(unresolvedAddress); } /** * Gets Either an Address or a NamespaceId. The **least**-significant bit of the first byte is 0 for Addresses and 1 for NamespaceId's.. * * @return Either an Address or a NamespaceId. The **least**-significant bit of the first byte is 0 for Addresses and 1 for NamespaceId's.. */ public getUnresolvedAddress(): Uint8Array { return this.unresolvedAddress; } /** * Gets the size of the object. * * @return Size in bytes. */ public getSize(): number { return 24; } /** * Serializes an object to bytes. * * @return Serialized bytes. */ public serialize(): Uint8Array { return this.getUnresolvedAddress(); } }