Function bitcoinconsensus::verify
source · pub fn verify(
spent_output: &[u8],
amount: u64,
spending_transaction: &[u8],
spent_outputs: Option<&[Utxo]>,
input_index: usize
) -> Result<(), Error>
Expand description
Verifies a single spend (input) of a Bitcoin transaction.
Note that amount will only be checked for Segwit transactions.
Arguments
spend_output
: A Bitcoin transaction output script to be spent, serialized in Bitcoin’s on wire format.amount
: The spent output amount in satoshis.spending_transaction
: The spending Bitcoin transaction, serialized in Bitcoin’s on wire format.input_index
: The index of the input within spending_transaction.
Examples
The (randomly choosen) Bitcoin transaction
aca326a724eda9a461c10a876534ecd5ae7b27f10f26c3862fb996f80ea2d45d
spends one input, that is the first output of
95da344585fcf2e5f7d6cbf2c3df2dcce84f9196f7a7bb901a43275cd6eb7c3f
The spending transaction serialized is:
spending = 02000000013f7cebd65c27431a90bba7f796914fe8cc2ddfc3f2cbd6f7e5f2fc854534da95000000006b483045022100de1ac3bcdfb0332207c4a91f3832bd2c2915840165f876ab47c5f8996b971c3602201c6c053d750fadde599e6f5c4e1963df0f01fc0d97815e8157e3d59fe09ca30d012103699b464d1d8bc9e47d4fb1cdaa89a1c5783d68363c4dbc4b524ed3d857148617feffffff02836d3c01000000001976a914fc25d6d5c94003bf5b0c7b640a248e2c637fcfb088ac7ada8202000000001976a914fbed3d9b11183209a57999d54d59f67c019e756c88ac6acb0700
The script of the first output of the spent transaction is:
spent = 76a9144bfbaf6afb76cc5771bc6404810d1cc041a6933988ac
The (pseudo code) call: verify(spent, 630482530, spending, 0)
should return Ok(())
.
Note since the spent amount will only be checked for Segwit transactions and the above
example is not segwit, verify
will succeed with any amount.