10 #include <chainparams.h> 20 #include <txmempool.h> 38 "\nSubmit a raw transaction (serialized, hex-encoded) to local node and network.\n" 39 "\nThe transaction will be sent unconditionally to all peers, so using sendrawtransaction\n" 40 "for manual rebroadcast may degrade privacy by leaking the transaction's origin, as\n" 41 "nodes will normally not rebroadcast non-wallet transactions already in their mempool.\n" 42 "\nA specific exception, RPC_TRANSACTION_ALREADY_IN_CHAIN, may throw if the transaction cannot be added to the mempool.\n" 43 "\nRelated RPCs: createrawtransaction, signrawtransactionwithkey\n",
47 "Reject transactions whose fee rate is higher than the specified value, expressed in " +
CURRENCY_UNIT +
48 "/kvB.\nFee rates larger than 1BTC/kvB are rejected.\nSet to 0 to accept any fee rate."},
50 "Reject transactions with provably unspendable outputs (e.g. 'datacarrier' outputs that use the OP_RETURN opcode) greater than the specified value, expressed in " +
CURRENCY_UNIT +
".\n" 51 "If burning funds through unspendable outputs is desired, increase this value.\n" 52 "This check is based on heuristics and does not guarantee spendability of outputs.\n"},
58 "\nCreate a transaction\n" 59 +
HelpExampleCli(
"createrawtransaction",
"\"[{\\\"txid\\\" : \\\"mytxid\\\",\\\"vout\\\":0}]\" \"{\\\"myaddress\\\":0.01}\"") +
60 "Sign the transaction, and get back the hex\n" 62 "\nSend the transaction (signed hex)\n" 64 "\nAs a JSON-RPC call\n" 72 if (!
DecodeHexTx(mtx, request.params[0].get_str())) {
76 for (
const auto&
out : mtx.
vout) {
77 if((
out.scriptPubKey.IsUnspendable() || !
out.scriptPubKey.HasValidOps()) &&
out.nValue > max_burn_amount) {
87 CAmount max_raw_tx_fee = max_raw_tx_fee_rate.GetFee(virtual_size);
89 std::string err_string;
97 return tx->GetHash().GetHex();
105 "\nReturns result of mempool acceptance tests indicating if raw transaction(s) (serialized, hex-encoded) would be accepted by mempool.\n" 106 "\nIf multiple transactions are passed in, parents must come before children and package policies apply: the transactions cannot conflict with any mempool transactions or each other.\n" 107 "\nIf one transaction fails, other transactions may not be fully validated (the 'allowed' key will be blank).\n" 109 "\nThis checks if transactions violate the consensus or policy rules.\n" 110 "\nSee sendrawtransaction call.\n",
118 "Reject transactions whose fee rate is higher than the specified value, expressed in " +
CURRENCY_UNIT +
119 "/kvB.\nFee rates larger than 1BTC/kvB are rejected.\nSet to 0 to accept any fee rate."},
122 RPCResult::Type::ARR,
"",
"The result of the mempool acceptance test for each raw transaction in the input array.\n" 123 "Returns results for each transaction in the same order they were passed in.\n" 124 "Transactions that cannot be fully validated due to failures in other transactions will not contain an 'allowed' result.\n",
130 {
RPCResult::Type::STR,
"package-error",
true,
"Package validation error, if any (only possible if rawtxs had more than 1 transaction)."},
131 {
RPCResult::Type::BOOL,
"allowed",
true,
"Whether this tx would be accepted to the mempool and pass client-specified maxfeerate. " 132 "If not present, the tx was not fully validated due to a failure in another tx in the list."},
133 {
RPCResult::Type::NUM,
"vsize",
true,
"Virtual transaction size as defined in BIP 141. This is different from actual serialized size for witness transactions as witness data is discounted (only present when 'allowed' is true)"},
137 {
RPCResult::Type::STR_AMOUNT,
"effective-feerate",
false,
"the effective feerate in " +
CURRENCY_UNIT +
" per KvB. May differ from the base feerate if, for example, there are modified fees from prioritisetransaction or a package feerate was used."},
138 {
RPCResult::Type::ARR,
"effective-includes",
false,
"transactions whose fees and vsizes are included in effective-feerate.",
142 {
RPCResult::Type::STR,
"reject-reason",
true,
"Rejection string (only present when 'allowed' is false)"},
147 "\nCreate a transaction\n" 148 +
HelpExampleCli(
"createrawtransaction",
"\"[{\\\"txid\\\" : \\\"mytxid\\\",\\\"vout\\\":0}]\" \"{\\\"myaddress\\\":0.01}\"") +
149 "Sign the transaction, and get back the hex\n" 151 "\nTest acceptance of the transaction (signed hex)\n" 153 "\nAs a JSON-RPC call\n" 166 std::vector<CTransactionRef> txns;
167 txns.reserve(raw_transactions.
size());
168 for (
const auto& rawtx : raw_transactions.
getValues()) {
172 "TX decode failed: " + rawtx.get_str() +
" Make sure the tx has at least one input.");
193 bool exit_early{
false};
194 for (
const auto& tx : txns) {
196 result_inner.
pushKV(
"txid", tx->GetHash().GetHex());
197 result_inner.
pushKV(
"wtxid", tx->GetWitnessHash().GetHex());
201 auto it = package_result.
m_tx_results.find(tx->GetWitnessHash());
202 if (exit_early || it == package_result.
m_tx_results.end()) {
207 const auto& tx_result = it->second;
211 const CAmount fee = tx_result.m_base_fees.value();
213 const int64_t virtual_size = tx_result.m_vsize.value();
214 const CAmount max_raw_tx_fee = max_raw_tx_fee_rate.GetFee(virtual_size);
215 if (max_raw_tx_fee && fee > max_raw_tx_fee) {
216 result_inner.
pushKV(
"allowed",
false);
217 result_inner.
pushKV(
"reject-reason",
"max-fee-exceeded");
222 result_inner.
pushKV(
"allowed",
true);
223 result_inner.
pushKV(
"vsize", virtual_size);
226 fees.
pushKV(
"effective-feerate",
ValueFromAmount(tx_result.m_effective_feerate.value().GetFeePerK()));
228 for (
const auto& wtxid : tx_result.m_wtxids_fee_calculations.value()) {
229 effective_includes_res.
push_back(wtxid.ToString());
231 fees.
pushKV(
"effective-includes", effective_includes_res);
232 result_inner.
pushKV(
"fees", fees);
235 result_inner.
pushKV(
"allowed",
false);
238 result_inner.
pushKV(
"reject-reason",
"missing-inputs");
253 RPCResult{
RPCResult::Type::NUM,
"vsize",
"virtual transaction size as defined in BIP 141. This is different from actual serialized size for witness transactions as witness data is discounted."},
273 RPCResult{
RPCResult::Type::BOOL,
"bip125-replaceable",
"Whether this transaction signals BIP125 replaceability or has an unconfirmed ancestor signaling BIP125 replaceability.\n"},
274 RPCResult{
RPCResult::Type::BOOL,
"unbroadcast",
"Whether this transaction is currently unbroadcast (initial broadcast not yet acknowledged by any peers)"},
282 info.pushKV(
"vsize", (
int)e.GetTxSize());
283 info.pushKV(
"weight", (
int)e.GetTxWeight());
285 info.pushKV(
"height", (
int)e.GetHeight());
286 info.pushKV(
"descendantcount", e.GetCountWithDescendants());
287 info.pushKV(
"descendantsize", e.GetSizeWithDescendants());
288 info.pushKV(
"ancestorcount", e.GetCountWithAncestors());
289 info.pushKV(
"ancestorsize", e.GetSizeWithAncestors());
290 info.pushKV(
"wtxid", e.GetTx().GetWitnessHash().ToString());
297 info.pushKV(
"fees", fees);
300 std::set<std::string> setDepends;
308 for (
const std::string& dep : setDepends)
313 info.pushKV(
"depends", depends);
317 spent.
push_back(child.GetTx().GetHash().ToString());
320 info.pushKV(
"spentby", spent);
323 bool rbfStatus =
false;
331 info.pushKV(
"bip125-replaceable", rbfStatus);
332 info.pushKV(
"unbroadcast", pool.IsUnbroadcastTx(tx.
GetHash()));
338 if (include_mempool_sequence) {
349 o.
pushKVEnd(e.GetTx().GetHash().ToString(), info);
354 uint64_t mempool_sequence;
358 a.
push_back(e.GetTx().GetHash().ToString());
362 if (!include_mempool_sequence) {
367 o.
pushKV(
"mempool_sequence", mempool_sequence);
376 "\nReturns all transaction ids in memory pool as a json array of string transaction ids.\n" 377 "\nHint: use getmempoolentry to fetch a specific transaction from the mempool.\n",
380 {
"mempool_sequence",
RPCArg::Type::BOOL,
RPCArg::Default{
false},
"If verbose=false, returns a json object with transaction list and mempool sequence number attached."},
393 RPCResult{
"for verbose = false and mempool_sequence = true",
409 bool fVerbose =
false;
410 if (!request.params[0].isNull())
411 fVerbose = request.params[0].
get_bool();
413 bool include_mempool_sequence =
false;
414 if (!request.params[1].isNull()) {
415 include_mempool_sequence = request.params[1].get_bool();
426 "\nIf txid is in the mempool, returns all in-mempool ancestors.\n",
447 bool fVerbose =
false;
448 if (!request.params[1].isNull())
449 fVerbose = request.params[1].
get_bool();
457 if (entry ==
nullptr) {
466 o.
push_back(ancestorIt->GetTx().GetHash().ToString());
487 "\nIf txid is in the mempool, returns all in-mempool descendants.\n",
508 bool fVerbose =
false;
509 if (!request.params[1].isNull())
510 fVerbose = request.params[1].
get_bool();
517 const auto it{mempool.
GetIter(hash)};
525 setDescendants.erase(*it);
530 o.
push_back(descendantIt->GetTx().GetHash().ToString());
552 "\nReturns mempool data for given transaction\n",
570 if (entry ==
nullptr) {
584 "Scans the mempool to find transactions spending any of the given outputs",
604 {
RPCResult::Type::STR_HEX,
"spendingtxid",
true,
"the transaction id of the mempool transaction spending this output (omitted if unspent)"},
609 HelpExampleCli(
"gettxspendingprevout",
"\"[{\\\"txid\\\":\\\"a08e6907dbbd3d809776dbfc5d82e371b764ed838b5655e72f463568df1aadf0\\\",\\\"vout\\\":3}]\"")
610 +
HelpExampleRpc(
"gettxspendingprevout",
"\"[{\\\"txid\\\":\\\"a08e6907dbbd3d809776dbfc5d82e371b764ed838b5655e72f463568df1aadf0\\\",\\\"vout\\\":3}]\"")
615 if (output_params.
empty()) {
619 std::vector<COutPoint> prevouts;
620 prevouts.reserve(output_params.
size());
622 for (
unsigned int idx = 0; idx < output_params.
size(); idx++) {
637 prevouts.emplace_back(txid, nOutput);
645 for (
const COutPoint& prevout : prevouts) {
647 o.
pushKV(
"txid", prevout.hash.ToString());
648 o.
pushKV(
"vout", (uint64_t)prevout.n);
651 if (spendingTx !=
nullptr) {
669 ret.pushKV(
"size", (int64_t)pool.
size());
685 "Returns details on the active state of the TX memory pool.",
690 {
RPCResult::Type::BOOL,
"loaded",
"True if the initial load attempt of the persisted mempool finished"},
692 {
RPCResult::Type::NUM,
"bytes",
"Sum of all virtual transaction sizes as defined in BIP 141. Differs from actual serialized size because witness data is discounted"},
699 {
RPCResult::Type::NUM,
"unbroadcastcount",
"Current number of transactions that haven't passed initial broadcast yet"},
700 {
RPCResult::Type::BOOL,
"fullrbf",
"True if the mempool accepts RBF without replaceability signaling inspection"},
717 "Import a mempool.dat file and attempt to add its contents to the mempool.\n" 718 "Warning: Importing untrusted files is dangerous, especially if metadata from the file is taken over.",
727 "Whether to use the current system time or use the entry time metadata from the mempool file.\n" 728 "Warning: Importing untrusted metadata may lead to unexpected issues and undesirable behavior."},
730 "Whether to apply the fee delta metadata from the mempool file.\n" 731 "It will be added to any existing fee deltas.\n" 732 "The fee delta can be set by the prioritisetransaction RPC.\n" 733 "Warning: Importing untrusted metadata may lead to unexpected issues and undesirable behavior.\n" 734 "Only set this bool if you understand what it does."},
736 "Whether to apply the unbroadcast set metadata from the mempool file.\n" 737 "Warning: Importing untrusted metadata may lead to unexpected issues and undesirable behavior."},
755 const UniValue& use_current_time{request.params[1][
"use_current_time"]};
756 const UniValue& apply_fee_delta{request.params[1][
"apply_fee_delta_priority"]};
757 const UniValue& apply_unbroadcast{request.params[1][
"apply_unbroadcast_set"]};
759 .
use_current_time = use_current_time.isNull() ? true : use_current_time.get_bool(),
760 .apply_fee_delta_priority = apply_fee_delta.isNull() ? false : apply_fee_delta.get_bool(),
761 .apply_unbroadcast_set = apply_unbroadcast.isNull() ? false : apply_unbroadcast.get_bool(),
777 "\nDumps the mempool to disk. It will fail until the previous dump is fully loaded.\n",
814 "Submit a package of raw transactions (serialized, hex-encoded) to local node.\n" 815 "The package must consist of a child with its parents, and none of the parents may depend on one another.\n" 816 "The package will be validated according to consensus and mempool policy rules. If any transaction passes, it will be accepted to mempool.\n" 817 "This RPC is experimental and the interface may be unstable. Refer to doc/policy/packages.md for documentation on package policies.\n" 818 "Warning: successful submission does not mean the transactions will propagate throughout the network.\n" 830 {
RPCResult::Type::STR,
"package_msg",
"The transaction package result message. \"success\" indicates all transactions were accepted into or are already in the mempool."},
835 {
RPCResult::Type::STR_HEX,
"other-wtxid",
true,
"The wtxid of a different transaction with the same txid but different witness found in the mempool. This means the submitted transaction was ignored."},
839 {
RPCResult::Type::STR_AMOUNT,
"effective-feerate",
true,
"if the transaction was not already in the mempool, the effective feerate in " +
CURRENCY_UNIT +
" per KvB. For example, the package feerate and/or feerate with modified fees from prioritisetransaction."},
840 {
RPCResult::Type::ARR,
"effective-includes",
true,
"if effective-feerate is provided, the wtxids of the transactions whose fees and vsizes are included in effective-feerate.",
844 {
RPCResult::Type::STR,
"error",
true,
"The transaction error string, if it was rejected by the mempool"},
865 std::vector<CTransactionRef> txns;
866 txns.reserve(raw_transactions.
size());
867 for (
const auto& rawtx : raw_transactions.
getValues()) {
871 "TX decode failed: " + rawtx.get_str() +
" Make sure the tx has at least one input.");
884 std::string package_msg =
"success";
887 switch(package_result.m_state.GetResult()) {
891 CHECK_NONFATAL(package_result.m_tx_results.size() == txns.size());
892 for (
const auto& tx : txns) {
901 package_result.m_state.GetRejectReason());
907 package_msg = package_result.m_state.ToString();
908 CHECK_NONFATAL(package_result.m_tx_results.size() == txns.size() ||
909 package_result.m_tx_results.empty());
914 size_t num_broadcast{0};
915 for (
const auto& tx : txns) {
922 std::string err_string;
926 strprintf(
"transaction broadcast failed: %s (%d transactions were broadcast successfully)",
927 err_string, num_broadcast));
933 rpc_result.pushKV(
"package_msg", package_msg);
935 std::set<uint256> replaced_txids;
936 for (
const auto& tx : txns) {
938 result_inner.pushKV(
"txid", tx->GetHash().GetHex());
939 auto it = package_result.m_tx_results.find(tx->GetWitnessHash());
940 if (it == package_result.m_tx_results.end()) {
942 result_inner.pushKV(
"error",
"unevaluated");
945 const auto& tx_result = it->second;
946 switch(it->second.m_result_type) {
948 result_inner.pushKV(
"other-wtxid", it->second.m_other_wtxid.value().GetHex());
951 result_inner.pushKV(
"error", it->second.m_state.ToString());
955 result_inner.pushKV(
"vsize", int64_t{it->second.m_vsize.value()});
962 fees.
pushKV(
"effective-feerate",
ValueFromAmount(tx_result.m_effective_feerate.value().GetFeePerK()));
964 for (
const auto& wtxid : tx_result.m_wtxids_fee_calculations.value()) {
965 effective_includes_res.
push_back(wtxid.ToString());
967 fees.
pushKV(
"effective-includes", effective_includes_res);
969 result_inner.pushKV(
"fees", fees);
970 if (it->second.m_replaced_transactions.has_value()) {
971 for (
const auto& ptx : it->second.m_replaced_transactions.value()) {
972 replaced_txids.insert(ptx->GetHash());
977 tx_result_map.pushKV(tx->GetWitnessHash().GetHex(), result_inner);
979 rpc_result.pushKV(
"tx-results", tx_result_map);
981 for (
const uint256& hash : replaced_txids) replaced_list.
push_back(hash.ToString());
982 rpc_result.pushKV(
"replaced-transactions", replaced_list);
1003 for (
const auto& c : commands) {
1004 t.appendCommand(c.name, &c);
std::shared_ptr< const CTransaction > CTransactionRef
void RegisterMempoolRPCCommands(CRPCTable &t)
void push_back(UniValue val)
UniValue MempoolToJSON(const CTxMemPool &pool, bool verbose, bool include_mempool_sequence)
Mempool to JSON.
static RPCHelpMan getrawmempool()
const std::vector< UniValue > & getValues() const
uint256 ParseHashO(const UniValue &o, std::string_view strKey)
indexed_transaction_set::nth_index< 0 >::type::const_iterator txiter
static RPCHelpMan getmempoolancestors()
void RPCTypeCheckObj(const UniValue &o, const std::map< std::string, UniValueType > &typesExpected, bool fAllowNull, bool fStrict)
RBFTransactionState IsRBFOptIn(const CTransaction &tx, const CTxMemPool &pool)
Determine whether an unconfirmed transaction is signaling opt-in to RBF according to BIP 125 This inv...
The package itself is invalid (e.g. too many transactions).
Valid, transaction was already in the mempool.
Either this tx or a mempool ancestor signals rbf.
CTxMemPool & EnsureMemPool(const NodeContext &node)
bool exists(const GenTxid >xid) const
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate gen...
static RPCHelpMan getmempoolinfo()
Unconfirmed tx that does not signal rbf and is not in the mempool.
void CalculateDescendants(txiter it, setEntries &setDescendants) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Populate setDescendants with all in-mempool descendants of hash.
const int64_t m_max_size_bytes
size_t DynamicMemoryUsage() const
transaction was missing some of its inputs
#define CHECK_NONFATAL(condition)
Identity function.
Special type that behaves almost exactly like OBJ, defining an options object with a list of pre-defi...
unsigned long size() const
UniValue MempoolInfoToJSON(const CTxMemPool &pool)
Mempool information to JSON.
uint64_t GetSequence() const EXCLUSIVE_LOCKS_REQUIRED(cs)
bool IsChildWithParentsTree(const Package &package)
Context-free check that a package IsChildWithParents() and none of the parents depend on each other (...
std::set< txiter, CompareIteratorByHash > setEntries
void pushKVEnd(std::string key, UniValue val)
const Children & GetMemPoolChildrenConst() const
std::map< uint256, MempoolAcceptResult > m_tx_results
Map from wtxid to finished MempoolAcceptResults.
const UniValue & get_array() const
static void entryToJSON(const CTxMemPool &pool, UniValue &info, const CTxMemPoolEntry &e) EXCLUSIVE_LOCKS_REQUIRED(pool.cs)
int64_t GetVirtualTransactionSize(int64_t nWeight, int64_t nSigOpCost, unsigned int bytes_per_sigop)
Compute the virtual transaction size (weight reinterpreted as bytes).
bool DumpMempool(const CTxMemPool &pool, const fs::path &dump_path, FopenFn mockable_fopen_function, bool skip_file_commit)
setEntries AssumeCalculateMemPoolAncestors(std::string_view calling_fn_name, const CTxMemPoolEntry &entry, const Limits &limits, bool fSearchForParents=true) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Same as CalculateMemPoolAncestors, but always returns a (non-optional) setEntries.
bool LoadMempool(CTxMemPool &pool, const fs::path &load_path, Chainstate &active_chainstate, ImportMempoolOptions &&opts)
Import the file and attempt to add its contents to the mempool.
const std::vector< CTxIn > vin
Invalid, missing or duplicate parameter.
RBFTransactionState
The rbf state of unconfirmed transactions.
CFeeRate ParseFeeRate(const UniValue &json)
Parse a json number or string, denoting BTC/kvB, into a CFeeRate (sat/kvB).
CTxMemPoolEntry stores data about the corresponding transaction, as well as data about all in-mempool...
static RPCHelpMan importmempool()
int64_t CAmount
Amount in satoshis (Can be negative)
const UniValue & find_value(std::string_view key) const
std::string oneline_description
Should be empty unless it is supposed to override the auto-generated summary line.
std::string ToString(const T &t)
Locale-independent version of std::to_string.
Special type that is a STR with only hex chars.
NodeContext struct containing references to chain state and connection state.
std::string HelpExampleRpc(const std::string &methodname, const std::string &args)
UniValue JSONRPCError(int code, const std::string &message)
Special string with only hex chars.
static CAmount AmountFromValue(const UniValue &value)
Chainstate stores and provides an API to update our local knowledge of the current best chain...
static RPCHelpMan submitpackage()
Validation result for package mempool acceptance.
An input of a transaction.
std::string ToString() const
std::string ToString() const
PackageMempoolAcceptResult ProcessNewPackage(Chainstate &active_chainstate, CTxMemPool &pool, const Package &package, bool test_accept)
Validate (and maybe submit) a package to the mempool.
const CFeeRate m_min_relay_feerate
const std::string CURRENCY_UNIT
TransactionError BroadcastTransaction(NodeContext &node, const CTransactionRef tx, std::string &err_string, const CAmount &max_tx_fee, bool relay, bool wait_callback)
Submit a transaction to the mempool and (optionally) relay it to all P2P peers.
static RPCHelpMan savemempool()
General application defined errors.
uint64_t GetTotalTxSize() const EXCLUSIVE_LOCKS_REQUIRED(cs)
std::string ToString() const
CTxMemPool & EnsureAnyMemPool(const std::any &context)
At least one tx is invalid.
static RPCHelpMan getmempooldescendants()
const CTransaction * GetConflictTx(const COutPoint &prevout) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Get the transaction in the pool that spends the same prevout.
An outpoint - a combination of a transaction hash and an index n into its vout.
std::string HelpExampleCli(const std::string &methodname, const std::string &args)
std::vector< CTxOut > vout
CFeeRate GetMinFee(size_t sizelimit) const
static RPCHelpMan sendrawtransaction()
Special numeric to denote unix epoch time.
#define WITH_LOCK(cs, code)
Run code while locking a mutex.
static RPCHelpMan gettxspendingprevout()
const CFeeRate m_incremental_relay_feerate
static RPCHelpMan getmempoolentry()
constexpr int64_t count_seconds(std::chrono::seconds t)
bool GetLoadTried() const
static CTransactionRef MakeTransactionRef(Tx &&txIn)
std::optional< txiter > GetIter(const uint256 &txid) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Returns an iterator to the given hash, if found.
std::string FormatMoney(const CAmount n)
Money parsing/formatting utilities.
PackageValidationState m_state
Optional argument for which the default value is omitted from help text for one of two reasons: ...
const CTxMemPoolEntry * GetEntry(const Txid &txid) const LIFETIMEBOUND EXCLUSIVE_LOCKS_REQUIRED(cs)
#define EXCLUSIVE_LOCKS_REQUIRED(...)
std::string utf8string() const
Return a UTF-8 representation of the path as a std::string, for compatibility with code using std::st...
CTxMemPool stores valid-according-to-the-current-best-chain transactions that may be included in the ...
Special string to represent a floating point amount.
std::set< uint256 > GetUnbroadcastTxs() const
Returns transactions in unbroadcast set.
void pushKV(std::string key, UniValue val)
static transaction_identifier FromUint256(const uint256 &id)
uint256 ParseHashV(const UniValue &v, std::string_view name)
Utilities: convert hex-encoded Values (throws error if not hex).
const CTransaction & GetTx() const
fs::path MempoolPath(const ArgsManager &argsman)
ChainstateManager & EnsureChainman(const NodeContext &node)
CAmount GetTotalFee() const EXCLUSIVE_LOCKS_REQUIRED(cs)
const UniValue & get_obj() const
bool IsInitialBlockDownload() const
Check whether we are doing an initial block download (synchronizing from disk or network) ...
Special type representing a floating point amount (can be either NUM or STR)
bool DecodeHexTx(CMutableTransaction &tx, const std::string &hex_tx, bool try_no_witness=false, bool try_witness=true)
UniValue ValueFromAmount(const CAmount amount)
static RPCHelpMan testmempoolaccept()
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
ArgsManager & EnsureAnyArgsman(const std::any &context)
#define AssertLockNotHeld(cs)
A mutable version of CTransaction.
static constexpr MemPoolLimits NoLimits()
static constexpr uint32_t MAX_PACKAGE_COUNT
Default maximum number of transactions in a package.
The basic transaction that is broadcasted on the network and contained in blocks. ...
UniValue JSONRPCTransactionError(TransactionError terr, const std::string &err_string)
Special dictionary with keys that are not literals.
std::string GetRejectReason() const
Still downloading initial blocks.
static path u8path(const std::string &utf8_str)
static const CFeeRate DEFAULT_MAX_RAW_TX_FEE_RATE
Maximum fee rate for sendrawtransaction and testmempoolaccept RPC calls.
Initial value. The package has not yet been rejected.
Path class wrapper to block calls to the fs::path(std::string) implicit constructor and the fs::path:...
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate...
CAmount GetFeePerK() const
Return the fee in satoshis for a vsize of 1000 vbytes.
Wrapper for UniValue::VType, which includes typeAny: Used to denote don't care type.
SnapshotCompletionResult MaybeCompleteSnapshotValidation() EXCLUSIVE_LOCKS_REQUIRED(const CBlockIndex *GetSnapshotBaseBlock() const EXCLUSIVE_LOCKS_REQUIRED(Chainstate ActiveChainstate)() const
Once the background validation chainstate has reached the height which is the base of the UTXO snapsh...
static GenTxid Txid(const uint256 &hash)
std::vector< CTxMemPoolEntryRef > entryAll() const EXCLUSIVE_LOCKS_REQUIRED(cs)
NodeContext & EnsureAnyNodeContext(const std::any &context)
RecursiveMutex cs
This mutex needs to be locked when accessing mapTx or other members that are guarded by it...
Error parsing or validating structure in raw format.
const Txid & GetHash() const LIFETIMEBOUND
static std::vector< RPCResult > MempoolEntryDescription()
MempoolAcceptResult ProcessTransaction(const CTransactionRef &tx, bool test_accept=false) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Try to add a transaction to the memory pool.