Bitcoin Core 28.99.0
P2P Digital Currency
tx_check.cpp
Go to the documentation of this file.
1// Copyright (c) 2017-2021 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
6
7#include <consensus/amount.h>
10
12{
13 // Basic checks that don't depend on any context
14 if (tx.vin.empty())
15 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-vin-empty");
16 if (tx.vout.empty())
17 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-vout-empty");
18 // Size limits (this doesn't take the witness into account, as that hasn't been checked for malleability)
20 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-oversize");
21 }
22
23 // Check for negative or overflow output values (see CVE-2010-5139)
24 CAmount nValueOut = 0;
25 for (const auto& txout : tx.vout)
26 {
27 if (txout.nValue < 0)
28 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-vout-negative");
29 if (txout.nValue > MAX_MONEY)
30 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-vout-toolarge");
31 nValueOut += txout.nValue;
32 if (!MoneyRange(nValueOut))
33 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-txouttotal-toolarge");
34 }
35
36 // Check for duplicate inputs (see CVE-2018-17144)
37 // While Consensus::CheckTxInputs does check if all inputs of a tx are available, and UpdateCoins marks all inputs
38 // of a tx as spent, it does not check if the tx has duplicate inputs.
39 // Failure to run this check will result in either a crash or an inflation bug, depending on the implementation of
40 // the underlying coins database.
41 std::set<COutPoint> vInOutPoints;
42 for (const auto& txin : tx.vin) {
43 if (!vInOutPoints.insert(txin.prevout).second)
44 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-inputs-duplicate");
45 }
46
47 if (tx.IsCoinBase())
48 {
49 if (tx.vin[0].scriptSig.size() < 2 || tx.vin[0].scriptSig.size() > 100)
50 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-cb-length");
51 }
52 else
53 {
54 for (const auto& txin : tx.vin)
55 if (txin.prevout.IsNull())
56 return state.Invalid(TxValidationResult::TX_CONSENSUS, "bad-txns-prevout-null");
57 }
58
59 return true;
60}
static constexpr CAmount MAX_MONEY
No amount larger than this (in satoshi) is valid.
Definition: amount.h:26
bool MoneyRange(const CAmount &nValue)
Definition: amount.h:27
int64_t CAmount
Amount in satoshis (Can be negative)
Definition: amount.h:12
The basic transaction that is broadcasted on the network and contained in blocks.
Definition: transaction.h:296
const std::vector< CTxOut > vout
Definition: transaction.h:307
bool IsCoinBase() const
Definition: transaction.h:356
const std::vector< CTxIn > vin
Definition: transaction.h:306
bool Invalid(Result result, const std::string &reject_reason="", const std::string &debug_message="")
Definition: validation.h:89
@ TX_CONSENSUS
invalid by consensus rules
static const unsigned int MAX_BLOCK_WEIGHT
The maximum allowed weight for a block, see BIP 141 (network rule)
Definition: consensus.h:15
static const int WITNESS_SCALE_FACTOR
Definition: consensus.h:21
static constexpr TransactionSerParams TX_NO_WITNESS
Definition: transaction.h:196
size_t GetSerializeSize(const T &t)
Definition: serialize.h:1103
bool CheckTransaction(const CTransaction &tx, TxValidationState &state)
Definition: tx_check.cpp:11