LCOV - code coverage report
Current view: top level - src/policy - policy.h (source / functions) Hit Total Coverage
Test: total_coverage.info Lines: 4 4 100.0 %
Date: 2020-09-26 01:30:44 Functions: 2 2 100.0 %

          Line data    Source code
       1             : // Copyright (c) 2009-2010 Satoshi Nakamoto
       2             : // Copyright (c) 2009-2019 The Bitcoin Core developers
       3             : // Distributed under the MIT software license, see the accompanying
       4             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       5             : 
       6             : #ifndef BITCOIN_POLICY_POLICY_H
       7             : #define BITCOIN_POLICY_POLICY_H
       8             : 
       9             : #include <consensus/consensus.h>
      10             : #include <policy/feerate.h>
      11             : #include <script/interpreter.h>
      12             : #include <script/standard.h>
      13             : 
      14             : #include <string>
      15             : 
      16             : class CCoinsViewCache;
      17             : class CTxOut;
      18             : 
      19             : /** Default for -blockmaxweight, which controls the range of block weights the mining code will create **/
      20             : static const unsigned int DEFAULT_BLOCK_MAX_WEIGHT = MAX_BLOCK_WEIGHT - 4000;
      21             : /** Default for -blockmintxfee, which sets the minimum feerate for a transaction in blocks created by mining code **/
      22             : static const unsigned int DEFAULT_BLOCK_MIN_TX_FEE = 1000;
      23             : /** The maximum weight for transactions we're willing to relay/mine */
      24             : static const unsigned int MAX_STANDARD_TX_WEIGHT = 400000;
      25             : /** The minimum non-witness size for transactions we're willing to relay/mine (1 segwit input + 1 P2WPKH output = 82 bytes) */
      26             : static const unsigned int MIN_STANDARD_TX_NONWITNESS_SIZE = 82;
      27             : /** Maximum number of signature check operations in an IsStandard() P2SH script */
      28             : static const unsigned int MAX_P2SH_SIGOPS = 15;
      29             : /** The maximum number of sigops we're willing to relay/mine in a single tx */
      30             : static const unsigned int MAX_STANDARD_TX_SIGOPS_COST = MAX_BLOCK_SIGOPS_COST/5;
      31             : /** Default for -maxmempool, maximum megabytes of mempool memory usage */
      32             : static const unsigned int DEFAULT_MAX_MEMPOOL_SIZE = 300;
      33             : /** Default for -incrementalrelayfee, which sets the minimum feerate increase for mempool limiting or BIP 125 replacement **/
      34             : static const unsigned int DEFAULT_INCREMENTAL_RELAY_FEE = 1000;
      35             : /** Default for -bytespersigop */
      36             : static const unsigned int DEFAULT_BYTES_PER_SIGOP = 20;
      37             : /** Default for -permitbaremultisig */
      38             : static const bool DEFAULT_PERMIT_BAREMULTISIG = true;
      39             : /** The maximum number of witness stack items in a standard P2WSH script */
      40             : static const unsigned int MAX_STANDARD_P2WSH_STACK_ITEMS = 100;
      41             : /** The maximum size of each witness stack item in a standard P2WSH script */
      42             : static const unsigned int MAX_STANDARD_P2WSH_STACK_ITEM_SIZE = 80;
      43             : /** The maximum size of a standard witnessScript */
      44             : static const unsigned int MAX_STANDARD_P2WSH_SCRIPT_SIZE = 3600;
      45             : /** Min feerate for defining dust. Historically this has been based on the
      46             :  * minRelayTxFee, however changing the dust limit changes which transactions are
      47             :  * standard and should be done with care and ideally rarely. It makes sense to
      48             :  * only increase the dust limit after prior releases were already not creating
      49             :  * outputs below the new threshold */
      50             : static const unsigned int DUST_RELAY_TX_FEE = 3000;
      51             : /**
      52             :  * Standard script verification flags that standard transactions will comply
      53             :  * with. However scripts violating these flags may still be present in valid
      54             :  * blocks and we must accept those blocks.
      55             :  */
      56             : static constexpr unsigned int STANDARD_SCRIPT_VERIFY_FLAGS = MANDATORY_SCRIPT_VERIFY_FLAGS |
      57             :                                                              SCRIPT_VERIFY_DERSIG |
      58             :                                                              SCRIPT_VERIFY_STRICTENC |
      59             :                                                              SCRIPT_VERIFY_MINIMALDATA |
      60             :                                                              SCRIPT_VERIFY_NULLDUMMY |
      61             :                                                              SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_NOPS |
      62             :                                                              SCRIPT_VERIFY_CLEANSTACK |
      63             :                                                              SCRIPT_VERIFY_MINIMALIF |
      64             :                                                              SCRIPT_VERIFY_NULLFAIL |
      65             :                                                              SCRIPT_VERIFY_CHECKLOCKTIMEVERIFY |
      66             :                                                              SCRIPT_VERIFY_CHECKSEQUENCEVERIFY |
      67             :                                                              SCRIPT_VERIFY_LOW_S |
      68             :                                                              SCRIPT_VERIFY_WITNESS |
      69             :                                                              SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_WITNESS_PROGRAM |
      70             :                                                              SCRIPT_VERIFY_WITNESS_PUBKEYTYPE |
      71             :                                                              SCRIPT_VERIFY_CONST_SCRIPTCODE;
      72             : 
      73             : /** For convenience, standard but not mandatory verify flags. */
      74             : static constexpr unsigned int STANDARD_NOT_MANDATORY_VERIFY_FLAGS = STANDARD_SCRIPT_VERIFY_FLAGS & ~MANDATORY_SCRIPT_VERIFY_FLAGS;
      75             : 
      76             : /** Used as the flags parameter to sequence and nLocktime checks in non-consensus code. */
      77             : static constexpr unsigned int STANDARD_LOCKTIME_VERIFY_FLAGS = LOCKTIME_VERIFY_SEQUENCE |
      78             :                                                                LOCKTIME_MEDIAN_TIME_PAST;
      79             : 
      80             : CAmount GetDustThreshold(const CTxOut& txout, const CFeeRate& dustRelayFee);
      81             : 
      82             : bool IsDust(const CTxOut& txout, const CFeeRate& dustRelayFee);
      83             : 
      84             : bool IsStandard(const CScript& scriptPubKey, TxoutType& whichType);
      85             :     /**
      86             :      * Check for standard transaction types
      87             :      * @return True if all outputs (scriptPubKeys) use only standard transaction forms
      88             :      */
      89             : bool IsStandardTx(const CTransaction& tx, bool permit_bare_multisig, const CFeeRate& dust_relay_fee, std::string& reason);
      90             :     /**
      91             :      * Check for standard transaction types
      92             :      * @param[in] mapInputs    Map of previous transactions that have outputs we're spending
      93             :      * @return True if all inputs (scriptSigs) use only standard transaction forms
      94             :      */
      95             : bool AreInputsStandard(const CTransaction& tx, const CCoinsViewCache& mapInputs);
      96             :     /**
      97             :      * Check if the transaction is over standard P2WSH resources limit:
      98             :      * 3600bytes witnessScript size, 80bytes per witness stack element, 100 witness stack elements
      99             :      * These limits are adequate for multi-signature up to n-of-100 using OP_CHECKSIG, OP_ADD, and OP_EQUAL,
     100             :      */
     101             : bool IsWitnessStandard(const CTransaction& tx, const CCoinsViewCache& mapInputs);
     102             : 
     103             : /** Compute the virtual transaction size (weight reinterpreted as bytes). */
     104             : int64_t GetVirtualTransactionSize(int64_t nWeight, int64_t nSigOpCost, unsigned int bytes_per_sigop);
     105             : int64_t GetVirtualTransactionSize(const CTransaction& tx, int64_t nSigOpCost, unsigned int bytes_per_sigop);
     106             : int64_t GetVirtualTransactionInputSize(const CTxIn& tx, int64_t nSigOpCost, unsigned int bytes_per_sigop);
     107             : 
     108       11455 : static inline int64_t GetVirtualTransactionSize(const CTransaction& tx)
     109             : {
     110       11455 :     return GetVirtualTransactionSize(tx, 0, 0);
     111             : }
     112             : 
     113      228428 : static inline int64_t GetVirtualTransactionInputSize(const CTxIn& tx)
     114             : {
     115      228428 :     return GetVirtualTransactionInputSize(tx, 0, 0);
     116             : }
     117             : 
     118             : #endif // BITCOIN_POLICY_POLICY_H

Generated by: LCOV version 1.15