UNPKG

@c4tplatform/caminojs

Version:
394 lines (392 loc) 46.2 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.NFTTransferOutput = exports.NFTMintOutput = exports.SECPMintOutput = exports.SECPTransferOutput = exports.NFTOutput = exports.AmountOutput = exports.TransferableOutput = exports.SelectOutputClass = void 0; /** * @packageDocumentation * @module API-AVM-Outputs */ const buffer_1 = require("buffer/"); const bintools_1 = __importDefault(require("../../utils/bintools")); const constants_1 = require("./constants"); const output_1 = require("../../common/output"); const serialization_1 = require("../../utils/serialization"); const errors_1 = require("../../utils/errors"); const bintools = bintools_1.default.getInstance(); const serialization = serialization_1.Serialization.getInstance(); /** * Takes a buffer representing the output and returns the proper Output instance. * * @param outputid A number representing the inputID parsed prior to the bytes passed in * * @returns An instance of an [[Output]]-extended class. */ const SelectOutputClass = (outputid, ...args) => { if (outputid === constants_1.AVMConstants.SECPXFEROUTPUTID || outputid === constants_1.AVMConstants.SECPXFEROUTPUTID_CODECONE) { return new SECPTransferOutput(...args); } else if (outputid === constants_1.AVMConstants.SECPMINTOUTPUTID || outputid === constants_1.AVMConstants.SECPMINTOUTPUTID_CODECONE) { return new SECPMintOutput(...args); } else if (outputid === constants_1.AVMConstants.NFTMINTOUTPUTID || outputid === constants_1.AVMConstants.NFTMINTOUTPUTID_CODECTWO) { return new NFTMintOutput(...args); } else if (outputid === constants_1.AVMConstants.NFTXFEROUTPUTID || outputid === constants_1.AVMConstants.NFTXFEROUTPUTID_CODECTWO) { return new NFTTransferOutput(...args); } throw new errors_1.OutputIdError("Error - SelectOutputClass: unknown outputid " + outputid); }; exports.SelectOutputClass = SelectOutputClass; class TransferableOutput extends output_1.StandardTransferableOutput { constructor() { super(...arguments); this._typeName = "TransferableOutput"; this._typeID = undefined; } //serialize is inherited deserialize(fields, encoding = "hex") { super.deserialize(fields, encoding); this.output = (0, exports.SelectOutputClass)(fields["output"]["_typeID"]); this.output.deserialize(fields["output"], encoding); } fromBuffer(bytes, offset = 0) { this.assetID = bintools.copyFrom(bytes, offset, offset + constants_1.AVMConstants.ASSETIDLEN); offset += constants_1.AVMConstants.ASSETIDLEN; const outputid = bintools .copyFrom(bytes, offset, offset + 4) .readUInt32BE(0); offset += 4; this.output = (0, exports.SelectOutputClass)(outputid); return this.output.fromBuffer(bytes, offset); } } exports.TransferableOutput = TransferableOutput; class AmountOutput extends output_1.StandardAmountOutput { constructor() { super(...arguments); this._typeName = "AmountOutput"; this._typeID = undefined; } //serialize and deserialize both are inherited /** * * @param assetID An assetID which is wrapped around the Buffer of the Output */ makeTransferable(assetID) { return new TransferableOutput(assetID, this); } select(id, ...args) { return (0, exports.SelectOutputClass)(id, ...args); } } exports.AmountOutput = AmountOutput; class NFTOutput extends output_1.BaseNFTOutput { constructor() { super(...arguments); this._typeName = "NFTOutput"; this._typeID = undefined; } //serialize and deserialize both are inherited /** * * @param assetID An assetID which is wrapped around the Buffer of the Output */ makeTransferable(assetID) { return new TransferableOutput(assetID, this); } select(id, ...args) { return (0, exports.SelectOutputClass)(id, ...args); } } exports.NFTOutput = NFTOutput; /** * An [[Output]] class which specifies an Output that carries an ammount for an assetID and uses secp256k1 signature scheme. */ class SECPTransferOutput extends AmountOutput { constructor() { super(...arguments); this._typeName = "SECPTransferOutput"; this._codecID = constants_1.AVMConstants.LATESTCODEC; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.SECPXFEROUTPUTID : constants_1.AVMConstants.SECPXFEROUTPUTID_CODECONE; } //serialize and deserialize both are inherited /** * Set the codecID * * @param codecID The codecID to set */ setCodecID(codecID) { if (codecID !== 0 && codecID !== 1) { /* istanbul ignore next */ throw new errors_1.CodecIdError("Error - SECPTransferOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1."); } this._codecID = codecID; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.SECPXFEROUTPUTID : constants_1.AVMConstants.SECPXFEROUTPUTID_CODECONE; } /** * Returns the outputID for this output */ getOutputID() { return this._typeID; } create(...args) { return new SECPTransferOutput(...args); } clone() { const newout = this.create(); newout.fromBuffer(this.toBuffer()); return newout; } } exports.SECPTransferOutput = SECPTransferOutput; /** * An [[Output]] class which specifies an Output that carries an ammount for an assetID and uses secp256k1 signature scheme. */ class SECPMintOutput extends output_1.Output { constructor() { super(...arguments); this._typeName = "SECPMintOutput"; this._codecID = constants_1.AVMConstants.LATESTCODEC; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.SECPMINTOUTPUTID : constants_1.AVMConstants.SECPMINTOUTPUTID_CODECONE; } //serialize and deserialize both are inherited /** * Set the codecID * * @param codecID The codecID to set */ setCodecID(codecID) { if (codecID !== 0 && codecID !== 1) { /* istanbul ignore next */ throw new errors_1.CodecIdError("Error - SECPMintOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1."); } this._codecID = codecID; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.SECPMINTOUTPUTID : constants_1.AVMConstants.SECPMINTOUTPUTID_CODECONE; } /** * Returns the outputID for this output */ getOutputID() { return this._typeID; } /** * * @param assetID An assetID which is wrapped around the Buffer of the Output */ makeTransferable(assetID) { return new TransferableOutput(assetID, this); } create(...args) { return new SECPMintOutput(...args); } clone() { const newout = this.create(); newout.fromBuffer(this.toBuffer()); return newout; } select(id, ...args) { return (0, exports.SelectOutputClass)(id, ...args); } } exports.SECPMintOutput = SECPMintOutput; /** * An [[Output]] class which specifies an Output that carries an NFT Mint and uses secp256k1 signature scheme. */ class NFTMintOutput extends NFTOutput { //serialize and deserialize both are inherited /** * Set the codecID * * @param codecID The codecID to set */ setCodecID(codecID) { if (codecID !== 0 && codecID !== 1) { /* istanbul ignore next */ throw new errors_1.CodecIdError("Error - NFTMintOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1."); } this._codecID = codecID; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.NFTMINTOUTPUTID : constants_1.AVMConstants.NFTMINTOUTPUTID_CODECTWO; } /** * Returns the outputID for this output */ getOutputID() { return this._typeID; } /** * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[NFTMintOutput]] and returns the size of the output. */ fromBuffer(utxobuff, offset = 0) { this.groupID = bintools.copyFrom(utxobuff, offset, offset + 4); offset += 4; return super.fromBuffer(utxobuff, offset); } /** * Returns the buffer representing the [[NFTMintOutput]] instance. */ toBuffer() { let superbuff = super.toBuffer(); let bsize = this.groupID.length + superbuff.length; let barr = [this.groupID, superbuff]; return buffer_1.Buffer.concat(barr, bsize); } create(...args) { return new NFTMintOutput(...args); } clone() { const newout = this.create(); newout.fromBuffer(this.toBuffer()); return newout; } /** * An [[Output]] class which contains an NFT mint for an assetID. * * @param groupID A number specifies the group this NFT is issued to * @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime * @param threshold A number representing the the threshold number of signers required to sign the transaction */ constructor(groupID = undefined, addresses = undefined, locktime = undefined, threshold = undefined) { super(addresses, locktime, threshold); this._typeName = "NFTMintOutput"; this._codecID = constants_1.AVMConstants.LATESTCODEC; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.NFTMINTOUTPUTID : constants_1.AVMConstants.NFTMINTOUTPUTID_CODECTWO; if (typeof groupID !== "undefined") { this.groupID.writeUInt32BE(groupID, 0); } } } exports.NFTMintOutput = NFTMintOutput; /** * An [[Output]] class which specifies an Output that carries an NFT and uses secp256k1 signature scheme. */ class NFTTransferOutput extends NFTOutput { serialize(encoding = "hex") { let fields = super.serialize(encoding); return Object.assign(Object.assign({}, fields), { payload: serialization.encoder(this.payload, encoding, "Buffer", "hex", this.payload.length) }); } deserialize(fields, encoding = "hex") { super.deserialize(fields, encoding); this.payload = serialization.decoder(fields["payload"], encoding, "hex", "Buffer"); this.sizePayload = buffer_1.Buffer.alloc(4); this.sizePayload.writeUInt32BE(this.payload.length, 0); } /** * Set the codecID * * @param codecID The codecID to set */ setCodecID(codecID) { if (codecID !== 0 && codecID !== 1) { /* istanbul ignore next */ throw new errors_1.CodecIdError("Error - NFTTransferOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1."); } this._codecID = codecID; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.NFTXFEROUTPUTID : constants_1.AVMConstants.NFTXFEROUTPUTID_CODECTWO; } /** * Returns the outputID for this output */ getOutputID() { return this._typeID; } /** * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[NFTTransferOutput]] and returns the size of the output. */ fromBuffer(utxobuff, offset = 0) { this.groupID = bintools.copyFrom(utxobuff, offset, offset + 4); offset += 4; this.sizePayload = bintools.copyFrom(utxobuff, offset, offset + 4); let psize = this.sizePayload.readUInt32BE(0); offset += 4; this.payload = bintools.copyFrom(utxobuff, offset, offset + psize); offset = offset + psize; return super.fromBuffer(utxobuff, offset); } /** * Returns the buffer representing the [[NFTTransferOutput]] instance. */ toBuffer() { const superbuff = super.toBuffer(); const bsize = this.groupID.length + this.sizePayload.length + this.payload.length + superbuff.length; this.sizePayload.writeUInt32BE(this.payload.length, 0); const barr = [ this.groupID, this.sizePayload, this.payload, superbuff ]; return buffer_1.Buffer.concat(barr, bsize); } create(...args) { return new NFTTransferOutput(...args); } clone() { const newout = this.create(); newout.fromBuffer(this.toBuffer()); return newout; } /** * An [[Output]] class which contains an NFT on an assetID. * * @param groupID A number representing the amount in the output * @param payload A {@link https://github.com/feross/buffer|Buffer} of max length 1024 * @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime * @param threshold A number representing the the threshold number of signers required to sign the transaction */ constructor(groupID = undefined, payload = undefined, addresses = undefined, locktime = undefined, threshold = undefined) { super(addresses, locktime, threshold); this._typeName = "NFTTransferOutput"; this._codecID = constants_1.AVMConstants.LATESTCODEC; this._typeID = this._codecID === 0 ? constants_1.AVMConstants.NFTXFEROUTPUTID : constants_1.AVMConstants.NFTXFEROUTPUTID_CODECTWO; this.sizePayload = buffer_1.Buffer.alloc(4); /** * Returns the payload as a {@link https://github.com/feross/buffer|Buffer} with content only. */ this.getPayload = () => bintools.copyFrom(this.payload); /** * Returns the payload as a {@link https://github.com/feross/buffer|Buffer} with length of payload prepended. */ this.getPayloadBuffer = () => buffer_1.Buffer.concat([ bintools.copyFrom(this.sizePayload), bintools.copyFrom(this.payload) ]); if (typeof groupID !== "undefined" && typeof payload !== "undefined") { this.groupID.writeUInt32BE(groupID, 0); this.sizePayload.writeUInt32BE(payload.length, 0); this.payload = bintools.copyFrom(payload, 0, payload.length); } } } exports.NFTTransferOutput = NFTTransferOutput; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../../src/apis/avm/outputs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module API-AVM-Outputs\n */\nimport { Buffer } from \"buffer/\"\nimport BN from \"bn.js\"\nimport BinTools from \"../../utils/bintools\"\nimport { AVMConstants } from \"./constants\"\nimport {\n  Output,\n  StandardAmountOutput,\n  StandardTransferableOutput,\n  BaseNFTOutput\n} from \"../../common/output\"\nimport { Serialization, SerializedEncoding } from \"../../utils/serialization\"\nimport { OutputIdError, CodecIdError } from \"../../utils/errors\"\n\nconst bintools: BinTools = BinTools.getInstance()\nconst serialization: Serialization = Serialization.getInstance()\n\n/**\n * Takes a buffer representing the output and returns the proper Output instance.\n *\n * @param outputid A number representing the inputID parsed prior to the bytes passed in\n *\n * @returns An instance of an [[Output]]-extended class.\n */\nexport const SelectOutputClass = (outputid: number, ...args: any[]): Output => {\n  if (\n    outputid === AVMConstants.SECPXFEROUTPUTID ||\n    outputid === AVMConstants.SECPXFEROUTPUTID_CODECONE\n  ) {\n    return new SECPTransferOutput(...args)\n  } else if (\n    outputid === AVMConstants.SECPMINTOUTPUTID ||\n    outputid === AVMConstants.SECPMINTOUTPUTID_CODECONE\n  ) {\n    return new SECPMintOutput(...args)\n  } else if (\n    outputid === AVMConstants.NFTMINTOUTPUTID ||\n    outputid === AVMConstants.NFTMINTOUTPUTID_CODECTWO\n  ) {\n    return new NFTMintOutput(...args)\n  } else if (\n    outputid === AVMConstants.NFTXFEROUTPUTID ||\n    outputid === AVMConstants.NFTXFEROUTPUTID_CODECTWO\n  ) {\n    return new NFTTransferOutput(...args)\n  }\n  throw new OutputIdError(\n    \"Error - SelectOutputClass: unknown outputid \" + outputid\n  )\n}\n\nexport class TransferableOutput extends StandardTransferableOutput {\n  protected _typeName = \"TransferableOutput\"\n  protected _typeID = undefined\n\n  //serialize is inherited\n\n  deserialize(fields: object, encoding: SerializedEncoding = \"hex\") {\n    super.deserialize(fields, encoding)\n    this.output = SelectOutputClass(fields[\"output\"][\"_typeID\"])\n    this.output.deserialize(fields[\"output\"], encoding)\n  }\n\n  fromBuffer(bytes: Buffer, offset: number = 0): number {\n    this.assetID = bintools.copyFrom(\n      bytes,\n      offset,\n      offset + AVMConstants.ASSETIDLEN\n    )\n    offset += AVMConstants.ASSETIDLEN\n    const outputid: number = bintools\n      .copyFrom(bytes, offset, offset + 4)\n      .readUInt32BE(0)\n    offset += 4\n    this.output = SelectOutputClass(outputid)\n    return this.output.fromBuffer(bytes, offset)\n  }\n}\n\nexport abstract class AmountOutput extends StandardAmountOutput {\n  protected _typeName = \"AmountOutput\"\n  protected _typeID = undefined\n\n  //serialize and deserialize both are inherited\n\n  /**\n   *\n   * @param assetID An assetID which is wrapped around the Buffer of the Output\n   */\n  makeTransferable(assetID: Buffer): TransferableOutput {\n    return new TransferableOutput(assetID, this)\n  }\n\n  select(id: number, ...args: any[]): Output {\n    return SelectOutputClass(id, ...args)\n  }\n}\n\nexport abstract class NFTOutput extends BaseNFTOutput {\n  protected _typeName = \"NFTOutput\"\n  protected _typeID = undefined\n\n  //serialize and deserialize both are inherited\n\n  /**\n   *\n   * @param assetID An assetID which is wrapped around the Buffer of the Output\n   */\n  makeTransferable(assetID: Buffer): TransferableOutput {\n    return new TransferableOutput(assetID, this)\n  }\n\n  select(id: number, ...args: any[]): Output {\n    return SelectOutputClass(id, ...args)\n  }\n}\n\n/**\n * An [[Output]] class which specifies an Output that carries an ammount for an assetID and uses secp256k1 signature scheme.\n */\nexport class SECPTransferOutput extends AmountOutput {\n  protected _typeName = \"SECPTransferOutput\"\n  protected _codecID = AVMConstants.LATESTCODEC\n  protected _typeID =\n    this._codecID === 0\n      ? AVMConstants.SECPXFEROUTPUTID\n      : AVMConstants.SECPXFEROUTPUTID_CODECONE\n\n  //serialize and deserialize both are inherited\n\n  /**\n   * Set the codecID\n   *\n   * @param codecID The codecID to set\n   */\n  setCodecID(codecID: number): void {\n    if (codecID !== 0 && codecID !== 1) {\n      /* istanbul ignore next */\n      throw new CodecIdError(\n        \"Error - SECPTransferOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1.\"\n      )\n    }\n    this._codecID = codecID\n    this._typeID =\n      this._codecID === 0\n        ? AVMConstants.SECPXFEROUTPUTID\n        : AVMConstants.SECPXFEROUTPUTID_CODECONE\n  }\n\n  /**\n   * Returns the outputID for this output\n   */\n  getOutputID(): number {\n    return this._typeID\n  }\n\n  create(...args: any[]): this {\n    return new SECPTransferOutput(...args) as this\n  }\n\n  clone(): this {\n    const newout: SECPTransferOutput = this.create()\n    newout.fromBuffer(this.toBuffer())\n    return newout as this\n  }\n}\n\n/**\n * An [[Output]] class which specifies an Output that carries an ammount for an assetID and uses secp256k1 signature scheme.\n */\nexport class SECPMintOutput extends Output {\n  protected _typeName = \"SECPMintOutput\"\n  protected _codecID = AVMConstants.LATESTCODEC\n  protected _typeID =\n    this._codecID === 0\n      ? AVMConstants.SECPMINTOUTPUTID\n      : AVMConstants.SECPMINTOUTPUTID_CODECONE\n\n  //serialize and deserialize both are inherited\n\n  /**\n   * Set the codecID\n   *\n   * @param codecID The codecID to set\n   */\n  setCodecID(codecID: number): void {\n    if (codecID !== 0 && codecID !== 1) {\n      /* istanbul ignore next */\n      throw new CodecIdError(\n        \"Error - SECPMintOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1.\"\n      )\n    }\n    this._codecID = codecID\n    this._typeID =\n      this._codecID === 0\n        ? AVMConstants.SECPMINTOUTPUTID\n        : AVMConstants.SECPMINTOUTPUTID_CODECONE\n  }\n\n  /**\n   * Returns the outputID for this output\n   */\n  getOutputID(): number {\n    return this._typeID\n  }\n\n  /**\n   *\n   * @param assetID An assetID which is wrapped around the Buffer of the Output\n   */\n  makeTransferable(assetID: Buffer): TransferableOutput {\n    return new TransferableOutput(assetID, this)\n  }\n\n  create(...args: any[]): this {\n    return new SECPMintOutput(...args) as this\n  }\n\n  clone(): this {\n    const newout: SECPMintOutput = this.create()\n    newout.fromBuffer(this.toBuffer())\n    return newout as this\n  }\n\n  select(id: number, ...args: any[]): Output {\n    return SelectOutputClass(id, ...args)\n  }\n}\n\n/**\n * An [[Output]] class which specifies an Output that carries an NFT Mint and uses secp256k1 signature scheme.\n */\nexport class NFTMintOutput extends NFTOutput {\n  protected _typeName = \"NFTMintOutput\"\n  protected _codecID = AVMConstants.LATESTCODEC\n  protected _typeID =\n    this._codecID === 0\n      ? AVMConstants.NFTMINTOUTPUTID\n      : AVMConstants.NFTMINTOUTPUTID_CODECTWO\n\n  //serialize and deserialize both are inherited\n\n  /**\n   * Set the codecID\n   *\n   * @param codecID The codecID to set\n   */\n  setCodecID(codecID: number): void {\n    if (codecID !== 0 && codecID !== 1) {\n      /* istanbul ignore next */\n      throw new CodecIdError(\n        \"Error - NFTMintOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1.\"\n      )\n    }\n    this._codecID = codecID\n    this._typeID =\n      this._codecID === 0\n        ? AVMConstants.NFTMINTOUTPUTID\n        : AVMConstants.NFTMINTOUTPUTID_CODECTWO\n  }\n\n  /**\n   * Returns the outputID for this output\n   */\n  getOutputID(): number {\n    return this._typeID\n  }\n\n  /**\n   * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[NFTMintOutput]] and returns the size of the output.\n   */\n  fromBuffer(utxobuff: Buffer, offset: number = 0): number {\n    this.groupID = bintools.copyFrom(utxobuff, offset, offset + 4)\n    offset += 4\n    return super.fromBuffer(utxobuff, offset)\n  }\n\n  /**\n   * Returns the buffer representing the [[NFTMintOutput]] instance.\n   */\n  toBuffer(): Buffer {\n    let superbuff: Buffer = super.toBuffer()\n    let bsize: number = this.groupID.length + superbuff.length\n    let barr: Buffer[] = [this.groupID, superbuff]\n    return Buffer.concat(barr, bsize)\n  }\n\n  create(...args: any[]): this {\n    return new NFTMintOutput(...args) as this\n  }\n\n  clone(): this {\n    const newout: NFTMintOutput = this.create()\n    newout.fromBuffer(this.toBuffer())\n    return newout as this\n  }\n\n  /**\n   * An [[Output]] class which contains an NFT mint for an assetID.\n   *\n   * @param groupID A number specifies the group this NFT is issued to\n   * @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing  addresses\n   * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime\n   * @param threshold A number representing the the threshold number of signers required to sign the transaction\n\n   */\n  constructor(\n    groupID: number = undefined,\n    addresses: Buffer[] = undefined,\n    locktime: BN = undefined,\n    threshold: number = undefined\n  ) {\n    super(addresses, locktime, threshold)\n    if (typeof groupID !== \"undefined\") {\n      this.groupID.writeUInt32BE(groupID, 0)\n    }\n  }\n}\n\n/**\n * An [[Output]] class which specifies an Output that carries an NFT and uses secp256k1 signature scheme.\n */\nexport class NFTTransferOutput extends NFTOutput {\n  protected _typeName = \"NFTTransferOutput\"\n  protected _codecID = AVMConstants.LATESTCODEC\n  protected _typeID =\n    this._codecID === 0\n      ? AVMConstants.NFTXFEROUTPUTID\n      : AVMConstants.NFTXFEROUTPUTID_CODECTWO\n\n  serialize(encoding: SerializedEncoding = \"hex\"): object {\n    let fields: object = super.serialize(encoding)\n    return {\n      ...fields,\n      payload: serialization.encoder(\n        this.payload,\n        encoding,\n        \"Buffer\",\n        \"hex\",\n        this.payload.length\n      )\n    }\n  }\n  deserialize(fields: object, encoding: SerializedEncoding = \"hex\") {\n    super.deserialize(fields, encoding)\n    this.payload = serialization.decoder(\n      fields[\"payload\"],\n      encoding,\n      \"hex\",\n      \"Buffer\"\n    )\n    this.sizePayload = Buffer.alloc(4)\n    this.sizePayload.writeUInt32BE(this.payload.length, 0)\n  }\n\n  protected sizePayload: Buffer = Buffer.alloc(4)\n  protected payload: Buffer\n\n  /**\n   * Set the codecID\n   *\n   * @param codecID The codecID to set\n   */\n  setCodecID(codecID: number): void {\n    if (codecID !== 0 && codecID !== 1) {\n      /* istanbul ignore next */\n      throw new CodecIdError(\n        \"Error - NFTTransferOutput.setCodecID: invalid codecID. Valid codecIDs are 0 and 1.\"\n      )\n    }\n    this._codecID = codecID\n    this._typeID =\n      this._codecID === 0\n        ? AVMConstants.NFTXFEROUTPUTID\n        : AVMConstants.NFTXFEROUTPUTID_CODECTWO\n  }\n\n  /**\n   * Returns the outputID for this output\n   */\n  getOutputID(): number {\n    return this._typeID\n  }\n\n  /**\n   * Returns the payload as a {@link https://github.com/feross/buffer|Buffer} with content only.\n   */\n  getPayload = (): Buffer => bintools.copyFrom(this.payload)\n\n  /**\n   * Returns the payload as a {@link https://github.com/feross/buffer|Buffer} with length of payload prepended.\n   */\n  getPayloadBuffer = (): Buffer =>\n    Buffer.concat([\n      bintools.copyFrom(this.sizePayload),\n      bintools.copyFrom(this.payload)\n    ])\n\n  /**\n   * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[NFTTransferOutput]] and returns the size of the output.\n   */\n  fromBuffer(utxobuff: Buffer, offset: number = 0): number {\n    this.groupID = bintools.copyFrom(utxobuff, offset, offset + 4)\n    offset += 4\n    this.sizePayload = bintools.copyFrom(utxobuff, offset, offset + 4)\n    let psize: number = this.sizePayload.readUInt32BE(0)\n    offset += 4\n    this.payload = bintools.copyFrom(utxobuff, offset, offset + psize)\n    offset = offset + psize\n    return super.fromBuffer(utxobuff, offset)\n  }\n\n  /**\n   * Returns the buffer representing the [[NFTTransferOutput]] instance.\n   */\n  toBuffer(): Buffer {\n    const superbuff: Buffer = super.toBuffer()\n    const bsize: number =\n      this.groupID.length +\n      this.sizePayload.length +\n      this.payload.length +\n      superbuff.length\n    this.sizePayload.writeUInt32BE(this.payload.length, 0)\n    const barr: Buffer[] = [\n      this.groupID,\n      this.sizePayload,\n      this.payload,\n      superbuff\n    ]\n    return Buffer.concat(barr, bsize)\n  }\n\n  create(...args: any[]): this {\n    return new NFTTransferOutput(...args) as this\n  }\n\n  clone(): this {\n    const newout: NFTTransferOutput = this.create()\n    newout.fromBuffer(this.toBuffer())\n    return newout as this\n  }\n\n  /**\n     * An [[Output]] class which contains an NFT on an assetID.\n     *\n     * @param groupID A number representing the amount in the output\n     * @param payload A {@link https://github.com/feross/buffer|Buffer} of max length 1024\n     * @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses\n     * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime\n     * @param threshold A number representing the the threshold number of signers required to sign the transaction\n\n     */\n  constructor(\n    groupID: number = undefined,\n    payload: Buffer = undefined,\n    addresses: Buffer[] = undefined,\n    locktime: BN = undefined,\n    threshold: number = undefined\n  ) {\n    super(addresses, locktime, threshold)\n    if (typeof groupID !== \"undefined\" && typeof payload !== \"undefined\") {\n      this.groupID.writeUInt32BE(groupID, 0)\n      this.sizePayload.writeUInt32BE(payload.length, 0)\n      this.payload = bintools.copyFrom(payload, 0, payload.length)\n    }\n  }\n}\n"]}