BSHA3  0.17.99
P2P Blockchain, based on Bitcoin
standard.h
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2018 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_SCRIPT_STANDARD_H
7 #define BITCOIN_SCRIPT_STANDARD_H
8 
9 #include <script/interpreter.h>
10 #include <uint256.h>
11 
12 #include <boost/variant.hpp>
13 
14 #include <stdint.h>
15 
16 static const bool DEFAULT_ACCEPT_DATACARRIER = true;
17 
18 class CKeyID;
19 class CScript;
20 
22 class CScriptID : public uint160
23 {
24 public:
25  CScriptID() : uint160() {}
26  explicit CScriptID(const CScript& in);
27  CScriptID(const uint160& in) : uint160(in) {}
28 };
29 
34 static const unsigned int MAX_OP_RETURN_RELAY = 83;
35 
40 extern bool fAcceptDatacarrier;
41 
43 extern unsigned nMaxDatacarrierBytes;
44 
54 static const unsigned int MANDATORY_SCRIPT_VERIFY_FLAGS = SCRIPT_VERIFY_P2SH;
55 
57 {
59  // 'standard' transaction types:
68 };
69 
71 public:
72  friend bool operator==(const CNoDestination &a, const CNoDestination &b) { return true; }
73  friend bool operator<(const CNoDestination &a, const CNoDestination &b) { return true; }
74 };
75 
77 {
79  explicit WitnessV0ScriptHash(const uint256& hash) : uint256(hash) {}
80  explicit WitnessV0ScriptHash(const CScript& script);
81  using uint256::uint256;
82 };
83 
84 struct WitnessV0KeyHash : public uint160
85 {
87  explicit WitnessV0KeyHash(const uint160& hash) : uint160(hash) {}
88  using uint160::uint160;
89 };
90 
93 {
94  unsigned int version;
95  unsigned int length;
96  unsigned char program[40];
97 
98  friend bool operator==(const WitnessUnknown& w1, const WitnessUnknown& w2) {
99  if (w1.version != w2.version) return false;
100  if (w1.length != w2.length) return false;
101  return std::equal(w1.program, w1.program + w1.length, w2.program);
102  }
103 
104  friend bool operator<(const WitnessUnknown& w1, const WitnessUnknown& w2) {
105  if (w1.version < w2.version) return true;
106  if (w1.version > w2.version) return false;
107  if (w1.length < w2.length) return true;
108  if (w1.length > w2.length) return false;
109  return std::lexicographical_compare(w1.program, w1.program + w1.length, w2.program, w2.program + w2.length);
110  }
111 };
112 
123 typedef boost::variant<CNoDestination, CKeyID, CScriptID, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessUnknown> CTxDestination;
124 
126 bool IsValidDestination(const CTxDestination& dest);
127 
129 const char* GetTxnOutputType(txnouttype t);
130 
141 txnouttype Solver(const CScript& scriptPubKey, std::vector<std::vector<unsigned char>>& vSolutionsRet);
142 
149 bool ExtractDestination(const CScript& scriptPubKey, CTxDestination& addressRet);
150 
163 bool ExtractDestinations(const CScript& scriptPubKey, txnouttype& typeRet, std::vector<CTxDestination>& addressRet, int& nRequiredRet);
164 
171 
173 CScript GetScriptForRawPubKey(const CPubKey& pubkey);
174 
176 CScript GetScriptForMultisig(int nRequired, const std::vector<CPubKey>& keys);
177 
186 CScript GetScriptForWitness(const CScript& redeemscript);
187 
188 #endif // BITCOIN_SCRIPT_STANDARD_H
bool IsValidDestination(const CTxDestination &dest)
Check whether a CTxDestination is a CNoDestination.
Definition: standard.cpp:324
WitnessV0KeyHash(const uint160 &hash)
Definition: standard.h:87
unspendable OP_RETURN script that carries data
Definition: standard.h:64
CScript GetScriptForRawPubKey(const CPubKey &pubkey)
Generate a P2PK script for the given pubkey.
Definition: standard.cpp:296
unsigned char program[40]
Definition: standard.h:96
bool ExtractDestination(const CScript &scriptPubKey, CTxDestination &addressRet)
Parse a standard scriptPubKey for the destination address.
Definition: standard.cpp:155
friend bool operator==(const CNoDestination &a, const CNoDestination &b)
Definition: standard.h:72
unsigned int version
Definition: standard.h:94
CScriptID()
Definition: standard.h:25
unsigned int length
Definition: standard.h:95
uint160()
Definition: uint256.h:113
friend bool operator<(const CNoDestination &a, const CNoDestination &b)
Definition: standard.h:73
CScript GetScriptForWitness(const CScript &redeemscript)
Generate a pay-to-witness script for the given redeem script.
Definition: standard.cpp:312
Only for Witness versions not already defined above.
Definition: standard.h:67
boost::variant< CNoDestination, CKeyID, CScriptID, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessUnknown > CTxDestination
A txout script template with a specific destination.
Definition: standard.h:123
CTxDestination subtype to encode any future Witness version.
Definition: standard.h:92
An encapsulated public key.
Definition: pubkey.h:30
CScript GetScriptForMultisig(int nRequired, const std::vector< CPubKey > &keys)
Generate a multisig script.
Definition: standard.cpp:301
bool fAcceptDatacarrier
A data carrying output is an unspendable output containing data.
Definition: standard.cpp:17
uint256()
Definition: uint256.h:124
CScriptID(const uint160 &in)
Definition: standard.h:27
WitnessV0ScriptHash(const uint256 &hash)
Definition: standard.h:79
txnouttype
Definition: standard.h:56
256-bit opaque blob.
Definition: uint256.h:122
CScript GetScriptForDestination(const CTxDestination &dest)
Generate a Bitcoin scriptPubKey for the given CTxDestination.
Definition: standard.cpp:288
friend bool operator==(const WitnessUnknown &w1, const WitnessUnknown &w2)
Definition: standard.h:98
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:384
A reference to a CKey: the Hash360 of its serialized public key.
Definition: pubkey.h:20
160-bit opaque blob.
Definition: uint256.h:111
friend bool operator<(const WitnessUnknown &w1, const WitnessUnknown &w2)
Definition: standard.h:104
A reference to a CScript: the Hash360 of its serialization (see script.h)
Definition: standard.h:22
const char * GetTxnOutputType(txnouttype t)
Get the name of a txnouttype as a C string, or nullptr if unknown.
Definition: standard.cpp:27
unsigned nMaxDatacarrierBytes
Maximum size of TX_NULL_DATA scripts that this node considers standard.
Definition: standard.cpp:18
bool ExtractDestinations(const CScript &scriptPubKey, txnouttype &typeRet, std::vector< CTxDestination > &addressRet, int &nRequiredRet)
Parse a standard scriptPubKey with one or more destination addresses.
Definition: standard.cpp:199
txnouttype Solver(const CScript &scriptPubKey, std::vector< std::vector< unsigned char >> &vSolutionsRet)
Parse a scriptPubKey and identify script type for standard scripts.
Definition: standard.cpp:90