Open jbair06 opened 2 months ago
hey @hendrikebbers @RickyLB , can I work on this issue, I have a very little experience with Rust though
@mrswastik-robot You may! Feel free to ask any questions and i'll answer to the best of my ability.
hii @RickyLB, I have tried to write the logic for the chunking of large content in the file_create_transaction.rs file and also wrote the test case for it, but I have not been able to pass the test case for it and it's giving me the error:
thread 'file::file_create_transaction::tests::serialize_large_contents' panicked at src/file/file_create_transaction.rs:458:20: called
Result::unwrap()on an
Errvalue: NoPayerAccountOrTransactionId
should I create a PR so that you can see the modified code and then I can make the requested changes?
Hey @mrswastik-robot,
Go ahead and create a PR, and i'll take a look at it. Thank you!
@RickyLB , I have raised the PR, you can have a look into it, I will be more than happy to make the requested changes once you review it.
ππ₯ First Timers Only
This issue is reserved for people who have never contributed to Hedera or any open source project in general. We know that creating a pull request (PR) is a major barrier for new contributors. The goal of this issue and all other issues labeled by 'good first issue' is to help you make your first contribution to Hedera.
πΎ Description of the issue
When creating or updating a file using the
FileCreateTransaction
orFileUpdateTransaction
, if the contents are too large for a single transaction, aFileAppendTransaction
is required to be created in addition to theFileCreate
/FileUpdate
.FileAppendTransaction
, on the other hand, can handle a large content because it does chunking of that content internally. It would be good to have FileCreate and FileUpdate to have this same functionality. This would allow for a single transaction to create or update a file with a large content.Solution
Refactor
FileCreateTransaction
andFileUpdateTransaction
to share the newpub trait FileTransaction
which should include anappend
method to store additional transactions when the content exceeds 1024 kB. Refer to FileAppendTransaction for an example of how to chunk the content.Implementation
pub trait FileTransaction
with append method (for new transactions).FileTransactionBase
that implementsFileTransaction
withset_contents
method to handle large files by creating multiple transactions.FileCreateTransaction
andFileUpdateTransaction
to implementFileTransaction
π Step by step guide to do a contribution
If you have never contributed to an open source project at GitHub, the following step-by-step guide will introduce you to the workflow. More information and concrete samples for shell commands for each step can be found in our CONTRIBUTING.md file. A more detailed general documentation of the GitHub PR workflow can be found here.
sign-off
information to the commit to accept the "Developer Certificate of Origin" (https://developercertificate.org). More details can be found in our CONTRIBUTING.mdπ Contribute to Hacktoberfest
Solve this issue as part of the Hacktoberfest event and get a chance to receive cool goodies like a T-Shirt. π½
π€ Additional Information
If you have any questions, just ask us directly in this issue by adding a comment. You can join our community chat at Discord. A general manual about open-source contributions can be found here.