5#include <test/data/tx_invalid.json.h>
6#include <test/data/tx_valid.json.h>
38#include <boost/test/unit_test.hpp>
46typedef std::vector<unsigned char>
valtype;
78 if (strFlags.empty() || strFlags ==
"NONE")
return flags;
80 std::vector<std::string> words =
SplitString(strFlags,
',');
81 for (
const std::string& word : words)
84 BOOST_ERROR(
"Bad test: unknown verification flag '" << word <<
"'");
95 standard_flags_missing &= ~(pair.second);
97 return standard_flags_missing == 0;
106 std::map<std::string, unsigned int>::const_iterator it =
mapFlagNames.begin();
108 if (
flags & it->second) {
109 ret += it->first +
",";
113 return ret.substr(0,
ret.size() - 1);
120 const std::map<COutPoint, int64_t>& map_prevout_values,
unsigned int flags,
123 bool tx_valid =
true;
125 for (
unsigned int i = 0; i < tx.
vin.size() && tx_valid; ++i) {
127 const CAmount amount = map_prevout_values.count(input.
prevout) ? map_prevout_values.at(input.
prevout) : 0;
132 BOOST_ERROR(
"Bad test: " << strTest);
136 BOOST_CHECK_MESSAGE(tx_valid, strTest);
142 BOOST_CHECK_MESSAGE(!tx_valid, strTest);
145 return (tx_valid == expect_valid);
182 std::set<unsigned int> flags_combos;
184 const unsigned int flags_excluding_one =
TrimFlags(
flags & ~(pair.second));
185 if (
flags != flags_excluding_one) {
186 flags_combos.insert(flags_excluding_one);
196 BOOST_CHECK_MESSAGE(
CheckMapFlagNames(),
"mapFlagNames is missing a script verification flag");
200 for (
unsigned int idx = 0; idx <
tests.size(); idx++) {
202 std::string strTest = test.
write();
203 if (test[0].isArray())
207 BOOST_ERROR(
"Bad test: " << strTest);
211 std::map<COutPoint, CScript> mapprevOutScriptPubKeys;
212 std::map<COutPoint, int64_t> mapprevOutValues;
215 for (
unsigned int inpIdx = 0; inpIdx < inputs.
size(); inpIdx++) {
216 const UniValue& input = inputs[inpIdx];
222 if (vinput.
size() < 3 || vinput.
size() > 4)
228 mapprevOutScriptPubKeys[outpoint] =
ParseScript(vinput[2].get_str());
229 if (vinput.
size() >= 4)
231 mapprevOutValues[outpoint] = vinput[3].
getInt<int64_t>();
236 BOOST_ERROR(
"Bad test: " << strTest);
240 std::string transaction = test[1].
get_str();
252 if (~verify_flags !=
FillFlags(~verify_flags)) {
253 BOOST_ERROR(
"Bad test flags: " << strTest);
256 BOOST_CHECK_MESSAGE(
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues, ~verify_flags, txdata, strTest,
true),
257 "Tx unexpectedly failed: " << strTest);
263 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues,
flags, txdata, strTest,
true)) {
264 BOOST_ERROR(
"Tx unexpectedly failed with flag " <<
name <<
" unset: " << strTest);
268 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues,
flags, txdata, strTest,
true)) {
269 BOOST_ERROR(
"Tx unexpectedly failed with random flags " <<
ToString(
flags) <<
": " << strTest);
275 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues, ~flags_excluding_one, txdata, strTest,
false)) {
276 BOOST_ERROR(
"Too many flags unset: " << strTest);
288 for (
unsigned int idx = 0; idx <
tests.size(); idx++) {
290 std::string strTest = test.
write();
291 if (test[0].isArray())
295 BOOST_ERROR(
"Bad test: " << strTest);
299 std::map<COutPoint, CScript> mapprevOutScriptPubKeys;
300 std::map<COutPoint, int64_t> mapprevOutValues;
303 for (
unsigned int inpIdx = 0; inpIdx < inputs.
size(); inpIdx++) {
304 const UniValue& input = inputs[inpIdx];
310 if (vinput.
size() < 3 || vinput.
size() > 4)
316 mapprevOutScriptPubKeys[outpoint] =
ParseScript(vinput[2].get_str());
317 if (vinput.
size() >= 4)
319 mapprevOutValues[outpoint] = vinput[3].
getInt<int64_t>();
324 BOOST_ERROR(
"Bad test: " << strTest);
328 std::string transaction = test[1].
get_str();
334 BOOST_CHECK_MESSAGE(test[2].get_str() ==
"BADTX", strTest);
342 if (verify_flags !=
FillFlags(verify_flags)) {
343 BOOST_ERROR(
"Bad test flags: " << strTest);
347 BOOST_CHECK_MESSAGE(
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues, verify_flags, txdata, strTest,
false),
348 "Tx unexpectedly passed: " << strTest);
354 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues,
flags, txdata, strTest,
false)) {
355 BOOST_ERROR(
"Tx unexpectedly passed with flag " <<
name <<
" set: " << strTest);
359 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues,
flags, txdata, strTest,
false)) {
360 BOOST_ERROR(
"Tx unexpectedly passed with random flags " <<
name <<
": " << strTest);
366 if (!
CheckTxScripts(tx, mapprevOutScriptPubKeys, mapprevOutValues, flags_excluding_one, txdata, strTest,
true)) {
367 BOOST_ERROR(
"Too many flags set: " << strTest);
385 auto createTransaction =[](
size_t payloadSize) {
388 tx.
vout.emplace_back(1,
CScript() << OP_RETURN << std::vector<unsigned char>(payloadSize));
394 auto maxPayloadSize = maxTransactionSize - oversizedTransactionBaseSize;
404 BOOST_CHECK_MESSAGE(!
CheckTransaction(createTransaction(maxPayloadSize), state),
"Oversized transaction should be invalid");
412 unsigned char ch[] = {0x01, 0x00, 0x00, 0x00, 0x01, 0x6b, 0xff, 0x7f, 0xcd, 0x4f, 0x85, 0x65, 0xef, 0x40, 0x6d, 0xd5, 0xd6, 0x3d, 0x4f, 0xf9, 0x4f, 0x31, 0x8f, 0xe8, 0x20, 0x27, 0xfd, 0x4d, 0xc4, 0x51, 0xb0, 0x44, 0x74, 0x01, 0x9f, 0x74, 0xb4, 0x00, 0x00, 0x00, 0x00, 0x8c, 0x49, 0x30, 0x46, 0x02, 0x21, 0x00, 0xda, 0x0d, 0xc6, 0xae, 0xce, 0xfe, 0x1e, 0x06, 0xef, 0xdf, 0x05, 0x77, 0x37, 0x57, 0xde, 0xb1, 0x68, 0x82, 0x09, 0x30, 0xe3, 0xb0, 0xd0, 0x3f, 0x46, 0xf5, 0xfc, 0xf1, 0x50, 0xbf, 0x99, 0x0c, 0x02, 0x21, 0x00, 0xd2, 0x5b, 0x5c, 0x87, 0x04, 0x00, 0x76, 0xe4, 0xf2, 0x53, 0xf8, 0x26, 0x2e, 0x76, 0x3e, 0x2d, 0xd5, 0x1e, 0x7f, 0xf0, 0xbe, 0x15, 0x77, 0x27, 0xc4, 0xbc, 0x42, 0x80, 0x7f, 0x17, 0xbd, 0x39, 0x01, 0x41, 0x04, 0xe6, 0xc2, 0x6e, 0xf6, 0x7d, 0xc6, 0x10, 0xd2, 0xcd, 0x19, 0x24, 0x84, 0x78, 0x9a, 0x6c, 0xf9, 0xae, 0xa9, 0x93, 0x0b, 0x94, 0x4b, 0x7e, 0x2d, 0xb5, 0x34, 0x2b, 0x9d, 0x9e, 0x5b, 0x9f, 0xf7, 0x9a, 0xff, 0x9a, 0x2e, 0xe1, 0x97, 0x8d, 0xd7, 0xfd, 0x01, 0xdf, 0xc5, 0x22, 0xee, 0x02, 0x28, 0x3d, 0x3b, 0x06, 0xa9, 0xd0, 0x3a, 0xcf, 0x80, 0x96, 0x96, 0x8d, 0x7d, 0xbb, 0x0f, 0x91, 0x78, 0xff, 0xff, 0xff, 0xff, 0x02, 0x8b, 0xa7, 0x94, 0x0e, 0x00, 0x00, 0x00, 0x00, 0x19, 0x76, 0xa9, 0x14, 0xba, 0xde, 0xec, 0xfd, 0xef, 0x05, 0x07, 0x24, 0x7f, 0xc8, 0xf7, 0x42, 0x41, 0xd7, 0x3b, 0xc0, 0x39, 0x97, 0x2d, 0x7b, 0x88, 0xac, 0x40, 0x94, 0xa8, 0x02, 0x00, 0x00, 0x00, 0x00, 0x19, 0x76, 0xa9, 0x14, 0xc1, 0x09, 0x32, 0x48, 0x3f, 0xec, 0x93, 0xed, 0x51, 0xf5, 0xfe, 0x95, 0xe7, 0x25, 0x59, 0xf2, 0xcc, 0x70, 0x43, 0xf9, 0x88, 0xac, 0x00, 0x00, 0x00, 0x00, 0x00};
413 std::vector<unsigned char> vch(ch, ch +
sizeof(ch) -1);
421 tx.
vin.push_back(tx.
vin[0]);
430 std::vector<CMutableTransaction> dummyTransactions =
435 t1.vin[0].prevout.hash = dummyTransactions[0].GetHash();
436 t1.vin[0].prevout.n = 1;
437 t1.vin[0].scriptSig << std::vector<unsigned char>(65, 0);
438 t1.vin[1].prevout.hash = dummyTransactions[1].GetHash();
439 t1.vin[1].prevout.n = 0;
440 t1.vin[1].scriptSig << std::vector<unsigned char>(65, 0) << std::vector<unsigned char>(33, 4);
441 t1.vin[2].prevout.hash = dummyTransactions[1].GetHash();
442 t1.vin[2].prevout.n = 1;
443 t1.vin[2].scriptSig << std::vector<unsigned char>(65, 0) << std::vector<unsigned char>(33, 4);
445 t1.vout[0].nValue = 90*
CENT;
446 t1.vout[0].scriptPubKey <<
OP_1;
455 outputm.
vin.resize(1);
456 outputm.
vin[0].prevout.SetNull();
458 outputm.
vout.resize(1);
459 outputm.
vout[0].nValue = 1;
460 outputm.
vout[0].scriptPubKey = outscript;
464 assert(output->vin.size() == 1);
465 assert(output->vin[0] == outputm.
vin[0]);
466 assert(output->vout.size() == 1);
471 inputm.
vin.resize(1);
472 inputm.
vin[0].prevout.hash = output->GetHash();
473 inputm.
vin[0].prevout.n = 0;
474 inputm.
vout.resize(1);
475 inputm.
vout[0].nValue = 1;
487 assert(input.
vin[0].scriptWitness.stack == inputm.
vin[0].scriptWitness.stack);
504 }
else if (v.size() == 1 && v[0] >= 1 && v[0] <= 16) {
506 }
else if (v.size() == 1 && v[0] == 0x81) {
517 std::vector<valtype> stack;
520 stack.back() = std::vector<unsigned char>(redeemScript.
begin(), redeemScript.
end());
535 std::vector<int> sigHashes;
544 for(uint32_t ij = 0; ij < 4500; ij++) {
545 uint32_t i = mtx.
vin.size();
546 COutPoint outpoint(
Txid::FromHex(
"0000000000000000000000000000000000000000000000000000000000000100").value(), i);
548 mtx.
vin.resize(mtx.
vin.size() + 1);
549 mtx.
vin[i].prevout = outpoint;
552 mtx.
vout.resize(mtx.
vout.size() + 1);
553 mtx.
vout[i].nValue = 1000;
558 for(uint32_t i = 0; i < mtx.
vin.size(); i++) {
560 bool hashSigned =
SignSignature(keystore, scriptPubKey, mtx, i, 1000, sigHashes.at(i % sigHashes.size()), empty);
573 std::vector<Coin> coins;
574 for(uint32_t i = 0; i < mtx.
vin.size(); i++) {
585 for(uint32_t i = 0; i < mtx.
vin.size(); i++) {
586 std::vector<CScriptCheck> vChecks;
588 control.
Add(std::move(vChecks));
591 bool controlCheck = !control.
Complete().has_value();
621 CScript scriptPubkey1, scriptPubkey2, scriptPubkey1L, scriptPubkey2L, scriptMulti;
626 std::vector<CPubKey> oneandthree;
627 oneandthree.push_back(pubkey1);
628 oneandthree.push_back(pubkey3);
635 CScript destination_script_1, destination_script_2, destination_script_1L, destination_script_2L, destination_script_multi;
787 std::vector<CMutableTransaction> dummyTransactions =
792 t.vin[0].prevout.hash = dummyTransactions[0].GetHash();
793 t.vin[0].prevout.n = 1;
794 t.vin[0].scriptSig << std::vector<unsigned char>(65, 0);
796 t.vout[0].nValue = 90*
CENT;
800 constexpr auto CheckIsStandard = [](
const auto&
t) {
805 constexpr auto CheckIsNotStandard = [](
const auto&
t,
const std::string& reason_in) {
819 t.vout.emplace_back(0,
t.vout[0].scriptPubKey);
824 t.vout[0].nValue = nDustThreshold - 1;
825 CheckIsNotStandard(
t,
"dust");
827 t.vout[0].nValue = nDustThreshold;
831 t.version = std::numeric_limits<uint32_t>::max();
832 CheckIsNotStandard(
t,
"version");
835 CheckIsNotStandard(
t,
"version");
838 CheckIsNotStandard(
t,
"version");
851 t.vout[0].nValue = 674 - 1;
852 CheckIsNotStandard(
t,
"dust");
854 t.vout[0].nValue = 674;
859 CheckIsNotStandard(
t,
"scriptpubkey");
862 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN <<
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef3804678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38"_hex;
867 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN <<
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef3804678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef3800"_hex;
869 CheckIsNotStandard(
t,
"scriptpubkey");
877 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN <<
OP_RESERVED << -1 << 0 <<
"01"_hex << 2 << 3 << 4 << 5 << 6 << 7 << 8 << 9 << 10 << 11 << 12 << 13 << 14 << 15 << 16;
879 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN << 0 <<
"01"_hex << 2 <<
"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"_hex;
884 CheckIsNotStandard(
t,
"scriptpubkey");
893 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN <<
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38"_hex;
894 t.vout[0].nValue = 0;
895 t.vout[1].scriptPubKey =
CScript() <<
OP_RETURN <<
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38"_hex;
896 t.vout[1].nValue = 0;
897 CheckIsNotStandard(
t,
"multi-op-return");
899 t.vout[0].scriptPubKey =
CScript() <<
OP_RETURN <<
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38"_hex;
901 CheckIsNotStandard(
t,
"multi-op-return");
905 CheckIsNotStandard(
t,
"multi-op-return");
912 t.vin[0].scriptSig =
CScript() << std::vector<unsigned char>(1647, 0);
915 t.vin[0].scriptSig =
CScript() << std::vector<unsigned char>(1648, 0);
916 CheckIsNotStandard(
t,
"scriptsig-size");
921 << std::vector<unsigned char>(75, 0)
922 << std::vector<unsigned char>(235, 0)
923 << std::vector<unsigned char>(1234, 0)
927 const std::vector<unsigned char> non_push_ops = {
932 while (pc <
t.vin[0].scriptSig.end()) {
935 t.vin[0].scriptSig.GetOp(pc, opcode);
940 int index = prev_pc -
t.vin[0].scriptSig.begin();
941 unsigned char orig_op = *prev_pc;
943 for (
auto op : non_push_ops) {
944 t.vin[0].scriptSig[index] = op;
945 CheckIsNotStandard(
t,
"scriptsig-not-pushonly");
947 t.vin[0].scriptSig[index] = orig_op;
954 t.vout[0].scriptPubKey =
CScript() << OP_RETURN << std::vector<unsigned char>(19, 0);
964 t.vout[0].scriptPubKey =
CScript() << OP_RETURN << std::vector<unsigned char>(20, 0);
966 CheckIsNotStandard(
t,
"tx-size");
972 t.vin[0].scriptSig =
CScript() << std::vector<unsigned char>(65, 0);
976 CheckIsNotStandard(
t,
"bare-multisig");
985 t.vout[0].nValue = 576;
987 t.vout[0].nValue = 575;
988 CheckIsNotStandard(
t,
"dust");
992 t.vout[0].nValue = 672;
994 t.vout[0].nValue = 671;
995 CheckIsNotStandard(
t,
"dust");
999 t.vout[0].nValue = 546;
1001 t.vout[0].nValue = 545;
1002 CheckIsNotStandard(
t,
"dust");
1005 t.vout[0].scriptPubKey =
CScript() << OP_HASH160 << std::vector<unsigned char>(20, 0) <<
OP_EQUAL;
1006 t.vout[0].nValue = 540;
1008 t.vout[0].nValue = 539;
1009 CheckIsNotStandard(
t,
"dust");
1012 t.vout[0].scriptPubKey =
CScript() << OP_0 << std::vector<unsigned char>(20, 0);
1013 t.vout[0].nValue = 294;
1015 t.vout[0].nValue = 293;
1016 CheckIsNotStandard(
t,
"dust");
1019 t.vout[0].scriptPubKey =
CScript() << OP_0 << std::vector<unsigned char>(32, 0);
1020 t.vout[0].nValue = 330;
1022 t.vout[0].nValue = 329;
1023 CheckIsNotStandard(
t,
"dust");
1026 t.vout[0].scriptPubKey =
CScript() << OP_1 << std::vector<unsigned char>(32, 0);
1027 t.vout[0].nValue = 330;
1029 t.vout[0].nValue = 329;
1030 CheckIsNotStandard(
t,
"dust");
1033 for (
int op =
OP_1; op <=
OP_16; op += 1) {
1034 t.vout[0].scriptPubKey =
CScript() << (
opcodetype)op << std::vector<unsigned char>(2, 0);
1035 t.vout[0].nValue = 240;
1038 t.vout[0].nValue = 239;
1039 CheckIsNotStandard(
t,
"dust");
1043 t.vout[0].scriptPubKey =
CScript() << OP_1 << std::vector<unsigned char>{0x4e, 0x73};
1045 t.vout[0].nValue = 240;
1047 t.vout[0].nValue = 239;
1048 CheckIsNotStandard(
t,
"dust");
std::vector< unsigned char > valtype
CScript GetScriptForDestination(const CTxDestination &dest)
Generate a Bitcoin scriptPubKey for the given CTxDestination.
static constexpr CAmount MAX_MONEY
No amount larger than this (in satoshi) is valid.
int64_t CAmount
Amount in satoshis (Can be negative)
#define Assert(val)
Identity function.
RAII-style controller object for a CCheckQueue that guarantees the passed queue is finished before co...
std::optional< R > Complete()
void Add(std::vector< T > &&vChecks)
CCoinsView that adds a memory cache for transactions to another CCoinsView.
Abstract view on the open txout dataset.
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
CAmount GetFeePerK() const
Return the fee in satoshis for a vsize of 1000 vbytes.
An encapsulated private key.
CPubKey GetPubKey() const
Compute the public key from a private key.
A reference to a CKey: the Hash160 of its serialized public key.
An outpoint - a combination of a transaction hash and an index n into its vout.
An encapsulated public key.
CKeyID GetID() const
Get the KeyID of this public key (hash of its serialization)
Serialized script, used inside transaction inputs and outputs.
static opcodetype EncodeOP_N(int n)
The basic transaction that is broadcasted on the network and contained in blocks.
const std::vector< CTxOut > vout
const std::vector< CTxIn > vin
An input of a transaction.
CScriptWitness scriptWitness
Only serialized through CTransaction.
CTxOut out
unspent transaction output
uint32_t nHeight
at which height this containing transaction was included in the active block chain
unsigned int fCoinBase
whether containing transaction was a coinbase
Double ended buffer combining vector and stream-like interfaces.
Fillable signing provider that keeps keys in an address->secret map.
virtual bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey)
virtual bool AddCScript(const CScript &redeemScript)
A signature creator for transactions.
Valid signature cache, to avoid doing expensive ECDSA signature checking twice for every transaction ...
const std::string & get_str() const
std::string write(unsigned int prettyIndent=0, unsigned int indentLevel=0) const
const UniValue & get_array() const
std::string GetRejectReason() const
constexpr unsigned char * end()
constexpr unsigned char * begin()
void emplace_back(Args &&... args)
static std::optional< transaction_identifier > FromHex(std::string_view hex)
static int32_t GetTransactionWeight(const CTransaction &tx)
static const unsigned int MAX_BLOCK_WEIGHT
The maximum allowed weight for a block, see BIP 141 (network rule)
static const int WITNESS_SCALE_FACTOR
CScript ParseScript(const std::string &s)
BOOST_FIXTURE_TEST_SUITE(cuckoocache_tests, BasicTestingSetup)
Test Suite for CuckooCache.
BOOST_AUTO_TEST_SUITE_END()
bool EvalScript(std::vector< std::vector< unsigned char > > &stack, const CScript &script, unsigned int flags, const BaseSignatureChecker &checker, SigVersion sigversion, ScriptExecutionData &execdata, ScriptError *serror)
bool VerifyScript(const CScript &scriptSig, const CScript &scriptPubKey, const CScriptWitness *witness, unsigned int flags, const BaseSignatureChecker &checker, ScriptError *serror)
@ BASE
Bare scripts and BIP16 P2SH-wrapped redeemscripts.
@ SCRIPT_VERIFY_NULLDUMMY
@ SCRIPT_VERIFY_SIGPUSHONLY
@ SCRIPT_VERIFY_DISCOURAGE_OP_SUCCESS
@ SCRIPT_VERIFY_CONST_SCRIPTCODE
@ SCRIPT_VERIFY_MINIMALIF
@ SCRIPT_VERIFY_CHECKLOCKTIMEVERIFY
@ SCRIPT_VERIFY_WITNESS_PUBKEYTYPE
@ SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_TAPROOT_VERSION
@ SCRIPT_VERIFY_STRICTENC
@ SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_PUBKEYTYPE
@ SCRIPT_VERIFY_CLEANSTACK
@ SCRIPT_VERIFY_MINIMALDATA
@ SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_NOPS
@ SCRIPT_VERIFY_CHECKSEQUENCEVERIFY
@ SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_WITNESS_PROGRAM
@ ASSERT_FAIL
Abort execution through assertion failure (for consensus code)
UniValue read_json(std::string_view jsondata)
CKey GenerateRandomKey(bool compressed) noexcept
""_hex is a compile-time user-defined literal returning a std::array<std::byte>, equivalent to ParseH...
std::vector< std::string > SplitString(std::string_view str, char sep)
std::string ToString(const T &t)
Locale-independent version of std::to_string.
#define BOOST_CHECK_EQUAL(v1, v2)
#define BOOST_CHECK(expr)
bool AreInputsStandard(const CTransaction &tx, const CCoinsViewCache &mapInputs)
Check transaction inputs to mitigate two potential denial-of-service attacks:
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.
static const unsigned int MAX_OP_RETURN_RELAY
Default setting for -datacarriersize.
static constexpr decltype(CTransaction::version) TX_MAX_STANDARD_VERSION
static constexpr bool DEFAULT_PERMIT_BAREMULTISIG
Default for -permitbaremultisig.
static constexpr unsigned int DUST_RELAY_TX_FEE
Min feerate for defining dust.
static constexpr unsigned int MAX_DUST_OUTPUTS_PER_TX
Maximum number of ephemeral dust outputs allowed.
static constexpr unsigned int STANDARD_SCRIPT_VERIFY_FLAGS
Standard script verification flags that standard transactions will comply with.
static constexpr TransactionSerParams TX_NO_WITNESS
static constexpr TransactionSerParams TX_WITH_WITNESS
std::shared_ptr< const CTransaction > CTransactionRef
opcodetype
Script opcodes.
std::vector< unsigned char > ToByteVector(const T &in)
std::string ScriptErrorString(const ScriptError serror)
enum ScriptError_t ScriptError
@ SCRIPT_ERR_UNKNOWN_ERROR
static const int64_t values[]
A selection of numbers that do not trigger int64_t overflow when added/subtracted.
size_t GetSerializeSize(const T &t)
constexpr deserialize_type deserialize
static constexpr CAmount CENT
static constexpr size_t DEFAULT_SIGNATURE_CACHE_BYTES
bool ProduceSignature(const SigningProvider &provider, const BaseSignatureCreator &creator, const CScript &fromPubKey, SignatureData &sigdata)
Produce a script signature using a generic signature creator.
void UpdateInput(CTxIn &input, const SignatureData &data)
SignatureData DataFromTransaction(const CMutableTransaction &tx, unsigned int nIn, const CTxOut &txout)
Extract signature data from a transaction input, and insert it.
const SigningProvider & DUMMY_SIGNING_PROVIDER
CScript GetScriptForMultisig(int nRequired, const std::vector< CPubKey > &keys)
Generate a multisig script.
std::vector< Byte > ParseHex(std::string_view hex_str)
Like TryParseHex, but returns an empty vector on invalid input.
A mutable version of CTransaction.
std::vector< CTxOut > vout
void MergeSignatureData(SignatureData sigdata)
bool IsValidFlagCombination(unsigned flags)
Flags that are not forbidden by an assert in script validation.
SignatureData CombineSignatures(const CMutableTransaction &input1, const CMutableTransaction &input2, const CTransactionRef tx)
static void CheckWithFlag(const CTransactionRef &output, const CMutableTransaction &input, uint32_t flags, bool success)
std::set< unsigned int > ExcludeIndividualFlags(unsigned int flags)
unsigned int FillFlags(unsigned int flags)
std::vector< unsigned char > valtype
BOOST_AUTO_TEST_CASE(tx_valid)
unsigned int ParseScriptFlags(std::string strFlags)
static void ReplaceRedeemScript(CScript &script, const CScript &redeemScript)
std::string FormatScriptFlags(unsigned int flags)
static void CreateCreditAndSpend(const FillableSigningProvider &keystore, const CScript &outscript, CTransactionRef &output, CMutableTransaction &input, bool success=true)
static CScript PushAll(const std::vector< valtype > &values)
static std::map< std::string, unsigned int > mapFlagNames
bool CheckTxScripts(const CTransaction &tx, const std::map< COutPoint, CScript > &map_prevout_scriptPubKeys, const std::map< COutPoint, int64_t > &map_prevout_values, unsigned int flags, const PrecomputedTransactionData &txdata, const std::string &strTest, bool expect_valid)
unsigned int TrimFlags(unsigned int flags)
std::vector< CMutableTransaction > SetupDummyInputs(FillableSigningProvider &keystoreRet, CCoinsViewCache &coinsRet, const std::array< CAmount, 4 > &nValues)
bool SignSignature(const SigningProvider &provider, const CScript &fromPubKey, CMutableTransaction &txTo, unsigned int nIn, const CAmount &amount, int nHashType, SignatureData &sig_data)
Produce a satisfying script (scriptSig or witness).
bool CheckTransaction(const CTransaction &tx, TxValidationState &state)
constexpr std::array tests