UNPKG

@hashgraph/sdk

Version:
531 lines (482 loc) 15.4 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _Transaction = _interopRequireWildcard(require("../transaction/Transaction.cjs")); var _AccountId = _interopRequireDefault(require("../account/AccountId.cjs")); var _TopicId = _interopRequireDefault(require("./TopicId.cjs")); var _Duration = _interopRequireDefault(require("../Duration.cjs")); var _Key = _interopRequireDefault(require("../Key.cjs")); var _Timestamp = _interopRequireDefault(require("../Timestamp.cjs")); var _CustomFixedFee = _interopRequireDefault(require("../token/CustomFixedFee.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("@hashgraph/proto").proto.IConsensusUpdateTopicTransactionBody} HieroProto.proto.IConsensusUpdateTopicTransactionBody * @typedef {import("@hashgraph/proto").proto.ITransaction} HieroProto.proto.ITransaction * @typedef {import("@hashgraph/proto").proto.ISignedTransaction} HieroProto.proto.ISignedTransaction * @typedef {import("@hashgraph/proto").proto.TransactionBody} HieroProto.proto.TransactionBody * @typedef {import("@hashgraph/proto").proto.ITransactionBody} HieroProto.proto.ITransactionBody * @typedef {import("@hashgraph/proto").proto.ITransactionResponse} HieroProto.proto.ITransactionResponse */ /** * @typedef {import("../channel/Channel.js").default} Channel * @typedef {import("../client/Client.js").default<*, *>} Client * @typedef {import("../transaction/TransactionId.js").default} TransactionId */ /** * Update a topic. * * If there is no adminKey, the only authorized update (available to anyone) is to extend the expirationTime. * Otherwise transaction must be signed by the adminKey. * * If an adminKey is updated, the transaction must be signed by the pre-update adminKey and post-update adminKey. * * If a new autoRenewAccount is specified (not just being removed), that account must also sign the transaction. */ class TopicUpdateTransaction extends _Transaction.default { /** * @param {object} props * @param {TopicId | string} [props.topicId] * @param {Key} [props.adminKey] * @param {Key} [props.submitKey] * @param {Key} [props.feeScheduleKey] * @param {Key[]} [props.feeExemptKeys] * @param {Duration | Long | number} [props.autoRenewPeriod] * @param {AccountId | string} [props.autoRenewAccountId] * @param {CustomFixedFee[]} [props.customFees] * @param {?string} [props.topicMemo] * @param {Timestamp | Date} [props.expirationTime] */ constructor(props = {}) { super(); /** * @private * @type {?TopicId} */ this._topicId = null; if (props.topicId != null) { this.setTopicId(props.topicId); } /** * @private * @type {?string} */ this._topicMemo = null; if (props.topicMemo != null) { this.setTopicMemo(props.topicMemo); } /** * @private * @type {?Key} */ this._submitKey = null; if (props.submitKey != null) { this.setSubmitKey(props.submitKey); } /** * @private * @type {?Key} */ this._adminKey = null; if (props.adminKey != null) { this.setAdminKey(props.adminKey); } /** * @private * @type {?Key} */ this._feeScheduleKey = null; if (props.feeScheduleKey != null) { this.setFeeScheduleKey(props.feeScheduleKey); } /** * @private * @type {?Key[]} */ this._feeExemptKeys = null; if (props.feeExemptKeys != null) { this.setFeeExemptKeys(props.feeExemptKeys); } /** * @private * @type {?AccountId} */ this._autoRenewAccountId = null; if (props.autoRenewAccountId != null) { this.setAutoRenewAccountId(props.autoRenewAccountId); } /** * @private * @type {?Duration} */ this._autoRenewPeriod = null; if (props.autoRenewPeriod != null) { this.setAutoRenewPeriod(props.autoRenewPeriod); } /** * @private * @type {?CustomFixedFee[]} */ this._customFees = null; if (props.customFees != null) { this.setCustomFees(props.customFees); } /** * @private * @type {?Timestamp} */ this._expirationTime = null; if (props.expirationTime != null) { this.setExpirationTime(props.expirationTime); } } /** * @internal * @param {HieroProto.proto.ITransaction[]} transactions * @param {HieroProto.proto.ISignedTransaction[]} signedTransactions * @param {TransactionId[]} transactionIds * @param {AccountId[]} nodeIds * @param {HieroProto.proto.ITransactionBody[]} bodies * @returns {TopicUpdateTransaction} */ static _fromProtobuf(transactions, signedTransactions, transactionIds, nodeIds, bodies) { const body = bodies[0]; const update = /** @type {HieroProto.proto.IConsensusUpdateTopicTransactionBody} */ body.consensusUpdateTopic; return _Transaction.default._fromProtobufTransactions(new TopicUpdateTransaction({ topicId: update.topicID != null ? _TopicId.default._fromProtobuf(update.topicID) : undefined, adminKey: update.adminKey != null ? _Key.default._fromProtobufKey(update.adminKey) : undefined, submitKey: update.submitKey != null ? _Key.default._fromProtobufKey(update.submitKey) : undefined, feeScheduleKey: update.feeScheduleKey != null ? _Key.default._fromProtobufKey(update.feeScheduleKey) : undefined, feeExemptKeys: update.feeExemptKeyList != null && update.feeExemptKeyList.keys != null ? update?.feeExemptKeyList.keys.map(key => _Key.default._fromProtobufKey(key)) : undefined, autoRenewAccountId: update.autoRenewAccount != null ? _AccountId.default._fromProtobuf(update.autoRenewAccount) : undefined, autoRenewPeriod: update.autoRenewPeriod != null ? update.autoRenewPeriod.seconds != null ? update.autoRenewPeriod.seconds : undefined : undefined, customFees: update.customFees != null && update.customFees.fees != null ? update.customFees.fees.map(customFee => _CustomFixedFee.default._fromProtobuf(customFee)) : undefined, topicMemo: update.memo != null ? Object.hasOwn(update.memo, "value") ? update.memo.value : undefined : undefined, expirationTime: update.expirationTime != null ? _Timestamp.default._fromProtobuf(update.expirationTime) : undefined }), transactions, signedTransactions, transactionIds, nodeIds, bodies); } /** * @returns {?Timestamp} */ get expirationTime() { return this._expirationTime; } /** * @param {Timestamp | Date | null} expirationTime * @returns {TopicUpdateTransaction} */ setExpirationTime(expirationTime) { this._requireNotFrozen(); this._expirationTime = expirationTime instanceof Date ? _Timestamp.default.fromDate(expirationTime) : expirationTime; return this; } /** * @returns {?TopicId} */ get topicId() { return this._topicId; } /** * @param {TopicId | string} topicId * @returns {TopicUpdateTransaction} */ setTopicId(topicId) { this._requireNotFrozen(); this._topicId = typeof topicId === "string" ? _TopicId.default.fromString(topicId) : topicId.clone(); return this; } /** * @returns {TopicUpdateTransaction} */ clearTopicId() { this._requireNotFrozen(); this._topicId = null; return this; } /** * @returns {?string} */ get topicMemo() { return this._topicMemo; } /** * @param {string} topicMemo * @returns {TopicUpdateTransaction} */ setTopicMemo(topicMemo) { this._requireNotFrozen(); this._topicMemo = topicMemo; return this; } /** * @returns {TopicUpdateTransaction} */ clearTopicMemo() { this._requireNotFrozen(); this._topicMemo = null; return this; } /** * @returns {?Key} */ get adminKey() { return this._adminKey; } /** * @param {Key} adminKey * @returns {TopicUpdateTransaction} */ setAdminKey(adminKey) { this._requireNotFrozen(); this._adminKey = adminKey; return this; } /** * @returns {TopicUpdateTransaction} */ clearAdminKey() { this._requireNotFrozen(); this._adminKey = null; return this; } /** * @returns {?Key} */ get submitKey() { return this._submitKey; } /** * @param {Key} submitKey * @returns {TopicUpdateTransaction} */ setSubmitKey(submitKey) { this._requireNotFrozen(); this._submitKey = submitKey; return this; } /** * @returns {TopicUpdateTransaction} */ clearSubmitKey() { this._requireNotFrozen(); this._submitKey = null; return this; } /** * Returns the key which allows updates to the new topic’s fees. * @returns {?Key} */ getFeeScheduleKey() { return this._feeScheduleKey; } /** * Sets the key which allows updates to the new topic’s fees. * @param {Key} feeScheduleKey * @returns {this} */ setFeeScheduleKey(feeScheduleKey) { this._requireNotFrozen(); this._feeScheduleKey = feeScheduleKey; return this; } /** * @returns {TopicUpdateTransaction} */ clearFeeScheduleKey() { this._requireNotFrozen(); this._feeScheduleKey = null; return this; } /** * Returns the keys that will be exempt from paying fees. * @returns {?Key[]} */ getFeeExemptKeys() { return this._feeExemptKeys; } /** * Sets the keys that will be exempt from paying fees. * @param {Key[]} feeExemptKeys * @returns {this} */ setFeeExemptKeys(feeExemptKeys) { this._requireNotFrozen(); this._feeExemptKeys = feeExemptKeys; return this; } /** * Adds a key that will be exempt from paying fees. * @param {Key} key * @returns {this} */ addFeeExemptKey(key) { this._requireNotFrozen(); if (this._feeExemptKeys == null) { this._feeExemptKeys = []; } this._feeExemptKeys.push(key); return this; } /** * Clears all keys that will be exempt from paying fees, effectively removing them from the network state. * @returns {this} */ clearFeeExemptKeys() { this._requireNotFrozen(); this._feeExemptKeys = []; return this; } /** * @returns {?AccountId} */ get autoRenewAccountId() { return this._autoRenewAccountId; } /** * @param {AccountId | string} autoRenewAccountId * @returns {TopicUpdateTransaction} */ setAutoRenewAccountId(autoRenewAccountId) { this._requireNotFrozen(); this._autoRenewAccountId = autoRenewAccountId instanceof _AccountId.default ? autoRenewAccountId : _AccountId.default.fromString(autoRenewAccountId); return this; } /** * @returns {TopicUpdateTransaction} */ clearAutoRenewAccountId() { this._requireNotFrozen(); this._autoRenewAccountId = null; return this; } /** * @returns {?Duration} */ get autoRenewPeriod() { return this._autoRenewPeriod; } /** * Set the auto renew period for this account. * * @param {Duration | Long | number} autoRenewPeriod * @returns {TopicUpdateTransaction} */ setAutoRenewPeriod(autoRenewPeriod) { this._requireNotFrozen(); this._autoRenewPeriod = autoRenewPeriod instanceof _Duration.default ? autoRenewPeriod : new _Duration.default(autoRenewPeriod); return this; } /** * Returns the fixed fees to assess when a message is submitted to the new topic. * @returns {?CustomFixedFee[]} */ getCustomFees() { return this._customFees; } /** * Sets the fixed fees to assess when a message is submitted to the new topic. * * @param {CustomFixedFee[]} customFees * @returns {this} */ setCustomFees(customFees) { this._requireNotFrozen(); this._customFees = customFees; return this; } /** * Adds fixed fee to assess when a message is submitted to the new topic. * * @param {CustomFixedFee} customFee * @returns {this} */ addCustomFee(customFee) { this._requireNotFrozen(); if (this._customFees == null) { this._customFees = []; } this._customFees.push(customFee); return this; } /** * Clears fixed fees, effectively removing them from the network state. * * @returns {this} */ clearCustomFees() { this._requireNotFrozen(); this._customFees = []; return this; } /** * @param {Client} client */ _validateChecksums(client) { if (this._topicId != null) { this._topicId.validateChecksum(client); } if (this._autoRenewAccountId != null) { this._autoRenewAccountId.validateChecksum(client); } } /** * @override * @internal * @param {Channel} channel * @param {HieroProto.proto.ITransaction} request * @returns {Promise<HieroProto.proto.ITransactionResponse>} */ _execute(channel, request) { return channel.consensus.updateTopic(request); } /** * @override * @protected * @returns {NonNullable<HieroProto.proto.TransactionBody["data"]>} */ _getTransactionDataCase() { return "consensusUpdateTopic"; } /** * @override * @protected * @returns {HieroProto.proto.IConsensusUpdateTopicTransactionBody} */ _makeTransactionData() { return { topicID: this._topicId != null ? this._topicId._toProtobuf() : null, adminKey: this._adminKey != null ? this._adminKey._toProtobufKey() : null, submitKey: this._submitKey != null ? this._submitKey._toProtobufKey() : null, feeScheduleKey: this._feeScheduleKey != null ? this._feeScheduleKey._toProtobufKey() : null, feeExemptKeyList: this._feeExemptKeys != null ? { keys: this._feeExemptKeys.map(key => key._toProtobufKey()) } : null, memo: this._topicMemo != null ? { value: this._topicMemo } : null, autoRenewAccount: this._autoRenewAccountId != null ? this._autoRenewAccountId._toProtobuf() : null, autoRenewPeriod: this._autoRenewPeriod != null ? this._autoRenewPeriod._toProtobuf() : null, customFees: this._customFees != null ? { fees: this._customFees.map(customFee => customFee._toTopicFeeProtobuf()) } : null, expirationTime: this._expirationTime != null ? this._expirationTime._toProtobuf() : null }; } /** * @returns {string} */ _getLogId() { const timestamp = /** @type {import("../Timestamp.js").default} */ this._transactionIds.current.validStart; return `TopicUpdateTransaction:${timestamp.toString()}`; } } exports.default = TopicUpdateTransaction; _Transaction.TRANSACTION_REGISTRY.set("consensusUpdateTopic", // eslint-disable-next-line @typescript-eslint/unbound-method TopicUpdateTransaction._fromProtobuf);