5 releases

0.1.16-alpha.0 Mar 31, 2023
0.1.14-alpha.0 Mar 18, 2023
0.1.13-alpha.0 Mar 18, 2023
0.1.12-alpha.0 Jan 19, 2023
0.1.10-alpha.0 Jan 18, 2023

#10 in #spent

Download history 178/week @ 2023-12-13 215/week @ 2023-12-20 85/week @ 2023-12-27 114/week @ 2024-01-03 153/week @ 2024-01-10 180/week @ 2024-01-17 65/week @ 2024-01-24 61/week @ 2024-01-31 93/week @ 2024-02-07 166/week @ 2024-02-14 124/week @ 2024-02-21 163/week @ 2024-02-28 123/week @ 2024-03-06 119/week @ 2024-03-13 228/week @ 2024-03-20 257/week @ 2024-03-27

764 downloads per month
Used in 79 crates (42 directly)

MIT license

1.5MB
6.5K SLoC

bitcoin-tx crate

The bitcoin-tx crate is a Rust implementation of the bitcoin-tx component of the Bitcoin system. This crate is a direct translation of the Bitcoin codebase from C++ to Rust. As such, some function bodies are still being translated.

This crate provides data structures and functions to work with Bitcoin transactions. A Bitcoin transaction is a fundamental data structure that specifies the transfer of bitcoins from one user to another. Each transaction is recorded in the blockchain, which is a public ledger of all transactions in the Bitcoin network.

The Transaction struct represents a Bitcoin transaction and provides functions to serialize and deserialize transactions, compute transaction hashes, get the total size of a transaction, and more. The TxIn and TxOut structs represent the inputs and outputs of a transaction, respectively.

This crate also provides several signature checker structs, such as DummySignatureChecker, GenericTransactionSignatureChecker, MutableTransactionSignatureChecker, and TransactionSignatureChecker. These structs are used to verify ECDSA and Schnorr signatures in transactions.

While there may not be any specific mathematical equations or concepts involved in the bitcoin-tx crate, it provides fundamental data structures and functions for working with Bitcoin transactions, which is a key part of the Bitcoin system.

14> could you teach me about bitcoin transactions?

Certainly!

A Bitcoin transaction is a message sent between users that contains information about the transfer of bitcoins. It consists of one or more inputs and one or more outputs. Each input references a previous output transaction that provided the funds being spent, and each output specifies the amount and destination address for the new coins being created.

The inputs and outputs of a transaction are represented as a script that is executed by the Bitcoin network to verify that the transaction is valid. The script is written in a stack-based language called Script, and is evaluated by nodes on the network to determine whether the transaction is allowed to be included in the blockchain.

When creating a transaction, the sender signs it with their private key to prove that they are authorized to spend the funds being transferred. This signature is verified by the network to ensure that the sender is who they claim to be.

Once a transaction is broadcast to the network, it is processed by nodes called miners who compete to solve a cryptographic puzzle in order to add the transaction to the blockchain. Once a miner has successfully solved the puzzle and added the transaction to the blockchain, it is considered confirmed and cannot be reversed.

I hope that helps! Let me know if you have any further questions.

15> what is their data layout?

Bitcoin transactions consist of a series of inputs and outputs. The inputs refer to previous transaction outputs that are being spent, and the outputs specify new values and conditions for the bitcoin amounts being transferred.

The data layout of a bitcoin transaction is structured as follows:

  1. Version: a 4-byte field indicating the transaction version number.

  2. Input count: a variable-length integer encoding the number of transaction inputs.

  3. List of inputs: a sequence of transaction inputs, each consisting of:

    • Previous transaction ID: a 32-byte hash of the transaction that the input is spending.

    • Previous output index: a 4-byte index specifying which output of the previous transaction is being spent.

    • ScriptSig: a variable-length script containing a signature and public key for the input, proving ownership of the coins being spent.

    • Sequence number: a 4-byte field specifying the relative time lock for the input.

  4. Output count: a variable-length integer encoding the number of transaction outputs.

  5. List of outputs: a sequence of transaction outputs, each consisting of:

    • Value: an 8-byte field specifying the amount of bitcoins being transferred in the output.

    • ScriptPubKey: a variable-length script specifying the conditions that must be met to spend the output.

  6. Locktime: a 4-byte field specifying the earliest time or block height at which the transaction may be included in a block.

The input and output scripts are written in a scripting language specific to Bitcoin called Script. This language is used to encode the conditions that must be met in order to spend the output. The scripts can be used to specify things like multi-signature requirements or time locks.

Dependencies

~93MB
~810K SLoC