UNPKG

@hashgraph/sdk

Version:
168 lines (150 loc) 4.91 kB
// SPDX-License-Identifier: Apache-2.0 import Transaction, { TRANSACTION_REGISTRY, } from "../transaction/Transaction.js"; import FileId from "./FileId.js"; /** * @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.IFileDeleteTransactionBody} HieroProto.proto.IFileDeleteTransactionBody */ /** * @typedef {import("@hashgraph/cryptography").Key} Key * @typedef {import("../channel/Channel.js").default} Channel * @typedef {import("../client/Client.js").default<*, *>} Client * @typedef {import("../account/AccountId.js").default} AccountId * @typedef {import("../transaction/TransactionId.js").default} TransactionId */ /** * A transaction to delete a file on the Hedera network. * * When deleted, a file's contents are truncated to zero length and it can no longer be updated * or appended to, or its expiration time extended. FileContentsQuery and FileInfoQuery * will throw HederaPreCheckStatusException with a status of Status#FileDeleted. * * Only one of the file's keys needs to sign to delete the file, unless the key you have is part * of a KeyList. */ export default class FileDeleteTransaction extends Transaction { /** * @param {object} [props] * @param {FileId | string} [props.fileId] */ constructor(props = {}) { super(); /** * @private * @type {?FileId} */ this._fileId = null; if (props.fileId != null) { this.setFileId(props.fileId); } } /** * @internal * @param {HieroProto.proto.ITransaction[]} transactions * @param {HieroProto.proto.ISignedTransaction[]} signedTransactions * @param {TransactionId[]} transactionIds * @param {AccountId[]} nodeIds * @param {HieroProto.proto.ITransactionBody[]} bodies * @returns {FileDeleteTransaction} */ static _fromProtobuf( transactions, signedTransactions, transactionIds, nodeIds, bodies, ) { const body = bodies[0]; const fileDelete = /** @type {HieroProto.proto.IFileDeleteTransactionBody} */ ( body.fileDelete ); return Transaction._fromProtobufTransactions( new FileDeleteTransaction({ fileId: fileDelete.fileID != null ? FileId._fromProtobuf(fileDelete.fileID) : undefined, }), transactions, signedTransactions, transactionIds, nodeIds, bodies, ); } /** * @returns {?FileId} */ get fileId() { return this._fileId; } /** * Set the file ID which is being deleted in this transaction. * * @param {FileId | string} fileId * @returns {FileDeleteTransaction} */ setFileId(fileId) { this._requireNotFrozen(); this._fileId = typeof fileId === "string" ? FileId.fromString(fileId) : fileId.clone(); return this; } /** * @param {Client} client */ _validateChecksums(client) { if (this._fileId != null) { this._fileId.validateChecksum(client); } } /** * @override * @internal * @param {Channel} channel * @param {HieroProto.proto.ITransaction} request * @returns {Promise<HieroProto.proto.ITransactionResponse>} */ _execute(channel, request) { return channel.file.deleteFile(request); } /** * @override * @protected * @returns {NonNullable<HieroProto.proto.TransactionBody["data"]>} */ _getTransactionDataCase() { return "fileDelete"; } /** * @override * @protected * @returns {HieroProto.proto.IFileDeleteTransactionBody} */ _makeTransactionData() { return { fileID: this._fileId != null ? this._fileId._toProtobuf() : null, }; } /** * @returns {string} */ _getLogId() { const timestamp = /** @type {import("../Timestamp.js").default} */ ( this._transactionIds.current.validStart ); return `FileDeleteTransaction:${timestamp.toString()}`; } } // eslint-disable-next-line @typescript-eslint/unbound-method TRANSACTION_REGISTRY.set("fileDelete", FileDeleteTransaction._fromProtobuf);