Create a File
A transaction that creates a new file on a Hedera network. The file is referenced by its file ID which can be obtained from the receipt or record once the transaction reaches consensus on a Hedera network. The file does not have a file name. If the file is too big to create with a single FileCreateTransaction()
, the file can be appended with the remaining content multiple times using the FileAppendTransaction()
Step 1:
Imports
Step 1:
ImportsThe code imports necessary modules from the Hedera JavaScript SDK (
@hashgraph/sdk
) such asFileCreateTransaction
,FileAppendTransaction
,FileContentsQuery
,TransactionRecordQuery
,Hbar
,LocalProvider
, andWallet
.It also imports the
fs
module from Node.js to read the contents of a file synchronously, and theexit
method from theprocess
module.
Step 2 : Environment Variables Retrieval and Validation
The code loads environment variables from a
.env
file located in theFile_Service
directory usingdotenv
.It checks whether the required environment variables (
MY_ACCOUNT_ID
andMY_PRIVATE_KEY
) are present. If not, it throws an error.
Step 3 : Wallet Initialization
It creates a new
Wallet
instance using the account ID and private key retrieved from the environment variables.The wallet is initialized with a
LocalProvider
, indicating that it will be used for local signing of transactions.
Step 4 : Main Function
It reads the contents of a PDF file (
hedera.pdf
) synchronously usingfs.readFileSync()
.It creates a file on the Hedera network using
FileCreateTransaction
, sets the necessary parameters such as keys, contents, and transaction fee, and freezes the transaction for signing.The file creation transaction is then signed with the wallet's signer and executed.
After execution, the receipt of the transaction is obtained to retrieve the new file ID.
Data from the PDF file is appended to the created file using
FileAppendTransaction
, with similar steps for signing and execution as the file creation transaction.The contents of the file are retrieved using
FileContentsQuery
.Transaction record queries are performed to get transaction fees for both the file creation and append transactions.
Exchange rates for the transactions are retrieved from the receipts.
Finally, various information such as file ID, file content length, transaction fees, and exchange rates are logged to the console.
Step 5 : Execution
This line calls the main()
function to start the execution of the script.
Last updated
Was this helpful?