@c4tplatform/caminojs
Version:
Camino Platform JS Library
116 lines • 15.1 kB
JavaScript
;
/**
* @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"]}