UNPKG

@c4tplatform/caminojs

Version:
116 lines 15.1 kB
"use strict"; /** * @packageDocumentation * @module API-AVM-InitialStates */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.InitialStates = void 0; const buffer_1 = require("buffer/"); const bintools_1 = __importDefault(require("../../utils/bintools")); const output_1 = require("../../common/output"); const outputs_1 = require("./outputs"); const constants_1 = require("./constants"); const serialization_1 = require("../../utils/serialization"); /** * @ignore */ const bintools = bintools_1.default.getInstance(); /** * Class for creating initial output states used in asset creation */ class InitialStates extends serialization_1.Serializable { constructor() { super(...arguments); this._typeName = "InitialStates"; this._typeID = undefined; this.fxs = {}; } serialize(encoding = "hex") { const fields = super.serialize(encoding); const flatfxs = {}; for (let fxid in this.fxs) { flatfxs[`${fxid}`] = this.fxs[`${fxid}`].map((o) => o.serialize(encoding)); } return Object.assign(Object.assign({}, fields), { fxs: flatfxs }); } deserialize(fields, encoding = "hex") { super.deserialize(fields, encoding); const unflat = {}; for (let fxid in fields["fxs"]) { unflat[`${fxid}`] = fields["fxs"][`${fxid}`].map((o) => { const out = (0, outputs_1.SelectOutputClass)(o["_typeID"]); out.deserialize(o, encoding); return out; }); } this.fxs = unflat; } /** * * @param out The output state to add to the collection * @param fxid The FxID that will be used for this output, default AVMConstants.SECPFXID */ addOutput(out, fxid = constants_1.AVMConstants.SECPFXID) { if (!(fxid in this.fxs)) { this.fxs[`${fxid}`] = []; } this.fxs[`${fxid}`].push(out); } fromBuffer(bytes, offset = 0) { const result = []; const klen = bintools.copyFrom(bytes, offset, offset + 4); offset += 4; const klennum = klen.readUInt32BE(0); for (let i = 0; i < klennum; i++) { const fxidbuff = bintools.copyFrom(bytes, offset, offset + 4); offset += 4; const fxid = fxidbuff.readUInt32BE(0); result[`${fxid}`] = []; const statelenbuff = bintools.copyFrom(bytes, offset, offset + 4); offset += 4; const statelen = statelenbuff.readUInt32BE(0); for (let j = 0; j < statelen; j++) { const outputid = bintools .copyFrom(bytes, offset, offset + 4) .readUInt32BE(0); offset += 4; const out = (0, outputs_1.SelectOutputClass)(outputid); offset = out.fromBuffer(bytes, offset); result[`${fxid}`].push(out); } } this.fxs = result; return offset; } toBuffer() { const buff = []; const keys = Object.keys(this.fxs) .map((k) => parseInt(k, 10)) .sort(); const klen = buffer_1.Buffer.alloc(4); klen.writeUInt32BE(keys.length, 0); buff.push(klen); for (let i = 0; i < keys.length; i++) { const fxid = keys[`${i}`]; const fxidbuff = buffer_1.Buffer.alloc(4); fxidbuff.writeUInt32BE(fxid, 0); buff.push(fxidbuff); const initialState = this.fxs[`${fxid}`].sort((0, output_1.BaseOutputComparator)()); const statelen = buffer_1.Buffer.alloc(4); statelen.writeUInt32BE(initialState.length, 0); buff.push(statelen); for (let j = 0; j < initialState.length; j++) { const outputid = buffer_1.Buffer.alloc(4); outputid.writeInt32BE(initialState[`${j}`].getOutputID(), 0); buff.push(outputid); buff.push(initialState[`${j}`].toBuffer()); } } return buffer_1.Buffer.concat(buff); } } exports.InitialStates = InitialStates; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"initialstates.js","sourceRoot":"","sources":["../../../src/apis/avm/initialstates.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module API-AVM-InitialStates\n */\n\nimport { Buffer } from \"buffer/\"\nimport BinTools from \"../../utils/bintools\"\nimport { BaseOutput, BaseOutputComparator } from \"../../common/output\"\nimport { SelectOutputClass } from \"./outputs\"\nimport { AVMConstants } from \"./constants\"\nimport { Serializable, SerializedEncoding } from \"../../utils/serialization\"\n/**\n * @ignore\n */\nconst bintools: BinTools = BinTools.getInstance()\n\n/**\n * Class for creating initial output states used in asset creation\n */\nexport class InitialStates extends Serializable {\n  protected _typeName = \"InitialStates\"\n  protected _typeID = undefined\n\n  serialize(encoding: SerializedEncoding = \"hex\"): object {\n    const fields: object = super.serialize(encoding)\n    const flatfxs: object = {}\n    for (let fxid in this.fxs) {\n      flatfxs[`${fxid}`] = this.fxs[`${fxid}`].map((o: BaseOutput): object =>\n        o.serialize(encoding)\n      )\n    }\n    return {\n      ...fields,\n      fxs: flatfxs\n    }\n  }\n  deserialize(fields: object, encoding: SerializedEncoding = \"hex\") {\n    super.deserialize(fields, encoding)\n    const unflat: { [fxid: number]: BaseOutput[] } = {}\n    for (let fxid in fields[\"fxs\"]) {\n      unflat[`${fxid}`] = fields[\"fxs\"][`${fxid}`].map((o: object) => {\n        const out: BaseOutput = SelectOutputClass(o[\"_typeID\"])\n        out.deserialize(o, encoding)\n        return out\n      })\n    }\n    this.fxs = unflat\n  }\n\n  protected fxs: { [fxid: number]: BaseOutput[] } = {}\n\n  /**\n   *\n   * @param out The output state to add to the collection\n   * @param fxid The FxID that will be used for this output, default AVMConstants.SECPFXID\n   */\n  addOutput(out: BaseOutput, fxid: number = AVMConstants.SECPFXID): void {\n    if (!(fxid in this.fxs)) {\n      this.fxs[`${fxid}`] = []\n    }\n    this.fxs[`${fxid}`].push(out)\n  }\n\n  fromBuffer(bytes: Buffer, offset: number = 0): number {\n    const result: { [fxid: number]: BaseOutput[] } = []\n    const klen: Buffer = bintools.copyFrom(bytes, offset, offset + 4)\n    offset += 4\n    const klennum: number = klen.readUInt32BE(0)\n    for (let i: number = 0; i < klennum; i++) {\n      const fxidbuff: Buffer = bintools.copyFrom(bytes, offset, offset + 4)\n      offset += 4\n      const fxid: number = fxidbuff.readUInt32BE(0)\n      result[`${fxid}`] = []\n      const statelenbuff: Buffer = bintools.copyFrom(bytes, offset, offset + 4)\n      offset += 4\n      const statelen: number = statelenbuff.readUInt32BE(0)\n      for (let j: number = 0; j < statelen; j++) {\n        const outputid: number = bintools\n          .copyFrom(bytes, offset, offset + 4)\n          .readUInt32BE(0)\n        offset += 4\n        const out: BaseOutput = SelectOutputClass(outputid)\n        offset = out.fromBuffer(bytes, offset)\n        result[`${fxid}`].push(out)\n      }\n    }\n    this.fxs = result\n    return offset\n  }\n\n  toBuffer(): Buffer {\n    const buff: Buffer[] = []\n    const keys: number[] = Object.keys(this.fxs)\n      .map((k: string): number => parseInt(k, 10))\n      .sort()\n    const klen: Buffer = Buffer.alloc(4)\n    klen.writeUInt32BE(keys.length, 0)\n    buff.push(klen)\n    for (let i: number = 0; i < keys.length; i++) {\n      const fxid: number = keys[`${i}`]\n      const fxidbuff: Buffer = Buffer.alloc(4)\n      fxidbuff.writeUInt32BE(fxid, 0)\n      buff.push(fxidbuff)\n      const initialState = this.fxs[`${fxid}`].sort(BaseOutputComparator())\n      const statelen: Buffer = Buffer.alloc(4)\n      statelen.writeUInt32BE(initialState.length, 0)\n      buff.push(statelen)\n      for (let j: number = 0; j < initialState.length; j++) {\n        const outputid: Buffer = Buffer.alloc(4)\n        outputid.writeInt32BE(initialState[`${j}`].getOutputID(), 0)\n        buff.push(outputid)\n        buff.push(initialState[`${j}`].toBuffer())\n      }\n    }\n    return Buffer.concat(buff)\n  }\n}\n"]}