From 571cacf6596e3a7c8a3b46f755ca8cce928cd47c Mon Sep 17 00:00:00 2001 From: wthrajat Date: Tue, 30 Apr 2024 00:18:53 +0530 Subject: [PATCH] solution.md added Signed-off-by: wthrajat --- SOLUTION.MD | 17 ----------------- solution.md | 38 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+), 17 deletions(-) delete mode 100644 SOLUTION.MD create mode 100644 solution.md diff --git a/SOLUTION.MD b/SOLUTION.MD deleted file mode 100644 index 241df15..0000000 --- a/SOLUTION.MD +++ /dev/null @@ -1,17 +0,0 @@ -### Design Approach -The design approach for the block construction program was to create a modular and scalable solution. The key concept was to create a valid block by ensuring that each block has a unique identifier and that it is connected to the previous block through a hash function. - -### Implementation Details -Pseudo code of the implementation is as follows: - -Define a class Block with properties: index, timestamp, data, previous_hash, hash. -The hash is calculated using SHA256 encryption of the block's index, timestamp, data, and the previous block's hash. -Define a class Blockchain with properties: chain. -The chain is an array of Block objects. -In the Blockchain class, define a method add_block(data) to add a new block to the chain. This method creates a new Block with the provided data and the hash of the last block in the chain. - -### Results and Performance -The solution works as expected and is able to create a valid blockchain with multiple blocks. The efficiency of the solution is O(1) for adding a new block as it only involves creating a new block and appending it to the chain. - -### Conclusion -Solving this problem provided a deeper understanding of how blockchains work. Potential areas for future improvement include adding validation to ensure the integrity of the blockchain and implementing a proof-of-work system. Resources consulted include various online articles and tutorials on blockchain technology. \ No newline at end of file diff --git a/solution.md b/solution.md new file mode 100644 index 0000000..c0cb2fd --- /dev/null +++ b/solution.md @@ -0,0 +1,38 @@ +### Design Approach + +Firstly we serialize the transaction based on the type of input address (specified by `scriptpubkey_type` in the previous output). Then, append the `sighash_type` (found at the end of the signature you are verifying) to the end of the modified transaction byte sequence. Perform a double SHA-256 hash on the trimmed transaction data. Parse the signature, public key, and transaction hash into `SIGNATURE`, `PUBLIC KEY`, and `MESSAGE` objects using the Secp256k1 library. After that, we used ECDSA verification functions to verify the message against the public key and signature. + +### Implementation Details +Provide pseudo code of your implementation, including sequence of logic, algorithms and variables used etc. +I took the use of following functions +```rust +locktime_check(), write_to_output_file(), weight_calc_right(), block_header_get(), coinbase_tx_get(), merkle_root_get(), ip_op_check(), check_sig(), pure_p2sh(), get_txid(), txids_collect(), sha256_hash(), hash160(), varint_convert_bro(), commitment_hash_segwit_get_bro(), commitment_hash_legacy_get(), fees_max_algorithm(), txs_assemble_hehe(), pubkeys_compression(), merkle_root_wtxid_get(), wtxid_get() + +``` +Description: `locktime_check()` validates transaction locktime; `write_to_output_file()` writes data to an output file; `weight_calc_right()` calculates transaction weight accurately; `block_header_get()` retrieves the block header; `coinbase_tx_get()` retrieves the coinbase transaction; `merkle_root_get()` calculates the Merkle root; `ip_op_check()` validates input and output data; `check_sig()` verifies signatures; `pure_p2sh()` handles pure Pay-to-Script-Hash transactions; `get_txid()` retrieves transaction IDs; `txids_collect()` collects transaction IDs; `sha256_hash()` performs a SHA-256 hash; `hash160()` performs a hash160 operation; `varint_convert_bro()` converts a variable integer; `commitment_hash_segwit_get_bro()` retrieves the SegWit commitment hash; `commitment_hash_legacy_get()` retrieves the legacy commitment hash; `fees_max_algorithm()` calculates maximum transaction fees; `txs_assemble_hehe()` assembles transactions; `pubkeys_compression()` compresses public keys; `merkle_root_wtxid_get()` calculates the Merkle root for a witness transaction ID; and `wtxid_get()` retrieves witness transaction IDs. + +### Results and Performance + +I scored and the job took around 6 mins 21 seconds on my local machine and around 6 mins on the GitHub actions. +Here is the score: +``` +Congratulations! Block is valid with a total fee of 19808182 sats and a total weight of 3995700! +Score: 97 +Fee: 19808182 +Weight: 3995700 +Max Fee: 20616923 +Max Weight: 4000000 +``` + +### Conclusion + +I have been the part of the January Chaincode cohort where we were given various assignments by the Chaincode guys, so I have some experience in solving those. Sometimes I felt that autograder instructions could have been more detailed but not a big issue! +
+Referenes I used are: +- https://learnmeabitcoin.com/ +- https://bitcoin.stackexchange.com/ +- https://en.bitcoin.it/wiki/Script +- https://wiki.bitcoinsv.io/index.php/Opcodes_used_in_Bitcoin_Script +- https://learn.saylor.org/mod/book/view.php?id=36340&chapterid=18913 +- https://bitcoin.stackexchange.com/questions/79266/which-serialization-format-the-transactions-use +- SoB `#assignment` Discord channel \ No newline at end of file