UNPKG

@hiero-ledger/sdk

Version:
259 lines (237 loc) 9.13 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _Hbar = _interopRequireDefault(require("./Hbar.cjs")); var _FileId = _interopRequireDefault(require("./file/FileId.cjs")); var _Transaction = _interopRequireWildcard(require("./transaction/Transaction.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 /** * @namespace proto * @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("@hashgraph/proto").proto.IEthereumTransactionBody} HieroProto.proto.IEthereumTransactionBody * @typedef {import("@hashgraph/proto").proto.IAccountID} HieroProto.proto.IAccountID */ /** * @typedef {import("bignumber.js").default} BigNumber * @typedef {import("./account/AccountId.js").default} AccountId * @typedef {import("./channel/Channel.js").default} Channel * @typedef {import("./client/Client.js").default<*, *>} Client * @typedef {import("./Timestamp.js").default} Timestamp * @typedef {import("./transaction/TransactionId.js").default} TransactionId * @typedef {import("long")} Long */ /** * Create a new Hedera™ transaction wrapped ethereum transaction. */ class EthereumTransaction extends _Transaction.default { /** * @param {object} [props] * @param {Uint8Array} [props.ethereumData] * @param {FileId} [props.callData] * @param {FileId} [props.callDataFileId] * @param {number | string | Long | BigNumber | Hbar} [props.maxGasAllowance] */ constructor(props = {}) { super(); /** * @private * @type {?Uint8Array} */ this._ethereumData = null; /** * @private * @type {?FileId} */ this._callDataFileId = null; /** * @private * @type {?Hbar} */ this._maxGasAllowance = null; if (props.ethereumData != null) { this.setEthereumData(props.ethereumData); } if (props.callData != null) { this.setCallDataFileId(props.callData); } if (props.callDataFileId != null) { this.setCallDataFileId(props.callDataFileId); } if (props.maxGasAllowance != null) { this.setMaxGasAllowanceHbar(props.maxGasAllowance); } } /** * @internal * @param {HieroProto.proto.ITransaction[]} transactions * @param {HieroProto.proto.ISignedTransaction[]} signedTransactions * @param {TransactionId[]} transactionIds * @param {AccountId[]} nodeIds * @param {HieroProto.proto.ITransactionBody[]} bodies * @returns {EthereumTransaction} */ static _fromProtobuf(transactions, signedTransactions, transactionIds, nodeIds, bodies) { const body = bodies[0]; const transaction = /** @type {HieroProto.proto.IEthereumTransactionBody} */ body.ethereumTransaction; return _Transaction.default._fromProtobufTransactions(new EthereumTransaction({ ethereumData: transaction.ethereumData != null ? transaction.ethereumData : undefined, callData: transaction.callData != null ? _FileId.default._fromProtobuf(transaction.callData) : undefined, maxGasAllowance: transaction.maxGasAllowance != null ? _Hbar.default.fromTinybars(transaction.maxGasAllowance) : undefined }), transactions, signedTransactions, transactionIds, nodeIds, bodies); } /** * @returns {?(Uint8Array | FileId)} */ get ethereumData() { return this._ethereumData; } /** * The raw Ethereum transaction (RLP encoded type 0, 1, and 2). Complete * unless the callData field is set. * * @param {Uint8Array} ethereumData * @returns {this} */ setEthereumData(ethereumData) { this._requireNotFrozen(); this._ethereumData = ethereumData; return this; } /** * @deprecated - Use `callDataFileId` instead * @returns {?FileId} */ get callData() { return this.callDataFileId; } /** * @deprecated - Use `setCallDataFileId()` instead * * For large transactions (for example contract create) this is the callData * of the callData. The data in the callData will be re-written with * the callData element as a zero length string with the original contents in * the referenced file at time of execution. The callData will need to be * "rehydrated" with the callData for signature validation to pass. * @param {FileId} callDataFileId * @returns {this} */ setCallData(callDataFileId) { return this.setCallDataFileId(callDataFileId); } /** * @returns {?FileId} */ get callDataFileId() { return this._callDataFileId; } /** * For large transactions (for example contract create) this is the callData * of the callData. The data in the callData will be re-written with * the callData element as a zero length string with the original contents in * the referenced file at time of execution. The callData will need to be * "rehydrated" with the callData for signature validation to pass. * * @param {FileId} callDataFileId * @returns {this} */ setCallDataFileId(callDataFileId) { this._requireNotFrozen(); this._callDataFileId = callDataFileId; return this; } /** * @returns {?Hbar} */ get maxGasAllowance() { return this._maxGasAllowance; } /** * @deprecated -- use setMaxGasAllowanceHbar instead * @param {number | string | Long | BigNumber | Hbar} maxGasAllowance * @returns {this} */ setMaxGasAllowance(maxGasAllowance) { return this.setMaxGasAllowanceHbar(maxGasAllowance); } /** * The maximum amount, in hbars, that the payer of the hedera transaction * is willing to pay to complete the transaction. * * Ordinarily the account with the ECDSA alias corresponding to the public * key that is extracted from the ethereum_data signature is responsible for * fees that result from the execution of the transaction. If that amount of * authorized fees is not sufficient then the payer of the transaction can be * charged, up to but not exceeding this amount. If the ethereum_data * transaction authorized an amount that was insufficient then the payer will * only be charged the amount needed to make up the difference. If the gas * price in the transaction was set to zero then the payer will be assessed * the entire fee. * * @param {number | string | Long | BigNumber | Hbar} maxGasAllowance * @returns {this} */ setMaxGasAllowanceHbar(maxGasAllowance) { this._requireNotFrozen(); this._maxGasAllowance = maxGasAllowance instanceof _Hbar.default ? maxGasAllowance : new _Hbar.default(maxGasAllowance); return this; } /** * @param {Client} client */ _validateChecksums(client) { if (this._ethereumData != null && this._ethereumData instanceof _FileId.default) { this._ethereumData.validateChecksum(client); } } /** * @override * @internal * @param {Channel} channel * @param {HieroProto.proto.ITransaction} request * @returns {Promise<HieroProto.proto.ITransactionResponse>} */ _execute(channel, request) { return channel.smartContract.callEthereum(request); } /** * @override * @protected * @returns {NonNullable<HieroProto.proto.TransactionBody["data"]>} */ _getTransactionDataCase() { return "ethereumTransaction"; } /** * @override * @protected * @returns {HieroProto.proto.IEthereumTransactionBody} */ _makeTransactionData() { return { ethereumData: this._ethereumData, callData: this._callDataFileId != null ? this._callDataFileId._toProtobuf() : null, maxGasAllowance: this._maxGasAllowance != null ? this._maxGasAllowance.toTinybars() : null }; } /** * @returns {string} */ _getLogId() { const timestamp = /** @type {import("./Timestamp.js").default} */ this._transactionIds.current.validStart; return `EthereumTransaction:${timestamp.toString()}`; } } exports.default = EthereumTransaction; _Transaction.TRANSACTION_REGISTRY.set("ethereumTransaction", // eslint-disable-next-line @typescript-eslint/unbound-method EthereumTransaction._fromProtobuf);