PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/common
Просмотр файла: utxos.js
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.StandardUTXOSet = exports.StandardUTXO = void 0;
/**
* @packageDocumentation
* @module Common-UTXOs
*/
const buffer_1 = require("buffer/");
const bintools_1 = __importDefault(require("../utils/bintools"));
const bn_js_1 = __importDefault(require("bn.js"));
const output_1 = require("./output");
const helperfunctions_1 = require("../utils/helperfunctions");
const serialization_1 = require("../utils/serialization");
const errors_1 = require("../utils/errors");
/**
* @ignore
*/
const bintools = bintools_1.default.getInstance();
const serialization = serialization_1.Serialization.getInstance();
/**
* Class for representing a single StandardUTXO.
*/
class StandardUTXO extends serialization_1.Serializable {
/**
* Class for representing a single StandardUTXO.
*
* @param codecID Optional number which specifies the codeID of the UTXO. Default 0
* @param txID Optional {@link https://github.com/feross/buffer|Buffer} of transaction ID for the StandardUTXO
* @param txidx Optional {@link https://github.com/feross/buffer|Buffer} or number for the index of the transaction's [[Output]]
* @param assetID Optional {@link https://github.com/feross/buffer|Buffer} of the asset ID for the StandardUTXO
* @param outputid Optional {@link https://github.com/feross/buffer|Buffer} or number of the output ID for the StandardUTXO
*/
constructor(codecID = 0, txID = undefined, outputidx = undefined, assetID = undefined, output = undefined) {
super();
this._typeName = "StandardUTXO";
this._typeID = undefined;
this.codecID = buffer_1.Buffer.alloc(2);
this.txid = buffer_1.Buffer.alloc(32);
this.outputidx = buffer_1.Buffer.alloc(4);
this.assetID = buffer_1.Buffer.alloc(32);
this.output = undefined;
/**
* Returns the numeric representation of the CodecID.
*/
this.getCodecID = () => this.codecID.readUInt8(0);
/**
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the CodecID
*/
this.getCodecIDBuffer = () => this.codecID;
/**
* Returns a {@link https://github.com/feross/buffer|Buffer} of the TxID.
*/
this.getTxID = () => this.txid;
/**
* Returns a {@link https://github.com/feross/buffer|Buffer} of the OutputIdx.
*/
this.getOutputIdx = () => this.outputidx;
/**
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}.
*/
this.getAssetID = () => this.assetID;
/**
* Returns the UTXOID as a base-58 string (UTXOID is a string )
*/
this.getUTXOID = () => bintools.bufferToB58(buffer_1.Buffer.concat([this.getTxID(), this.getOutputIdx()]));
/**
* Returns a reference to the output
*/
this.getOutput = () => this.output;
if (typeof codecID !== "undefined") {
this.codecID.writeUInt8(codecID, 0);
}
if (typeof txID !== "undefined") {
this.txid = txID;
}
if (typeof outputidx === "number") {
this.outputidx.writeUInt32BE(outputidx, 0);
}
else if (outputidx instanceof buffer_1.Buffer) {
this.outputidx = outputidx;
}
if (typeof assetID !== "undefined") {
this.assetID = assetID;
}
if (typeof output !== "undefined") {
this.output = output;
}
}
serialize(encoding = "hex") {
let fields = super.serialize(encoding);
return Object.assign(Object.assign({}, fields), { codecID: serialization.encoder(this.codecID, encoding, "Buffer", "decimalString"), txid: serialization.encoder(this.txid, encoding, "Buffer", "cb58"), outputidx: serialization.encoder(this.outputidx, encoding, "Buffer", "decimalString"), assetID: serialization.encoder(this.assetID, encoding, "Buffer", "cb58"), output: this.output.serialize(encoding) });
}
deserialize(fields, encoding = "hex") {
super.deserialize(fields, encoding);
this.codecID = serialization.decoder(fields["codecID"], encoding, "decimalString", "Buffer", 2);
this.txid = serialization.decoder(fields["txid"], encoding, "cb58", "Buffer", 32);
this.outputidx = serialization.decoder(fields["outputidx"], encoding, "decimalString", "Buffer", 4);
this.assetID = serialization.decoder(fields["assetID"], encoding, "cb58", "Buffer", 32);
}
/**
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[StandardUTXO]].
*/
toBuffer() {
const outbuff = this.output.toBuffer();
const outputidbuffer = buffer_1.Buffer.alloc(4);
outputidbuffer.writeUInt32BE(this.output.getOutputID(), 0);
const barr = [
this.codecID,
this.txid,
this.outputidx,
this.assetID,
outputidbuffer,
outbuff
];
return buffer_1.Buffer.concat(barr, this.codecID.length +
this.txid.length +
this.outputidx.length +
this.assetID.length +
outputidbuffer.length +
outbuff.length);
}
}
exports.StandardUTXO = StandardUTXO;
/**
* Class representing a set of [[StandardUTXO]]s.
*/
class StandardUTXOSet extends serialization_1.Serializable {
constructor() {
super(...arguments);
this._typeName = "StandardUTXOSet";
this._typeID = undefined;
this.utxos = {};
this.addressUTXOs = {}; // maps address to utxoids:locktime
/**
* Returns true if the [[StandardUTXO]] is in the StandardUTXOSet.
*
* @param utxo Either a [[StandardUTXO]] a cb58 serialized string representing a StandardUTXO
*/
this.includes = (utxo) => {
let utxoX = undefined;
let utxoid = undefined;
try {
utxoX = this.parseUTXO(utxo);
utxoid = utxoX.getUTXOID();
}
catch (e) {
if (e instanceof Error) {
console.log(e.message);
}
else {
console.log(e);
}
return false;
}
return utxoid in this.utxos;
};
/**
* Removes a [[StandardUTXO]] from the [[StandardUTXOSet]] if it exists.
*
* @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO
*
* @returns A [[StandardUTXO]] if it was removed and undefined if nothing was removed.
*/
this.remove = (utxo) => {
let utxovar = undefined;
try {
utxovar = this.parseUTXO(utxo);
}
catch (e) {
if (e instanceof Error) {
console.log(e.message);
}
else {
console.log(e);
}
return undefined;
}
const utxoid = utxovar.getUTXOID();
if (!(utxoid in this.utxos)) {
return undefined;
}
delete this.utxos[`${utxoid}`];
const addresses = Object.keys(this.addressUTXOs);
for (let i = 0; i < addresses.length; i++) {
if (utxoid in this.addressUTXOs[addresses[`${i}`]]) {
delete this.addressUTXOs[addresses[`${i}`]][`${utxoid}`];
}
}
return utxovar;
};
/**
* Removes an array of [[StandardUTXO]]s to the [[StandardUTXOSet]].
*
* @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO
* @param overwrite If true, if the UTXOID already exists, overwrite it... default false
*
* @returns An array of UTXOs which were removed.
*/
this.removeArray = (utxos) => {
const removed = [];
for (let i = 0; i < utxos.length; i++) {
const result = this.remove(utxos[`${i}`]);
if (typeof result !== "undefined") {
removed.push(result);
}
}
return removed;
};
/**
* Gets a [[StandardUTXO]] from the [[StandardUTXOSet]] by its UTXOID.
*
* @param utxoid String representing the UTXOID
*
* @returns A [[StandardUTXO]] if it exists in the set.
*/
this.getUTXO = (utxoid) => this.utxos[`${utxoid}`];
/**
* Gets all the [[StandardUTXO]]s, optionally that match with UTXOIDs in an array
*
* @param utxoids An optional array of UTXOIDs, returns all [[StandardUTXO]]s if not provided
*
* @returns An array of [[StandardUTXO]]s.
*/
this.getAllUTXOs = (utxoids = undefined) => {
let results = [];
if (typeof utxoids !== "undefined" && Array.isArray(utxoids)) {
results = utxoids
.filter((utxoid) => this.utxos[`${utxoid}`])
.map((utxoid) => this.utxos[`${utxoid}`]);
}
else {
results = Object.values(this.utxos);
}
return results;
};
/**
* Gets all the [[StandardUTXO]]s as strings, optionally that match with UTXOIDs in an array.
*
* @param utxoids An optional array of UTXOIDs, returns all [[StandardUTXO]]s if not provided
*
* @returns An array of [[StandardUTXO]]s as cb58 serialized strings.
*/
this.getAllUTXOStrings = (utxoids = undefined) => {
const results = [];
const utxos = Object.keys(this.utxos);
if (typeof utxoids !== "undefined" && Array.isArray(utxoids)) {
for (let i = 0; i < utxoids.length; i++) {
if (utxoids[`${i}`] in this.utxos) {
results.push(this.utxos[utxoids[`${i}`]].toString());
}
}
}
else {
for (const u of utxos) {
results.push(this.utxos[`${u}`].toString());
}
}
return results;
};
/**
* Given an address or array of addresses, returns all the UTXOIDs for those addresses
*
* @param address An array of address {@link https://github.com/feross/buffer|Buffer}s
* @param spendable If true, only retrieves UTXOIDs whose locktime has passed
*
* @returns An array of addresses.
*/
this.getUTXOIDs = (addresses = undefined, spendable = true) => {
if (typeof addresses !== "undefined") {
const results = [];
const now = (0, helperfunctions_1.UnixNow)();
for (let i = 0; i < addresses.length; i++) {
if (addresses[`${i}`].toString("hex") in this.addressUTXOs) {
const entries = Object.entries(this.addressUTXOs[addresses[`${i}`].toString("hex")]);
for (const [utxoid, locktime] of entries) {
if ((results.indexOf(utxoid) === -1 &&
spendable &&
locktime.lte(now)) ||
!spendable) {
results.push(utxoid);
}
}
}
}
return results;
}
return Object.keys(this.utxos);
};
/**
* Gets the addresses in the [[StandardUTXOSet]] and returns an array of {@link https://github.com/feross/buffer|Buffer}.
*/
this.getAddresses = () => Object.keys(this.addressUTXOs).map((k) => buffer_1.Buffer.from(k, "hex"));
/**
* Returns the balance of a set of addresses in the StandardUTXOSet.
*
* @param addresses An array of addresses
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an cb58 serialized representation of an AssetID
* @param asOf The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}
*
* @returns Returns the total balance as a {@link https://github.com/indutny/bn.js/|BN}.
*/
this.getBalance = (addresses, assetID, asOf = undefined) => {
const utxoids = this.getUTXOIDs(addresses);
const utxos = this.getAllUTXOs(utxoids);
let spend = new bn_js_1.default(0);
let asset;
if (typeof assetID === "string") {
asset = bintools.cb58Decode(assetID);
}
else {
asset = assetID;
}
for (let i = 0; i < utxos.length; i++) {
if (utxos[`${i}`].getOutput() instanceof output_1.StandardAmountOutput &&
utxos[`${i}`].getAssetID().toString("hex") === asset.toString("hex") &&
utxos[`${i}`].getOutput().meetsThreshold(addresses, asOf)) {
spend = spend.add(utxos[`${i}`].getOutput().getAmount());
}
}
return spend;
};
/**
* Gets all the Asset IDs, optionally that match with Asset IDs in an array
*
* @param utxoids An optional array of Addresses as string or Buffer, returns all Asset IDs if not provided
*
* @returns An array of {@link https://github.com/feross/buffer|Buffer} representing the Asset IDs.
*/
this.getAssetIDs = (addresses = undefined) => {
const results = new Set();
let utxoids = [];
if (typeof addresses !== "undefined") {
utxoids = this.getUTXOIDs(addresses);
}
else {
utxoids = this.getUTXOIDs();
}
for (let i = 0; i < utxoids.length; i++) {
if (utxoids[`${i}`] in this.utxos && !(utxoids[`${i}`] in results)) {
results.add(this.utxos[utxoids[`${i}`]].getAssetID());
}
}
return [...results];
};
/**
* Returns a new set with copy of UTXOs in this and set parameter.
*
* @param utxoset The [[StandardUTXOSet]] to merge with this one
* @param hasUTXOIDs Will subselect a set of [[StandardUTXO]]s which have the UTXOIDs provided in this array, defults to all UTXOs
*
* @returns A new StandardUTXOSet that contains all the filtered elements.
*/
this.merge = (utxoset, hasUTXOIDs = undefined) => {
const results = this.create();
const utxos1 = this.getAllUTXOs(hasUTXOIDs);
const utxos2 = utxoset.getAllUTXOs(hasUTXOIDs);
const process = (utxo) => {
results.add(utxo);
};
utxos1.forEach(process);
utxos2.forEach(process);
return results;
};
/**
* Set intersetion between this set and a parameter.
*
* @param utxoset The set to intersect
*
* @returns A new StandardUTXOSet containing the intersection
*/
this.intersection = (utxoset) => {
const us1 = this.getUTXOIDs();
const us2 = utxoset.getUTXOIDs();
const results = us1.filter((utxoid) => us2.includes(utxoid));
return this.merge(utxoset, results);
};
/**
* Set difference between this set and a parameter.
*
* @param utxoset The set to difference
*
* @returns A new StandardUTXOSet containing the difference
*/
this.difference = (utxoset) => {
const us1 = this.getUTXOIDs();
const us2 = utxoset.getUTXOIDs();
const results = us1.filter((utxoid) => !us2.includes(utxoid));
return this.merge(utxoset, results);
};
/**
* Set symmetrical difference between this set and a parameter.
*
* @param utxoset The set to symmetrical difference
*
* @returns A new StandardUTXOSet containing the symmetrical difference
*/
this.symDifference = (utxoset) => {
const us1 = this.getUTXOIDs();
const us2 = utxoset.getUTXOIDs();
const results = us1
.filter((utxoid) => !us2.includes(utxoid))
.concat(us2.filter((utxoid) => !us1.includes(utxoid)));
return this.merge(utxoset, results);
};
/**
* Set union between this set and a parameter.
*
* @param utxoset The set to union
*
* @returns A new StandardUTXOSet containing the union
*/
this.union = (utxoset) => this.merge(utxoset);
/**
* Merges a set by the rule provided.
*
* @param utxoset The set to merge by the MergeRule
* @param mergeRule The [[MergeRule]] to apply
*
* @returns A new StandardUTXOSet containing the merged data
*
* @remarks
* The merge rules are as follows:
* * "intersection" - the intersection of the set
* * "differenceSelf" - the difference between the existing data and new set
* * "differenceNew" - the difference between the new data and the existing set
* * "symDifference" - the union of the differences between both sets of data
* * "union" - the unique set of all elements contained in both sets
* * "unionMinusNew" - the unique set of all elements contained in both sets, excluding values only found in the new set
* * "unionMinusSelf" - the unique set of all elements contained in both sets, excluding values only found in the existing set
*/
this.mergeByRule = (utxoset, mergeRule) => {
let uSet;
switch (mergeRule) {
case "intersection":
return this.intersection(utxoset);
case "differenceSelf":
return this.difference(utxoset);
case "differenceNew":
return utxoset.difference(this);
case "symDifference":
return this.symDifference(utxoset);
case "union":
return this.union(utxoset);
case "unionMinusNew":
uSet = this.union(utxoset);
return uSet.difference(utxoset);
case "unionMinusSelf":
uSet = this.union(utxoset);
return uSet.difference(this);
default:
throw new errors_1.MergeRuleError("Error - StandardUTXOSet.mergeByRule: bad MergeRule");
}
};
}
serialize(encoding = "hex") {
let fields = super.serialize(encoding);
let utxos = {};
for (let utxoid in this.utxos) {
let utxoidCleaned = serialization.encoder(utxoid, encoding, "base58", "base58");
utxos[`${utxoidCleaned}`] = this.utxos[`${utxoid}`].serialize(encoding);
}
let addressUTXOs = {};
for (let address in this.addressUTXOs) {
let addressCleaned = serialization.encoder(address, encoding, "hex", "cb58");
let utxobalance = {};
for (let utxoid in this.addressUTXOs[`${address}`]) {
let utxoidCleaned = serialization.encoder(utxoid, encoding, "base58", "base58");
utxobalance[`${utxoidCleaned}`] = serialization.encoder(this.addressUTXOs[`${address}`][`${utxoid}`], encoding, "BN", "decimalString");
}
addressUTXOs[`${addressCleaned}`] = utxobalance;
}
return Object.assign(Object.assign({}, fields), { utxos,
addressUTXOs });
}
/**
* Adds a [[StandardUTXO]] to the StandardUTXOSet.
*
* @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO
* @param overwrite If true, if the UTXOID already exists, overwrite it... default false
*
* @returns A [[StandardUTXO]] if one was added and undefined if nothing was added.
*/
add(utxo, overwrite = false) {
let utxovar = undefined;
try {
utxovar = this.parseUTXO(utxo);
}
catch (e) {
if (e instanceof Error) {
console.log(e.message);
}
else {
console.log(e);
}
return undefined;
}
const utxoid = utxovar.getUTXOID();
if (!(utxoid in this.utxos) || overwrite === true) {
this.utxos[`${utxoid}`] = utxovar;
const addresses = utxovar.getOutput().getAddresses();
const locktime = utxovar.getOutput().getLocktime();
for (let i = 0; i < addresses.length; i++) {
const address = addresses[`${i}`].toString("hex");
if (!(address in this.addressUTXOs)) {
this.addressUTXOs[`${address}`] = {};
}
this.addressUTXOs[`${address}`][`${utxoid}`] = locktime;
}
return utxovar;
}
return undefined;
}
/**
* Adds an array of [[StandardUTXO]]s to the [[StandardUTXOSet]].
*
* @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO
* @param overwrite If true, if the UTXOID already exists, overwrite it... default false
*
* @returns An array of StandardUTXOs which were added.
*/
addArray(utxos, overwrite = false) {
const added = [];
for (let i = 0; i < utxos.length; i++) {
let result = this.add(utxos[`${i}`], overwrite);
if (typeof result !== "undefined") {
added.push(result);
}
}
return added;
}
filter(args, lambda) {
let newset = this.clone();
let utxos = this.getAllUTXOs();
for (let i = 0; i < utxos.length; i++) {
if (lambda(utxos[`${i}`], ...args) === false) {
newset.remove(utxos[`${i}`]);
}
}
return newset;
}
}
exports.StandardUTXOSet = StandardUTXOSet;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utxos.js","sourceRoot":"","sources":["../../../src/common/utxos.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module Common-UTXOs\n */\nimport { Buffer } from \"buffer/\"\nimport BinTools from \"../utils/bintools\"\nimport BN from \"bn.js\"\nimport { Output, StandardAmountOutput } from \"./output\"\nimport { UnixNow } from \"../utils/helperfunctions\"\nimport { MergeRule } from \"../utils/constants\"\nimport {\n  Serializable,\n  Serialization,\n  SerializedEncoding\n} from \"../utils/serialization\"\nimport { MergeRuleError } from \"../utils/errors\"\n\n/**\n * @ignore\n */\nconst bintools: BinTools = BinTools.getInstance()\nconst serialization: Serialization = Serialization.getInstance()\n\n/**\n * Class for representing a single StandardUTXO.\n */\nexport abstract class StandardUTXO extends Serializable {\n  protected _typeName = \"StandardUTXO\"\n  protected _typeID = undefined\n\n  serialize(encoding: SerializedEncoding = \"hex\"): object {\n    let fields: object = super.serialize(encoding)\n    return {\n      ...fields,\n      codecID: serialization.encoder(\n        this.codecID,\n        encoding,\n        \"Buffer\",\n        \"decimalString\"\n      ),\n      txid: serialization.encoder(this.txid, encoding, \"Buffer\", \"cb58\"),\n      outputidx: serialization.encoder(\n        this.outputidx,\n        encoding,\n        \"Buffer\",\n        \"decimalString\"\n      ),\n      assetID: serialization.encoder(this.assetID, encoding, \"Buffer\", \"cb58\"),\n      output: this.output.serialize(encoding)\n    }\n  }\n  deserialize(fields: object, encoding: SerializedEncoding = \"hex\") {\n    super.deserialize(fields, encoding)\n    this.codecID = serialization.decoder(\n      fields[\"codecID\"],\n      encoding,\n      \"decimalString\",\n      \"Buffer\",\n      2\n    )\n    this.txid = serialization.decoder(\n      fields[\"txid\"],\n      encoding,\n      \"cb58\",\n      \"Buffer\",\n      32\n    )\n    this.outputidx = serialization.decoder(\n      fields[\"outputidx\"],\n      encoding,\n      \"decimalString\",\n      \"Buffer\",\n      4\n    )\n    this.assetID = serialization.decoder(\n      fields[\"assetID\"],\n      encoding,\n      \"cb58\",\n      \"Buffer\",\n      32\n    )\n  }\n\n  protected codecID: Buffer = Buffer.alloc(2)\n  protected txid: Buffer = Buffer.alloc(32)\n  protected outputidx: Buffer = Buffer.alloc(4)\n  protected assetID: Buffer = Buffer.alloc(32)\n  protected output: Output = undefined\n\n  /**\n   * Returns the numeric representation of the CodecID.\n   */\n  getCodecID = (): /* istanbul ignore next */ number =>\n    this.codecID.readUInt8(0)\n\n  /**\n   * Returns the {@link https://github.com/feross/buffer|Buffer} representation of the CodecID\n   */\n  getCodecIDBuffer = (): Buffer => this.codecID\n\n  /**\n   * Returns a {@link https://github.com/feross/buffer|Buffer} of the TxID.\n   */\n  getTxID = (): /* istanbul ignore next */ Buffer => this.txid\n\n  /**\n   * Returns a {@link https://github.com/feross/buffer|Buffer}  of the OutputIdx.\n   */\n  getOutputIdx = (): /* istanbul ignore next */ Buffer => this.outputidx\n\n  /**\n   * Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}.\n   */\n  getAssetID = (): Buffer => this.assetID\n\n  /**\n   * Returns the UTXOID as a base-58 string (UTXOID is a string )\n   */\n  getUTXOID = (): /* istanbul ignore next */ string =>\n    bintools.bufferToB58(Buffer.concat([this.getTxID(), this.getOutputIdx()]))\n\n  /**\n   * Returns a reference to the output\n   */\n  getOutput = (): Output => this.output\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[StandardUTXO]], parses it, populates the class, and returns the length of the StandardUTXO in bytes.\n   *\n   * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[StandardUTXO]]\n   */\n  abstract fromBuffer(bytes: Buffer, offset?: number): number\n\n  /**\n   * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[StandardUTXO]].\n   */\n  toBuffer(): Buffer {\n    const outbuff: Buffer = this.output.toBuffer()\n    const outputidbuffer: Buffer = Buffer.alloc(4)\n    outputidbuffer.writeUInt32BE(this.output.getOutputID(), 0)\n    const barr: Buffer[] = [\n      this.codecID,\n      this.txid,\n      this.outputidx,\n      this.assetID,\n      outputidbuffer,\n      outbuff\n    ]\n    return Buffer.concat(\n      barr,\n      this.codecID.length +\n        this.txid.length +\n        this.outputidx.length +\n        this.assetID.length +\n        outputidbuffer.length +\n        outbuff.length\n    )\n  }\n\n  abstract fromString(serialized: string): number\n\n  abstract toString(): string\n\n  abstract clone(): this\n\n  abstract create(\n    codecID?: number,\n    txid?: Buffer,\n    outputidx?: Buffer | number,\n    assetID?: Buffer,\n    output?: Output\n  ): this\n\n  /**\n   * Class for representing a single StandardUTXO.\n   *\n   * @param codecID Optional number which specifies the codeID of the UTXO. Default 0\n   * @param txID Optional {@link https://github.com/feross/buffer|Buffer} of transaction ID for the StandardUTXO\n   * @param txidx Optional {@link https://github.com/feross/buffer|Buffer} or number for the index of the transaction's [[Output]]\n   * @param assetID Optional {@link https://github.com/feross/buffer|Buffer} of the asset ID for the StandardUTXO\n   * @param outputid Optional {@link https://github.com/feross/buffer|Buffer} or number of the output ID for the StandardUTXO\n   */\n  constructor(\n    codecID: number = 0,\n    txID: Buffer = undefined,\n    outputidx: Buffer | number = undefined,\n    assetID: Buffer = undefined,\n    output: Output = undefined\n  ) {\n    super()\n    if (typeof codecID !== \"undefined\") {\n      this.codecID.writeUInt8(codecID, 0)\n    }\n    if (typeof txID !== \"undefined\") {\n      this.txid = txID\n    }\n    if (typeof outputidx === \"number\") {\n      this.outputidx.writeUInt32BE(outputidx, 0)\n    } else if (outputidx instanceof Buffer) {\n      this.outputidx = outputidx\n    }\n\n    if (typeof assetID !== \"undefined\") {\n      this.assetID = assetID\n    }\n    if (typeof output !== \"undefined\") {\n      this.output = output\n    }\n  }\n}\n/**\n * Class representing a set of [[StandardUTXO]]s.\n */\nexport abstract class StandardUTXOSet<\n  UTXOClass extends StandardUTXO\n> extends Serializable {\n  protected _typeName = \"StandardUTXOSet\"\n  protected _typeID = undefined\n\n  serialize(encoding: SerializedEncoding = \"hex\"): object {\n    let fields: object = super.serialize(encoding)\n    let utxos = {}\n    for (let utxoid in this.utxos) {\n      let utxoidCleaned: string = serialization.encoder(\n        utxoid,\n        encoding,\n        \"base58\",\n        \"base58\"\n      )\n      utxos[`${utxoidCleaned}`] = this.utxos[`${utxoid}`].serialize(encoding)\n    }\n    let addressUTXOs = {}\n    for (let address in this.addressUTXOs) {\n      let addressCleaned: string = serialization.encoder(\n        address,\n        encoding,\n        \"hex\",\n        \"cb58\"\n      )\n      let utxobalance = {}\n      for (let utxoid in this.addressUTXOs[`${address}`]) {\n        let utxoidCleaned: string = serialization.encoder(\n          utxoid,\n          encoding,\n          \"base58\",\n          \"base58\"\n        )\n        utxobalance[`${utxoidCleaned}`] = serialization.encoder(\n          this.addressUTXOs[`${address}`][`${utxoid}`],\n          encoding,\n          \"BN\",\n          \"decimalString\"\n        )\n      }\n      addressUTXOs[`${addressCleaned}`] = utxobalance\n    }\n    return {\n      ...fields,\n      utxos,\n      addressUTXOs\n    }\n  }\n\n  protected utxos: { [utxoid: string]: UTXOClass } = {}\n  protected addressUTXOs: { [address: string]: { [utxoid: string]: BN } } = {} // maps address to utxoids:locktime\n\n  abstract parseUTXO(utxo: UTXOClass | string): UTXOClass\n\n  /**\n   * Returns true if the [[StandardUTXO]] is in the StandardUTXOSet.\n   *\n   * @param utxo Either a [[StandardUTXO]] a cb58 serialized string representing a StandardUTXO\n   */\n  includes = (utxo: UTXOClass | string): boolean => {\n    let utxoX: UTXOClass = undefined\n    let utxoid: string = undefined\n    try {\n      utxoX = this.parseUTXO(utxo)\n      utxoid = utxoX.getUTXOID()\n    } catch (e) {\n      if (e instanceof Error) {\n        console.log(e.message)\n      } else {\n        console.log(e)\n      }\n      return false\n    }\n    return utxoid in this.utxos\n  }\n\n  /**\n   * Adds a [[StandardUTXO]] to the StandardUTXOSet.\n   *\n   * @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO\n   * @param overwrite If true, if the UTXOID already exists, overwrite it... default false\n   *\n   * @returns A [[StandardUTXO]] if one was added and undefined if nothing was added.\n   */\n  add(utxo: UTXOClass | string, overwrite: boolean = false): UTXOClass {\n    let utxovar: UTXOClass = undefined\n    try {\n      utxovar = this.parseUTXO(utxo)\n    } catch (e) {\n      if (e instanceof Error) {\n        console.log(e.message)\n      } else {\n        console.log(e)\n      }\n      return undefined\n    }\n\n    const utxoid: string = utxovar.getUTXOID()\n    if (!(utxoid in this.utxos) || overwrite === true) {\n      this.utxos[`${utxoid}`] = utxovar\n      const addresses: Buffer[] = utxovar.getOutput().getAddresses()\n      const locktime: BN = utxovar.getOutput().getLocktime()\n      for (let i: number = 0; i < addresses.length; i++) {\n        const address: string = addresses[`${i}`].toString(\"hex\")\n        if (!(address in this.addressUTXOs)) {\n          this.addressUTXOs[`${address}`] = {}\n        }\n        this.addressUTXOs[`${address}`][`${utxoid}`] = locktime\n      }\n      return utxovar\n    }\n    return undefined\n  }\n\n  /**\n   * Adds an array of [[StandardUTXO]]s to the [[StandardUTXOSet]].\n   *\n   * @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO\n   * @param overwrite If true, if the UTXOID already exists, overwrite it... default false\n   *\n   * @returns An array of StandardUTXOs which were added.\n   */\n  addArray(\n    utxos: string[] | UTXOClass[],\n    overwrite: boolean = false\n  ): StandardUTXO[] {\n    const added: UTXOClass[] = []\n    for (let i: number = 0; i < utxos.length; i++) {\n      let result: UTXOClass = this.add(utxos[`${i}`], overwrite)\n      if (typeof result !== \"undefined\") {\n        added.push(result)\n      }\n    }\n    return added\n  }\n\n  /**\n   * Removes a [[StandardUTXO]] from the [[StandardUTXOSet]] if it exists.\n   *\n   * @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO\n   *\n   * @returns A [[StandardUTXO]] if it was removed and undefined if nothing was removed.\n   */\n  remove = (utxo: UTXOClass | string): UTXOClass => {\n    let utxovar: UTXOClass = undefined\n    try {\n      utxovar = this.parseUTXO(utxo)\n    } catch (e) {\n      if (e instanceof Error) {\n        console.log(e.message)\n      } else {\n        console.log(e)\n      }\n      return undefined\n    }\n\n    const utxoid: string = utxovar.getUTXOID()\n    if (!(utxoid in this.utxos)) {\n      return undefined\n    }\n    delete this.utxos[`${utxoid}`]\n    const addresses = Object.keys(this.addressUTXOs)\n    for (let i: number = 0; i < addresses.length; i++) {\n      if (utxoid in this.addressUTXOs[addresses[`${i}`]]) {\n        delete this.addressUTXOs[addresses[`${i}`]][`${utxoid}`]\n      }\n    }\n    return utxovar\n  }\n\n  /**\n   * Removes an array of [[StandardUTXO]]s to the [[StandardUTXOSet]].\n   *\n   * @param utxo Either a [[StandardUTXO]] an cb58 serialized string representing a StandardUTXO\n   * @param overwrite If true, if the UTXOID already exists, overwrite it... default false\n   *\n   * @returns An array of UTXOs which were removed.\n   */\n  removeArray = (utxos: string[] | UTXOClass[]): UTXOClass[] => {\n    const removed: UTXOClass[] = []\n    for (let i: number = 0; i < utxos.length; i++) {\n      const result: UTXOClass = this.remove(utxos[`${i}`])\n      if (typeof result !== \"undefined\") {\n        removed.push(result)\n      }\n    }\n    return removed\n  }\n\n  /**\n   * Gets a [[StandardUTXO]] from the [[StandardUTXOSet]] by its UTXOID.\n   *\n   * @param utxoid String representing the UTXOID\n   *\n   * @returns A [[StandardUTXO]] if it exists in the set.\n   */\n  getUTXO = (utxoid: string): UTXOClass => this.utxos[`${utxoid}`]\n\n  /**\n   * Gets all the [[StandardUTXO]]s, optionally that match with UTXOIDs in an array\n   *\n   * @param utxoids An optional array of UTXOIDs, returns all [[StandardUTXO]]s if not provided\n   *\n   * @returns An array of [[StandardUTXO]]s.\n   */\n  getAllUTXOs = (utxoids: string[] = undefined): UTXOClass[] => {\n    let results: UTXOClass[] = []\n    if (typeof utxoids !== \"undefined\" && Array.isArray(utxoids)) {\n      results = utxoids\n        .filter((utxoid) => this.utxos[`${utxoid}`])\n        .map((utxoid) => this.utxos[`${utxoid}`])\n    } else {\n      results = Object.values(this.utxos)\n    }\n    return results\n  }\n\n  /**\n   * Gets all the [[StandardUTXO]]s as strings, optionally that match with UTXOIDs in an array.\n   *\n   * @param utxoids An optional array of UTXOIDs, returns all [[StandardUTXO]]s if not provided\n   *\n   * @returns An array of [[StandardUTXO]]s as cb58 serialized strings.\n   */\n  getAllUTXOStrings = (utxoids: string[] = undefined): string[] => {\n    const results: string[] = []\n    const utxos = Object.keys(this.utxos)\n    if (typeof utxoids !== \"undefined\" && Array.isArray(utxoids)) {\n      for (let i: number = 0; i < utxoids.length; i++) {\n        if (utxoids[`${i}`] in this.utxos) {\n          results.push(this.utxos[utxoids[`${i}`]].toString())\n        }\n      }\n    } else {\n      for (const u of utxos) {\n        results.push(this.utxos[`${u}`].toString())\n      }\n    }\n    return results\n  }\n\n  /**\n   * Given an address or array of addresses, returns all the UTXOIDs for those addresses\n   *\n   * @param address An array of address {@link https://github.com/feross/buffer|Buffer}s\n   * @param spendable If true, only retrieves UTXOIDs whose locktime has passed\n   *\n   * @returns An array of addresses.\n   */\n  getUTXOIDs = (\n    addresses: Buffer[] = undefined,\n    spendable: boolean = true\n  ): string[] => {\n    if (typeof addresses !== \"undefined\") {\n      const results: string[] = []\n      const now: BN = UnixNow()\n      for (let i: number = 0; i < addresses.length; i++) {\n        if (addresses[`${i}`].toString(\"hex\") in this.addressUTXOs) {\n          const entries = Object.entries(\n            this.addressUTXOs[addresses[`${i}`].toString(\"hex\")]\n          )\n          for (const [utxoid, locktime] of entries) {\n            if (\n              (results.indexOf(utxoid) === -1 &&\n                spendable &&\n                locktime.lte(now)) ||\n              !spendable\n            ) {\n              results.push(utxoid)\n            }\n          }\n        }\n      }\n      return results\n    }\n    return Object.keys(this.utxos)\n  }\n\n  /**\n   * Gets the addresses in the [[StandardUTXOSet]] and returns an array of {@link https://github.com/feross/buffer|Buffer}.\n   */\n  getAddresses = (): Buffer[] =>\n    Object.keys(this.addressUTXOs).map((k) => Buffer.from(k, \"hex\"))\n\n  /**\n   * Returns the balance of a set of addresses in the StandardUTXOSet.\n   *\n   * @param addresses An array of addresses\n   * @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an cb58 serialized representation of an AssetID\n   * @param asOf The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}\n   *\n   * @returns Returns the total balance as a {@link https://github.com/indutny/bn.js/|BN}.\n   */\n  getBalance = (\n    addresses: Buffer[],\n    assetID: Buffer | string,\n    asOf: BN = undefined\n  ): BN => {\n    const utxoids: string[] = this.getUTXOIDs(addresses)\n    const utxos: StandardUTXO[] = this.getAllUTXOs(utxoids)\n    let spend: BN = new BN(0)\n    let asset: Buffer\n    if (typeof assetID === \"string\") {\n      asset = bintools.cb58Decode(assetID)\n    } else {\n      asset = assetID\n    }\n    for (let i: number = 0; i < utxos.length; i++) {\n      if (\n        utxos[`${i}`].getOutput() instanceof StandardAmountOutput &&\n        utxos[`${i}`].getAssetID().toString(\"hex\") === asset.toString(\"hex\") &&\n        utxos[`${i}`].getOutput().meetsThreshold(addresses, asOf)\n      ) {\n        spend = spend.add(\n          (utxos[`${i}`].getOutput() as StandardAmountOutput).getAmount()\n        )\n      }\n    }\n    return spend\n  }\n\n  /**\n   * Gets all the Asset IDs, optionally that match with Asset IDs in an array\n   *\n   * @param utxoids An optional array of Addresses as string or Buffer, returns all Asset IDs if not provided\n   *\n   * @returns An array of {@link https://github.com/feross/buffer|Buffer} representing the Asset IDs.\n   */\n  getAssetIDs = (addresses: Buffer[] = undefined): Buffer[] => {\n    const results: Set<Buffer> = new Set()\n    let utxoids: string[] = []\n    if (typeof addresses !== \"undefined\") {\n      utxoids = this.getUTXOIDs(addresses)\n    } else {\n      utxoids = this.getUTXOIDs()\n    }\n\n    for (let i: number = 0; i < utxoids.length; i++) {\n      if (utxoids[`${i}`] in this.utxos && !(utxoids[`${i}`] in results)) {\n        results.add(this.utxos[utxoids[`${i}`]].getAssetID())\n      }\n    }\n\n    return [...results]\n  }\n\n  abstract clone(): this\n\n  abstract create(...args: any[]): this\n\n  filter(\n    args: any[],\n    lambda: (utxo: UTXOClass, ...largs: any[]) => boolean\n  ): this {\n    let newset: this = this.clone()\n    let utxos: UTXOClass[] = this.getAllUTXOs()\n    for (let i: number = 0; i < utxos.length; i++) {\n      if (lambda(utxos[`${i}`], ...args) === false) {\n        newset.remove(utxos[`${i}`])\n      }\n    }\n    return newset\n  }\n\n  /**\n   * Returns a new set with copy of UTXOs in this and set parameter.\n   *\n   * @param utxoset The [[StandardUTXOSet]] to merge with this one\n   * @param hasUTXOIDs Will subselect a set of [[StandardUTXO]]s which have the UTXOIDs provided in this array, defults to all UTXOs\n   *\n   * @returns A new StandardUTXOSet that contains all the filtered elements.\n   */\n  merge = (utxoset: this, hasUTXOIDs: string[] = undefined): this => {\n    const results: this = this.create()\n    const utxos1: UTXOClass[] = this.getAllUTXOs(hasUTXOIDs)\n    const utxos2: UTXOClass[] = utxoset.getAllUTXOs(hasUTXOIDs)\n    const process = (utxo: UTXOClass) => {\n      results.add(utxo)\n    }\n    utxos1.forEach(process)\n    utxos2.forEach(process)\n    return results as this\n  }\n\n  /**\n   * Set intersetion between this set and a parameter.\n   *\n   * @param utxoset The set to intersect\n   *\n   * @returns A new StandardUTXOSet containing the intersection\n   */\n  intersection = (utxoset: this): this => {\n    const us1: string[] = this.getUTXOIDs()\n    const us2: string[] = utxoset.getUTXOIDs()\n    const results: string[] = us1.filter((utxoid) => us2.includes(utxoid))\n    return this.merge(utxoset, results) as this\n  }\n\n  /**\n   * Set difference between this set and a parameter.\n   *\n   * @param utxoset The set to difference\n   *\n   * @returns A new StandardUTXOSet containing the difference\n   */\n  difference = (utxoset: this): this => {\n    const us1: string[] = this.getUTXOIDs()\n    const us2: string[] = utxoset.getUTXOIDs()\n    const results: string[] = us1.filter((utxoid) => !us2.includes(utxoid))\n    return this.merge(utxoset, results) as this\n  }\n\n  /**\n   * Set symmetrical difference between this set and a parameter.\n   *\n   * @param utxoset The set to symmetrical difference\n   *\n   * @returns A new StandardUTXOSet containing the symmetrical difference\n   */\n  symDifference = (utxoset: this): this => {\n    const us1: string[] = this.getUTXOIDs()\n    const us2: string[] = utxoset.getUTXOIDs()\n    const results: string[] = us1\n      .filter((utxoid) => !us2.includes(utxoid))\n      .concat(us2.filter((utxoid) => !us1.includes(utxoid)))\n    return this.merge(utxoset, results) as this\n  }\n\n  /**\n   * Set union between this set and a parameter.\n   *\n   * @param utxoset The set to union\n   *\n   * @returns A new StandardUTXOSet containing the union\n   */\n  union = (utxoset: this): this => this.merge(utxoset) as this\n\n  /**\n   * Merges a set by the rule provided.\n   *\n   * @param utxoset The set to merge by the MergeRule\n   * @param mergeRule The [[MergeRule]] to apply\n   *\n   * @returns A new StandardUTXOSet containing the merged data\n   *\n   * @remarks\n   * The merge rules are as follows:\n   *   * \"intersection\" - the intersection of the set\n   *   * \"differenceSelf\" - the difference between the existing data and new set\n   *   * \"differenceNew\" - the difference between the new data and the existing set\n   *   * \"symDifference\" - the union of the differences between both sets of data\n   *   * \"union\" - the unique set of all elements contained in both sets\n   *   * \"unionMinusNew\" - the unique set of all elements contained in both sets, excluding values only found in the new set\n   *   * \"unionMinusSelf\" - the unique set of all elements contained in both sets, excluding values only found in the existing set\n   */\n  mergeByRule = (utxoset: this, mergeRule: MergeRule): this => {\n    let uSet: this\n    switch (mergeRule) {\n      case \"intersection\":\n        return this.intersection(utxoset)\n      case \"differenceSelf\":\n        return this.difference(utxoset)\n      case \"differenceNew\":\n        return utxoset.difference(this) as this\n      case \"symDifference\":\n        return this.symDifference(utxoset)\n      case \"union\":\n        return this.union(utxoset)\n      case \"unionMinusNew\":\n        uSet = this.union(utxoset)\n        return uSet.difference(utxoset) as this\n      case \"unionMinusSelf\":\n        uSet = this.union(utxoset)\n        return uSet.difference(this) as this\n      default:\n        throw new MergeRuleError(\n          \"Error - StandardUTXOSet.mergeByRule: bad MergeRule\"\n        )\n    }\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!