UNPKG

@hashgraph/sdk

Version:
223 lines (204 loc) 7.47 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _AccountId = _interopRequireDefault(require("../account/AccountId.cjs")); var _Timestamp = _interopRequireDefault(require("../Timestamp.cjs")); var HieroProto = _interopRequireWildcard(require("@hashgraph/proto")); var _long = _interopRequireDefault(require("long")); var _Cache = _interopRequireDefault(require("../Cache.cjs")); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } // SPDX-License-Identifier: Apache-2.0 /** * @typedef {import("../client/Client.js").default<*, *>} Client * @typedef {import("./TransactionReceipt.js").default} TransactionReceipt * @typedef {import("./TransactionRecord.js").default} TransactionRecord */ /** * The client-generated ID for a transaction. * * This is used for retrieving receipts and records for a transaction, for appending to a file * right after creating it, for instantiating a smart contract with bytecode in a file just created, * and internally by the network for detecting when duplicate transactions are submitted. */ class TransactionId { /** * Don't use this method directly. * Use `TransactionId.[generate|withNonce|withValidStart]()` instead. * * @param {?AccountId} accountId * @param {?Timestamp} validStart * @param {?boolean} scheduled * @param {?Long | number} nonce */ constructor(accountId, validStart, scheduled = false, nonce = null) { /** * The Account ID that paid for this transaction. * * @readonly */ this.accountId = accountId; /** * The time from when this transaction is valid. * * When a transaction is submitted there is additionally a validDuration (defaults to 120s) * and together they define a time window that a transaction may be processed in. * * @readonly */ this.validStart = validStart; this.scheduled = scheduled; this.nonce = null; if (nonce != null && nonce != 0) { this.setNonce(nonce); } Object.seal(this); } /** * @param {Long | number} nonce * @returns {TransactionId} */ setNonce(nonce) { this.nonce = typeof nonce === "number" ? _long.default.fromNumber(nonce) : nonce; return this; } /** * @param {AccountId} accountId * @param {Timestamp} validStart * @returns {TransactionId} */ static withValidStart(accountId, validStart) { return new TransactionId(accountId, validStart); } /** * Generates a new transaction ID for the given account ID. * * Note that transaction IDs are made of the valid start of the transaction and the account * that will be charged the transaction fees for the transaction. * * @param {AccountId | string} id * @returns {TransactionId} */ static generate(id) { return new TransactionId(typeof id === "string" ? _AccountId.default.fromString(id) : new _AccountId.default(id), _Timestamp.default.generate()); } /** * @param {string} wholeId * @returns {TransactionId} */ static fromString(wholeId) { let account, seconds, nanos, isScheduled, nonce; let rest; // 1.1.1@5.4?scheduled/117 [account, rest] = wholeId.split("@"); [seconds, rest] = rest.split("."); if (rest.includes("?")) { [nanos, rest] = rest.split("?scheduled"); isScheduled = true; if (rest.includes("/")) { nonce = rest.replace("/", ""); } else { nonce = null; } } else if (rest.includes("/")) { [nanos, nonce] = rest.split("/"); isScheduled = false; } else { nanos = rest; } return new TransactionId(_AccountId.default.fromString(account), new _Timestamp.default(_long.default.fromValue(seconds), _long.default.fromValue(nanos)), isScheduled, nonce != null ? _long.default.fromString(nonce) : null); } /** * @param {boolean} scheduled * @returns {this} */ setScheduled(scheduled) { this.scheduled = scheduled; return this; } /** * @returns {string} */ toString() { if (this.accountId != null && this.validStart != null) { const zeroPaddedNanos = String(this.validStart.nanos).padStart(9, "0"); const nonce = this.nonce != null ? "/".concat(this.nonce.toString()) : ""; const scheduled = this.scheduled ? "?scheduled" : ""; return `${this.accountId.toString()}@${this.validStart.seconds.toString()}.${zeroPaddedNanos}${scheduled}${nonce}`; } else { throw new Error("neither `accountId` nor `validStart` are set"); } } /** * @internal * @param {HieroProto.proto.ITransactionID} id * @returns {TransactionId} */ static _fromProtobuf(id) { if (id.accountID != null && id.transactionValidStart != null) { return new TransactionId(_AccountId.default._fromProtobuf(id.accountID), _Timestamp.default._fromProtobuf(id.transactionValidStart), id.scheduled != null ? id.scheduled : undefined, id.nonce != null ? id.nonce : undefined); } else { throw new Error("Neither `nonce` or `accountID` and `transactionValidStart` are set"); } } /** * @internal * @returns {HieroProto.proto.ITransactionID} */ _toProtobuf() { return { accountID: this.accountId != null ? this.accountId._toProtobuf() : null, transactionValidStart: this.validStart != null ? this.validStart._toProtobuf() : null, scheduled: this.scheduled, nonce: this.nonce != null ? this.nonce.toInt() : null }; } /** * @param {Uint8Array} bytes * @returns {TransactionId} */ static fromBytes(bytes) { return TransactionId._fromProtobuf(HieroProto.proto.TransactionID.decode(bytes)); } /** * @returns {Uint8Array} */ toBytes() { return HieroProto.proto.TransactionID.encode(this._toProtobuf()).finish(); } /** * @returns {TransactionId} */ clone() { return new TransactionId(this.accountId, this.validStart, this.scheduled, this.nonce); } /** * @param {TransactionId} other * @returns {number} */ compare(other) { const comparison = /** @type {AccountId} */this.accountId.compare(/** @type {AccountId} */other.accountId); if (comparison != 0) { return comparison; } return /** @type {Timestamp} */this.validStart.compare(/** @type {Timestamp} */other.validStart); } /** * @param {Client} client * @returns {Promise<TransactionReceipt>} */ getReceipt(client) { return _Cache.default.transactionReceiptQueryConstructor().setTransactionId(this).execute(client); } /** * @param {Client} client * @returns {Promise<TransactionRecord>} */ async getRecord(client) { await this.getReceipt(client); return _Cache.default.transactionRecordQueryConstructor().setTransactionId(this).execute(client); } } exports.default = TransactionId;