Bitcoin Core  26.1.0
P2P Digital Currency
transaction.cpp
Go to the documentation of this file.
1 // Copyright (c) 2019-2022 The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 
5 #include <chainparams.h>
6 #include <coins.h>
7 #include <consensus/tx_check.h>
8 #include <consensus/tx_verify.h>
9 #include <consensus/validation.h>
10 #include <core_io.h>
11 #include <core_memusage.h>
12 #include <policy/policy.h>
13 #include <policy/settings.h>
14 #include <primitives/transaction.h>
15 #include <streams.h>
16 #include <test/fuzz/fuzz.h>
17 #include <univalue.h>
18 #include <util/chaintype.h>
19 #include <util/rbf.h>
20 #include <validation.h>
21 #include <version.h>
22 
23 #include <cassert>
24 
26 {
28 }
29 
31 {
33  try {
34  int nVersion;
35  ds >> nVersion;
36  ds.SetVersion(nVersion);
37  } catch (const std::ios_base::failure&) {
38  return;
39  }
40  bool valid_tx = true;
41  const CTransaction tx = [&] {
42  try {
43  return CTransaction(deserialize, ds);
44  } catch (const std::ios_base::failure&) {
45  valid_tx = false;
47  }
48  }();
49  bool valid_mutable_tx = true;
51  CMutableTransaction mutable_tx;
52  try {
53  int nVersion;
54  ds_mtx >> nVersion;
55  ds_mtx.SetVersion(nVersion);
56  ds_mtx >> mutable_tx;
57  } catch (const std::ios_base::failure&) {
58  valid_mutable_tx = false;
59  }
60  assert(valid_tx == valid_mutable_tx);
61  if (!valid_tx) {
62  return;
63  }
64 
65  {
66  TxValidationState state_with_dupe_check;
67  const bool res{CheckTransaction(tx, state_with_dupe_check)};
68  Assert(res == state_with_dupe_check.IsValid());
69  }
70 
71  const CFeeRate dust_relay_fee{DUST_RELAY_TX_FEE};
72  std::string reason;
73  const bool is_standard_with_permit_bare_multisig = IsStandardTx(tx, std::nullopt, /* permit_bare_multisig= */ true, dust_relay_fee, reason);
74  const bool is_standard_without_permit_bare_multisig = IsStandardTx(tx, std::nullopt, /* permit_bare_multisig= */ false, dust_relay_fee, reason);
75  if (is_standard_without_permit_bare_multisig) {
76  assert(is_standard_with_permit_bare_multisig);
77  }
78 
79  (void)tx.GetHash();
80  (void)tx.GetTotalSize();
81  try {
82  (void)tx.GetValueOut();
83  } catch (const std::runtime_error&) {
84  }
85  (void)tx.GetWitnessHash();
86  (void)tx.HasWitness();
87  (void)tx.IsCoinBase();
88  (void)tx.IsNull();
89  (void)tx.ToString();
90 
91  (void)EncodeHexTx(tx);
92  (void)GetLegacySigOpCount(tx);
93  (void)GetTransactionWeight(tx);
94  (void)GetVirtualTransactionSize(tx);
95  (void)IsFinalTx(tx, /* nBlockHeight= */ 1024, /* nBlockTime= */ 1024);
96  (void)RecursiveDynamicUsage(tx);
97  (void)SignalsOptInRBF(tx);
98 
99  CCoinsView coins_view;
100  const CCoinsViewCache coins_view_cache(&coins_view);
101  (void)AreInputsStandard(tx, coins_view_cache);
102  (void)IsWitnessStandard(tx, coins_view_cache);
103 
104  if (tx.GetTotalSize() < 250'000) { // Avoid high memory usage (with msan) due to json encoding
105  {
106  UniValue u{UniValue::VOBJ};
107  TxToUniv(tx, /*block_hash=*/uint256::ZERO, /*entry=*/u);
108  }
109  {
110  UniValue u{UniValue::VOBJ};
111  TxToUniv(tx, /*block_hash=*/uint256::ONE, /*entry=*/u);
112  }
113  }
114 }
bool IsStandardTx(const CTransaction &tx, const std::optional< unsigned > &max_datacarrier_bytes, bool permit_bare_multisig, const CFeeRate &dust_relay_fee, std::string &reason)
Check for standard transaction types.
Definition: policy.cpp:94
assert(!tx.IsCoinBase())
void initialize_transaction()
Definition: transaction.cpp:25
constexpr deserialize_type deserialize
Definition: serialize.h:49
int64_t GetVirtualTransactionSize(int64_t nWeight, int64_t nSigOpCost, unsigned int bytes_per_sigop)
Compute the virtual transaction size (weight reinterpreted as bytes).
Definition: policy.cpp:295
bool SignalsOptInRBF(const CTransaction &tx)
Check whether the sequence numbers on this transaction are signaling opt-in to replace-by-fee, according to BIP 125.
Definition: rbf.cpp:9
static int32_t GetTransactionWeight(const CTransaction &tx)
Definition: validation.h:148
bool IsCoinBase() const
Definition: transaction.h:350
bool IsWitnessStandard(const CTransaction &tx, const CCoinsViewCache &mapInputs)
Check if the transaction is over standard P2WSH resources limit: 3600bytes witnessScript size...
Definition: policy.cpp:211
CAmount GetValueOut() const
Definition: transaction.cpp:89
bool AreInputsStandard(const CTransaction &tx, const CCoinsViewCache &mapInputs)
Check transaction inputs to mitigate two potential denial-of-service attacks:
Definition: policy.cpp:177
bool IsValid() const
Definition: validation.h:121
FUZZ_TARGET(transaction,.init=initialize_transaction)
Definition: transaction.cpp:30
Abstract view on the open txout dataset.
Definition: coins.h:172
const uint256 & GetWitnessHash() const
Definition: transaction.h:338
const uint256 & GetHash() const
Definition: transaction.h:337
bool IsNull() const
Definition: transaction.h:333
static const int INIT_PROTO_VERSION
initial proto version, to be increased after version/verack negotiation
Definition: version.h:15
static constexpr unsigned int DUST_RELAY_TX_FEE
Min feerate for defining dust.
Definition: policy.h:55
bool HasWitness() const
Definition: transaction.h:367
unsigned int GetLegacySigOpCount(const CTransaction &tx)
Auxiliary functions for transaction validation (ideally should not be exposed)
Definition: tx_verify.cpp:116
std::string ToString() const
std::string EncodeHexTx(const CTransaction &tx, const int serializeFlags=0)
Definition: core_write.cpp:143
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
Definition: feerate.h:32
static size_t RecursiveDynamicUsage(const CScript &script)
Definition: core_memusage.h:12
A mutable version of CTransaction.
Definition: transaction.h:379
unsigned int GetTotalSize() const
Get the total transaction size in bytes, including witness data.
bool IsFinalTx(const CTransaction &tx, int nBlockHeight, int64_t nBlockTime)
Check if transaction is final and can be included in a block with the specified height and time...
Definition: tx_verify.cpp:17
The basic transaction that is broadcasted on the network and contained in blocks. ...
Definition: transaction.h:294
CCoinsView that adds a memory cache for transactions to another CCoinsView.
Definition: coins.h:228
void SetVersion(int n)
Definition: streams.h:346
bool CheckTransaction(const CTransaction &tx, TxValidationState &state)
Definition: tx_check.cpp:11
void SelectParams(const ChainType chain)
Sets the params returned by Params() to those for the given chain type.
#define Assert(val)
Identity function.
Definition: check.h:73