@hashgraph/sdk
Version:
155 lines (140 loc) • 5.09 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _Transaction = _interopRequireWildcard(require("../transaction/Transaction.cjs"));
var _long = _interopRequireDefault(require("long"));
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("@hashgraph/proto").proto.ITransaction} ITransaction
* @typedef {import("@hashgraph/proto").proto.ITransaction} ISignedTransaction
* @typedef {import("@hashgraph/proto").proto.TransactionBody} TransactionBody
* @typedef {import("@hashgraph/proto").proto.ITransactionBody} ITransactionBody
* @typedef {import("@hashgraph/proto").proto.ITransactionResponse} ITransactionResponse
*/
/**
* @namespace com.hedera.hapi.node.addressbook
* @typedef {import("@hashgraph/proto").com.hedera.hapi.node.addressbook.INodeDeleteTransactionBody} INodeDeleteTransactionBody
*/
/**
* @typedef {import("../channel/Channel.js").default} Channel
* @typedef {import("../transaction/TransactionId.js").default} TransactionId
* @typedef {import("../client/Client.js").default<*, *>} Client
* @typedef {import("../account/AccountId.js").default} AccountId
*/
/**
* A transaction to delete a consensus node in the network.
*/
class NodeDeleteTransaction extends _Transaction.default {
/**
* @param {object} [props]
* @param {Long} [props.nodeId]
*/
constructor(props) {
super();
/**
* @private
* @type {?Long}
* @description Consensus node identifier in the network state. It's required.
*/
this._nodeId = props?.nodeId != null ? props.nodeId : null;
}
/**
* @internal
* @param {ITransaction[]} transactions
* @param {ISignedTransaction[]} signedTransactions
* @param {TransactionId[]} transactionIds
* @param {AccountId[]} nodeIds
* @param {ITransactionBody[]} bodies
* @returns {NodeDeleteTransaction}
*/
static _fromProtobuf(transactions, signedTransactions, transactionIds, nodeIds, bodies) {
const body = bodies[0];
const nodeDelete = /** @type {INodeDeleteTransactionBody} */
body.nodeDelete;
return _Transaction.default._fromProtobufTransactions(new NodeDeleteTransaction({
nodeId: nodeDelete.nodeId != null ? nodeDelete.nodeId : undefined
}), transactions, signedTransactions, transactionIds, nodeIds, bodies);
}
/**
* @param {Long} nodeId
* @description Set consensus node identifier.
* @returns {NodeDeleteTransaction}
*/
setNodeId(nodeId) {
this._requireNotFrozen();
if (nodeId == null) {
this._nodeId = null;
return this;
}
// Convert to Long if it's a plain number
const longNodeId = _long.default.isLong(nodeId) ? nodeId : _long.default.fromValue(nodeId);
if (longNodeId.toNumber() < 0) {
throw new Error("NodeDeleteTransaction: 'nodeId' must be positive.");
}
this._nodeId = longNodeId;
return this;
}
/**
* @description Get consensus node identifier.
* @returns {?Long}
*/
get nodeId() {
return this._nodeId;
}
/**
* @override
* @param {?import("../client/Client.js").default<Channel, *>} client
* @returns {this}
*/
freezeWith(client) {
if (this.nodeId == null) {
throw new Error("NodeDeleteTransaction: 'nodeId' must be explicitly set before calling freeze().");
}
return super.freezeWith(client);
}
/**
* @override
* @internal
* @param {Channel} channel
* @param {ITransaction} request
* @returns {Promise<ITransactionResponse>}
*/
_execute(channel, request) {
return channel.addressBook.deleteNode(request);
}
/**
* @override
* @protected
* @returns {NonNullable<TransactionBody["data"]>}
*/
_getTransactionDataCase() {
return "nodeDelete";
}
/**
* @override
* @protected
* @returns {INodeDeleteTransactionBody}
*/
_makeTransactionData() {
return {
nodeId: this._nodeId != null ? this._nodeId : null
};
}
/**
* @returns {string}
*/
_getLogId() {
const timestamp = /** @type {import("../Timestamp.js").default} */
this._transactionIds.current.validStart;
return `NodeDeleteTransaction:${timestamp.toString()}`;
}
}
exports.default = NodeDeleteTransaction;
_Transaction.TRANSACTION_REGISTRY.set("nodeDelete",
// eslint-disable-next-line @typescript-eslint/unbound-method
NodeDeleteTransaction._fromProtobuf);
;