PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/apis/avm

Просмотр файла: outputs.js

"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_CODECONE) {
        return new NFTMintOutput(...args);
    }
    else if (outputid === constants_1.AVMConstants.NFTXFEROUTPUTID ||
        outputid === constants_1.AVMConstants.NFTXFEROUTPUTID_CODECONE) {
        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 {
    /**
     * 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_CODECONE;
        if (typeof groupID !== "undefined") {
            this.groupID.writeUInt32BE(groupID, 0);
        }
    }
    //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_CODECONE;
    }
    /**
     * 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;
    }
}
exports.NFTMintOutput = NFTMintOutput;
/**
 * An [[Output]] class which specifies an Output that carries an NFT and uses secp256k1 signature scheme.
 */
class NFTTransferOutput extends NFTOutput {
    /**
       * 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_CODECONE;
        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);
        }
    }
    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_CODECONE;
    }
    /**
     * 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;
    }
}
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_CODECONE\n  ) {\n    return new NFTMintOutput(...args)\n  } else if (\n    outputid === AVMConstants.NFTXFEROUTPUTID ||\n    outputid === AVMConstants.NFTXFEROUTPUTID_CODECONE\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_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 - 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_CODECONE\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_CODECONE\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_CODECONE\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"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!