UNPKG

@hashgraph/sdk

Version:
165 lines (152 loc) 6.48 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _Transaction = _interopRequireWildcard(require("../transaction/Transaction.cjs")); var _AccountId = _interopRequireDefault(require("./AccountId.cjs")); var _NftId = _interopRequireDefault(require("../token/NftId.cjs")); var _TokenNftAllowance = _interopRequireDefault(require("./TokenNftAllowance.cjs")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } 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); } // SPDX-License-Identifier: Apache-2.0 /** * @namespace proto * @typedef {import("@hiero-ledger/proto").proto.ITransaction} HieroProto.proto.ITransaction * @typedef {import("@hiero-ledger/proto").proto.ISignedTransaction} HieroProto.proto.ISignedTransaction * @typedef {import("@hiero-ledger/proto").proto.TransactionBody} HieroProto.proto.TransactionBody * @typedef {import("@hiero-ledger/proto").proto.ITransactionBody} HieroProto.proto.ITransactionBody * @typedef {import("@hiero-ledger/proto").proto.ITransactionResponse} HieroProto.proto.ITransactionResponse * @typedef {import("@hiero-ledger/proto").proto.ICryptoDeleteAllowanceTransactionBody} HieroProto.proto.ICryptoDeleteAllowanceTransactionBody * @typedef {import("@hiero-ledger/proto").proto.IAccountID} HieroProto.proto.IAccountID */ /** * @typedef {import("./HbarAllowance.js").default} HbarAllowance * @typedef {import("./TokenAllowance.js").default} TokenAllowance * @typedef {import("../channel/Channel.js").default} Channel * @typedef {import("../client/Client.js").default<*, *>} Client * @typedef {import("../transaction/TransactionId.js").default} TransactionId * @typedef {import("bignumber.js").default} BigNumber * @typedef {import("../long.js").LongObject} LongObject */ /** * Change properties for the given account. */ class AccountAllowanceDeleteTransaction extends _Transaction.default { /** * @param {object} [props] * @param {HbarAllowance[]} [props.hbarAllowances] * @param {TokenAllowance[]} [props.tokenAllowances] * @param {TokenNftAllowance[]} [props.nftAllowances] */ constructor(props = {}) { super(); /** * @private * @type {TokenNftAllowance[]} */ this._nftAllowances = props.nftAllowances != null ? props.nftAllowances : []; } /** * @internal * @param {HieroProto.proto.ITransaction[]} transactions * @param {HieroProto.proto.ISignedTransaction[]} signedTransactions * @param {TransactionId[]} transactionIds * @param {AccountId[]} nodeIds * @param {HieroProto.proto.ITransactionBody[]} bodies * @returns {AccountAllowanceDeleteTransaction} */ static _fromProtobuf(transactions, signedTransactions, transactionIds, nodeIds, bodies) { const body = bodies[0]; const allowance = /** @type {HieroProto.proto.ICryptoDeleteAllowanceTransactionBody} */ body.cryptoDeleteAllowance; return _Transaction.default._fromProtobufTransactions(new AccountAllowanceDeleteTransaction({ nftAllowances: (allowance.nftAllowances != null ? allowance.nftAllowances : []).map(allowance => _TokenNftAllowance.default._fromProtobuf(allowance)) }), transactions, signedTransactions, transactionIds, nodeIds, bodies); } /** * @returns {TokenNftAllowance[]} */ get tokenNftAllowanceDeletions() { return this._nftAllowances; } /** * @description If you want to remove allowance for all serials of a NFT * - use AccountAllowanceApproveTransaction().deleteTokenNftAllowanceAllSerials() * @param {NftId | string} nftId * @param {AccountId | string} ownerAccountId * @returns {AccountAllowanceDeleteTransaction} */ deleteAllTokenNftAllowances(nftId, ownerAccountId) { this._requireNotFrozen(); const id = typeof nftId === "string" ? _NftId.default.fromString(nftId) : nftId; const owner = typeof ownerAccountId === "string" ? _AccountId.default.fromString(ownerAccountId) : ownerAccountId; let found = false; for (const allowance of this._nftAllowances) { if (allowance.tokenId.compare(id.tokenId) === 0) { if (allowance.serialNumbers != null) { allowance.serialNumbers.push(id.serial); } found = true; break; } } if (!found) { this._nftAllowances.push(new _TokenNftAllowance.default({ tokenId: id.tokenId, spenderAccountId: null, serialNumbers: [id.serial], ownerAccountId: owner, allSerials: false, delegatingSpender: null })); } return this; } /** * @param {Client} client */ _validateChecksums(client) { this._nftAllowances.map(allowance => allowance._validateChecksums(client)); } /** * @override * @internal * @param {Channel} channel * @param {HieroProto.proto.ITransaction} request * @returns {Promise<HieroProto.proto.ITransactionResponse>} */ _execute(channel, request) { return channel.crypto.deleteAllowances(request); } /** * @override * @protected * @returns {NonNullable<HieroProto.proto.TransactionBody["data"]>} */ _getTransactionDataCase() { return "cryptoDeleteAllowance"; } /** * @override * @protected * @returns {HieroProto.proto.ICryptoDeleteAllowanceTransactionBody} */ _makeTransactionData() { return { nftAllowances: this._nftAllowances.map(allowance => allowance._toProtobuf()) }; } /** * @returns {string} */ _getLogId() { const timestamp = /** @type {import("../Timestamp.js").default} */ this._transactionIds.current.validStart; return `AccountAllowanceDeleteTransaction:${timestamp.toString()}`; } } exports.default = AccountAllowanceDeleteTransaction; _Transaction.TRANSACTION_REGISTRY.set("cryptoDeleteAllowance", // eslint-disable-next-line @typescript-eslint/unbound-method AccountAllowanceDeleteTransaction._fromProtobuf);