7 #include <chainparams.h> 32 #include <txmempool.h> 58 if (height >= 0 && height < active_chain.
Height()) {
59 pb = active_chain[height];
62 if (pb ==
nullptr || !pb->
nHeight)
75 int64_t maxTime = minTime;
76 for (
int i = 0; i < lookup; i++) {
79 minTime = std::min(time, minTime);
80 maxTime = std::max(time, maxTime);
84 if (minTime == maxTime)
88 int64_t timeDiff = maxTime - minTime;
96 "\nReturns the estimated network hashes per second based on the last n blocks.\n" 97 "Pass in [blocks] to override # of blocks, -1 specifies since last difficulty change.\n" 98 "Pass in [height] to estimate the network speed at the time when a certain block was found.\n",
130 if (block.
nNonce == std::numeric_limits<uint32_t>::max()) {
134 block_out = std::make_shared<const CBlock>(block);
136 if (!process_new_block)
return true;
150 if (!pblocktemplate.get())
153 std::shared_ptr<const CBlock> block_out;
154 if (!
GenerateBlock(chainman, pblocktemplate->block, nMaxTries, block_out,
true)) {
160 blockHashes.
push_back(block_out->GetHash().GetHex());
169 const auto desc =
Parse(descriptor, key_provider,
error,
false);
171 if (desc->IsRange()) {
176 std::vector<CScript> scripts;
177 if (!desc->Expand(0, key_provider, scripts, provider)) {
184 if (scripts.size() == 1) {
185 script = scripts.at(0);
186 }
else if (scripts.size() == 4) {
188 script = scripts.at(2);
191 script = scripts.at(1);
203 "generatetodescriptor",
204 "Mine to a specified descriptor and return the block hashes.",
217 "\nGenerate 11 blocks to mydesc\n" +
HelpExampleCli(
"generatetodescriptor",
"11 \"mydesc\"")},
220 const auto num_blocks{
self.Arg<
int>(0)};
221 const auto max_tries{
self.Arg<uint64_t>(2)};
233 return generateBlocks(chainman, mempool, coinbase_script, num_blocks, max_tries);
248 "Mine to a specified address and return the block hashes.",
260 "\nGenerate 11 blocks to myaddress\n" 262 +
"If you are using the " PACKAGE_NAME " wallet, you can get a new address to send the newly generated bitcoin to with:\n" 267 const int num_blocks{request.params[0].
getInt<
int>()};
268 const uint64_t max_tries{request.params[2].isNull() ?
DEFAULT_MAX_TRIES : request.params[2].getInt<
int>()};
281 return generateBlocks(chainman, mempool, coinbase_script, num_blocks, max_tries);
289 "Mine a set of ordered transactions to a specified address or descriptor and return the block hash.",
293 "Txids must reference transactions currently in the mempool.\n" 294 "All transactions must be valid and in valid order, otherwise the block will be rejected.",
309 "\nGenerate a block to myaddress, with txs rawtx and mempool_txid\n" 310 +
HelpExampleCli(
"generateblock", R
"("myaddress" '["rawtx", "mempool_txid"]')") 314 const auto address_or_descriptor = request.params[0].
get_str();
330 std::vector<CTransactionRef> txs;
331 const auto raw_txs_or_txids = request.params[1].get_array();
332 for (
size_t i = 0; i < raw_txs_or_txids.size(); i++) {
333 const auto str(raw_txs_or_txids[i].get_str());
339 const auto tx = mempool.
get(hash);
344 txs.emplace_back(tx);
354 const bool process_new_block{request.params[2].isNull() ? true : request.params[2].get_bool()};
362 if (!blocktemplate) {
365 block = blocktemplate->block;
371 block.
vtx.insert(block.
vtx.end(), txs.begin(), txs.end());
383 std::shared_ptr<const CBlock> block_out;
386 if (!
GenerateBlock(chainman, block, max_tries, block_out, process_new_block) || !block_out) {
391 obj.
pushKV(
"hash", block_out->GetHash().GetHex());
392 if (!process_new_block) {
394 block_ser << *block_out;
405 "\nReturns a json object containing mining-related information.",
411 {
RPCResult::Type::NUM,
"currentblockweight",
true,
"The block weight of the last assembled block (only present if a block was ever assembled)"},
412 {
RPCResult::Type::NUM,
"currentblocktx",
true,
"The number of block transactions of the last assembled block (only present if a block was ever assembled)"},
433 if (BlockAssembler::m_last_block_weight) obj.
pushKV(
"currentblockweight", *BlockAssembler::m_last_block_weight);
434 if (BlockAssembler::m_last_block_num_txs) obj.
pushKV(
"currentblocktx", *BlockAssembler::m_last_block_num_txs);
437 obj.
pushKV(
"pooledtx", (uint64_t)mempool.
size());
450 "Accepts the transaction into mined blocks at a higher (or lower) priority\n",
454 " DEPRECATED. For forward compatibility use named arguments and omit this parameter."},
456 " Note, that this value is not a fee rate. It is a value to modify absolute fee of the TX.\n" 457 " The fee is not actually paid, only the algorithm for selecting transactions into a block\n" 458 " considers the transaction as it would have paid a higher (or lower) fee."},
471 const auto dummy{
self.MaybeArg<
double>(1)};
472 CAmount nAmount = request.params[2].getInt<int64_t>();
474 if (dummy && *dummy != 0) {
486 return RPCHelpMan{
"getprioritisedtransactions",
487 "Returns a map of all user-created (see prioritisetransaction) fee deltas by txid, and whether the tx is present in mempool.",
509 result_inner.pushKV(
"fee_delta", delta_info.delta);
510 result_inner.pushKV(
"in_mempool", delta_info.in_mempool);
511 rpc_result.pushKV(delta_info.txid.GetHex(), result_inner);
530 if (strRejectReason.empty())
532 return strRejectReason;
540 std::string s = vbinfo.
name;
542 s.insert(s.begin(),
'!');
550 "\nIf the request parameters include a 'mode' key, that is used to explicitly select between the default 'template' request or a 'proposal'.\n" 551 "It returns data needed to construct a block to work on.\n" 552 "For full specification, see BIPs 22, 23, 9, and 145:\n" 553 " https://github.com/bitcoin/bips/blob/master/bip-0022.mediawiki\n" 554 " https://github.com/bitcoin/bips/blob/master/bip-0023.mediawiki\n" 555 " https://github.com/bitcoin/bips/blob/master/bip-0009.mediawiki#getblocktemplate_changes\n" 556 " https://github.com/bitcoin/bips/blob/master/bip-0145.mediawiki\n",
583 {
RPCResult::Type::STR,
"",
"name of a rule the client must understand to some extent; see BIP 9 for format"},
587 {
RPCResult::Type::NUM,
"rulename",
"identifies the bit number as indicating acceptance and readiness for the named softfork rule"},
593 {
RPCResult::Type::NUM,
"vbrequired",
"bit mask of versionbits the server requires set in submissions"},
595 {
RPCResult::Type::ARR,
"transactions",
"contents of non-coinbase transactions that should be included in the next block",
604 {
RPCResult::Type::NUM,
"",
"transactions before this one (by 1-based index in 'transactions' list) that must be present in the final block if this one is"},
606 {
RPCResult::Type::NUM,
"fee",
"difference in value between transaction inputs and outputs (in satoshis); for coinbase transactions, this is a negative Number of the total collected block fees (ie, not including the block subsidy); if key is not present, fee is unknown and clients MUST NOT assume there isn't one"},
607 {
RPCResult::Type::NUM,
"sigops",
"total SigOps cost, as counted for purposes of block limits; if key is not present, sigop cost is unknown and clients MUST NOT assume it is zero"},
608 {
RPCResult::Type::NUM,
"weight",
"total transaction weight, as counted for purposes of block limits"},
615 {
RPCResult::Type::NUM,
"coinbasevalue",
"maximum allowable input to coinbase transaction, including the generation award and transaction fees (in satoshis)"},
616 {
RPCResult::Type::STR,
"longpollid",
"an id to include with a request to longpoll on an update to this template"},
621 {
RPCResult::Type::STR,
"value",
"A way the block template may be changed, e.g. 'time', 'transactions', 'prevblock'"},
631 {
RPCResult::Type::STR_HEX,
"default_witness_commitment",
true,
"a valid witness commitment for the unmodified block template"},
644 std::string strMode =
"template";
646 std::set<std::string> setClientRules;
649 if (!request.params[0].isNull())
655 else if (modeval.
isNull())
663 if (strMode ==
"proposal")
666 if (!dataval.
isStr())
679 return "duplicate-invalid";
680 return "duplicate-inconclusive";
686 return "inconclusive-not-best-prevblk";
694 for (
unsigned int i = 0; i < aClientRules.
size(); ++i) {
695 const UniValue& v = aClientRules[i];
696 setClientRules.insert(v.
get_str());
701 if (strMode !=
"template")
715 static unsigned int nTransactionsUpdatedLast;
722 std::chrono::steady_clock::time_point checktxtime;
723 unsigned int nTransactionsUpdatedLastLP;
728 const std::string& lpstr = lpval.
get_str();
730 hashWatchedChain =
ParseHashV(lpstr.substr(0, 64),
"longpollid");
731 nTransactionsUpdatedLastLP = LocaleIndependentAtoi<int64_t>(lpstr.substr(64));
737 nTransactionsUpdatedLastLP = nTransactionsUpdatedLast;
743 checktxtime = std::chrono::steady_clock::now() + std::chrono::minutes(1);
748 if (
g_best_block_cv.wait_until(lock, checktxtime) == std::cv_status::timeout)
754 checktxtime += std::chrono::seconds(10);
768 if (consensusParams.
signet_blocks && setClientRules.count(
"signet") != 1) {
773 if (setClientRules.count(
"segwit") != 1) {
779 static int64_t time_start;
780 static std::unique_ptr<CBlockTemplate> pblocktemplate;
781 if (pindexPrev != active_chain.
Tip() ||
785 pindexPrev =
nullptr;
794 pblocktemplate =
BlockAssembler{active_chainstate, &mempool}.CreateNewBlock(scriptDummy);
799 pindexPrev = pindexPrevNew;
802 CBlock* pblock = &pblocktemplate->block;
805 UpdateTime(pblock, consensusParams, pindexPrev);
814 std::map<uint256, int64_t> setTxIndex;
816 for (
const auto& it : pblock->
vtx) {
819 setTxIndex[txHash] = i++;
836 entry.
pushKV(
"depends", deps);
838 int index_in_template = i - 1;
839 entry.
pushKV(
"fee", pblocktemplate->vTxFees[index_in_template]);
840 int64_t nTxSigOps = pblocktemplate->vTxSigOpsCost[index_in_template];
845 entry.
pushKV(
"sigops", nTxSigOps);
861 result.
pushKV(
"capabilities", aCaps);
865 if (!fPreSegWit) aRules.
push_back(
"!segwit");
889 if (setClientRules.find(vbinfo.
name) == setClientRules.end()) {
902 if (setClientRules.find(vbinfo.
name) == setClientRules.end()) {
913 result.
pushKV(
"rules", aRules);
914 result.
pushKV(
"vbavailable", vbavailable);
915 result.
pushKV(
"vbrequired",
int(0));
918 result.
pushKV(
"transactions", transactions);
919 result.
pushKV(
"coinbaseaux", aux);
920 result.
pushKV(
"coinbasevalue", (int64_t)pblock->
vtx[0]->vout[0].nValue);
924 result.
pushKV(
"mutable", aMutable);
925 result.
pushKV(
"noncerange",
"00000000ffffffff");
934 result.
pushKV(
"sigoplimit", nSigOpLimit);
935 result.
pushKV(
"sizelimit", nSizeLimit);
947 if (!pblocktemplate->vchCoinbaseCommitment.empty()) {
948 result.
pushKV(
"default_witness_commitment",
HexStr(pblocktemplate->vchCoinbaseCommitment));
978 "\nAttempts to submit new block to network.\n" 979 "See https://en.bitcoin.it/wiki/BIP_0022 for full specification.\n",
994 std::shared_ptr<CBlock> blockptr = std::make_shared<CBlock>();
995 CBlock& block = *blockptr;
996 if (!
DecodeHexBlk(block, request.params[0].get_str())) {
1000 if (block.vtx.empty() || !block.vtx[0]->IsCoinBase()) {
1005 uint256 hash = block.GetHash();
1014 return "duplicate-invalid";
1023 chainman.UpdateUncommittedBlockStructures(block, pindex);
1028 auto sc = std::make_shared<submitblock_StateCatcher>(block.GetHash());
1030 bool accepted = chainman.
ProcessNewBlock(blockptr,
true,
true, &new_block);
1032 if (!new_block && accepted) {
1036 return "inconclusive";
1046 "\nDecode the given hexdata as a header and submit it as a candidate chain tip if valid." 1047 "\nThrows when the header is invalid.\n",
1098 for (
const auto& c : commands) {
1099 t.appendCommand(c.name, &c);
arith_uint256 nChainWork
(memory only) Total amount of work (expected number of hashes) in the chain up to and including this ...
node::BlockManager m_blockman
A single BlockManager instance is shared across each constructed chainstate to avoid duplicating bloc...
static UniValue Parse(std::string_view raw)
Parse string to UniValue or throw runtime_error if string contains invalid JSON.
void push_back(UniValue val)
bool ShutdownRequested()
Returns true if a shutdown is requested, false otherwise.
static RPCHelpMan getnetworkhashps()
bool DecodeHexBlk(CBlock &, const std::string &strHexBlk)
std::condition_variable g_best_block_cv
Ran out of memory during operation.
static const int WITNESS_SCALE_FACTOR
int64_t GetBlockTime() const
Generate a new block, without valid proof-of-work.
CBlockIndex * pprev
pointer to the index of the predecessor of this block
bool IsValidDestination(const CTxDestination &dest)
Check whether a CTxDestination corresponds to one with an address.
bool IsRPCRunning()
Query whether RPC is running.
BlockValidationState state
std::string GetChainTypeString() const
Return the chain type string.
CTxMemPool & EnsureMemPool(const NodeContext &node)
bool gbt_force
Whether GBT clients can safely ignore this rule in simplified usage.
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate gen...
An in-memory indexed chain of blocks.
static UniValue BIP22ValidationResult(const BlockValidationState &state)
static RPCHelpMan getblocktemplate()
CChain & ActiveChain() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
#define CHECK_NONFATAL(condition)
Identity function.
int Height() const
Return the maximal height in the chain.
bool DeploymentActiveAfter(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, Consensus::BuriedDeployment dep, [[maybe_unused]] VersionBitsCache &versionbitscache)
Determine if a deployment is active for the next block.
void BlockChecked(const CBlock &block, const BlockValidationState &stateIn) override
Notifies listeners of a block validation result.
unsigned long size() const
static bool getScriptFromDescriptor(const std::string &descriptor, CScript &script, std::string &error)
static RPCHelpMan submitheader()
const std::string & get_str() const
double GetDifficulty(const CBlockIndex *blockindex)
Get the difficulty of the net wrt to the given block index.
ThresholdState
BIP 9 defines a finite-state-machine to deploy a softfork in multiple stages.
void RegisterSharedValidationInterface(std::shared_ptr< CValidationInterface > callbacks)
Register subscriber.
bool DecodeHexBlockHeader(CBlockHeader &, const std::string &hex_header)
CChain m_chain
The current chain of blockheaders we consult and build on.
submitblock_StateCatcher(const uint256 &hashIn)
static const int64_t MAX_BLOCK_SIGOPS_COST
The maximum allowed number of signature check operations in a block (network rule) ...
static int32_t GetTransactionWeight(const CTransaction &tx)
int64_t UpdateTime(CBlockHeader *pblock, const Consensus::Params &consensusParams, const CBlockIndex *pindexPrev)
void UnregisterSharedValidationInterface(std::shared_ptr< CValidationInterface > callbacks)
Unregister subscriber.
Implement this to subscribe to events generated in validation.
static uint32_t Mask(const Consensus::Params ¶ms, Consensus::DeploymentPos pos)
const std::vector< CTxIn > vin
Invalid, missing or duplicate parameter.
uint256 g_best_block
Used to notify getblocktemplate RPC of new tips.
NodeClock::time_point GetAdjustedTime()
VersionBitsCache m_versionbitscache
Track versionbit status.
static const unsigned int MAX_BLOCK_WEIGHT
The maximum allowed weight for a block, see BIP 141 (network rule)
bool ProcessNewBlock(const std::shared_ptr< const CBlock > &block, bool force_processing, bool min_pow_checked, bool *new_block) LOCKS_EXCLUDED(cs_main)
Process an incoming block.
ThresholdState State(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, Consensus::DeploymentPos pos) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
Get the BIP9 state for a given deployment for the block after pindexPrev.
int64_t CAmount
Amount in satoshis (Can be negative)
const UniValue & find_value(std::string_view key) const
uint256 GetBlockHash() const
static std::string gbt_vb_name(const Consensus::DeploymentPos pos)
void RegisterMiningRPCCommands(CRPCTable &t)
General error during transaction or block submission.
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)
static RPCHelpMan generatetodescriptor()
Special string with only hex chars.
Chainstate stores and provides an API to update our local knowledge of the current best chain...
std::string HexStr(const Span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Scripts & signatures ok. Implies all parents are either at least VALID_SCRIPTS, or are ASSUMED_VALID...
#define LEAVE_CRITICAL_SECTION(cs)
static const uint64_t DEFAULT_MAX_TRIES
Default max iterations to try in RPC generatetodescriptor, generatetoaddress, and generateblock...
An input of a transaction.
const uint256 & GetWitnessHash() const
const uint256 & GetHash() const
std::string ToString() const
const struct VBDeploymentInfo VersionBitsDeploymentInfo[Consensus::MAX_VERSION_BITS_DEPLOYMENTS]
Unexpected type was passed as parameter.
bool signet_blocks
If true, witness commitments contain a payload equal to a Bitcoin Script solution to the signet chall...
const Consensus::Params & GetConsensus() const
std::vector< delta_info > GetPrioritisedTransactions() const EXCLUSIVE_LOCKS_REQUIRED(!cs)
Return a vector of all entries in mapDeltas with their corresponding delta_info.
General application defined errors.
std::string DefaultHint
Hint for default value.
uint256 BlockMerkleRoot(const CBlock &block, bool *mutated)
#define WAIT_LOCK(cs, name)
static RPCHelpMan submitblock()
CTxMemPool & EnsureAnyMemPool(const std::any &context)
Parameters that influence chain consensus.
bool CheckProofOfWork(uint256 hash, unsigned int nBits, const Consensus::Params ¶ms)
Check whether a block hash satisfies the proof-of-work requirement specified by nBits.
CBlockIndex * LookupBlockIndex(const uint256 &hash) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
std::string HelpExampleCli(const std::string &methodname, const std::string &args)
static RPCHelpMan prioritisetransaction()
Special numeric to denote unix epoch time.
256-bit unsigned big integer.
int64_t GetMedianTimePast() const
static RPCHelpMan generateblock()
CScript GetScriptForDestination(const CTxDestination &dest)
Generate a Bitcoin scriptPubKey for the given CTxDestination.
static CTransactionRef MakeTransactionRef(Tx &&txIn)
int64_t DifficultyAdjustmentInterval() const
uint256 ParseHashV(const UniValue &v, std::string strName)
Utilities: convert hex-encoded Values (throws error if not hex).
static UniValue generateBlocks(ChainstateManager &chainman, const CTxMemPool &mempool, const CScript &coinbase_script, int nGenerate, uint64_t nMaxTries)
std::variant< CNoDestination, PubKeyDestination, PKHash, ScriptHash, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessV1Taproot, WitnessUnknown > CTxDestination
A txout script categorized into standard templates.
#define ENTER_CRITICAL_SECTION(cs)
bool IsValid(enum BlockStatus nUpTo=BLOCK_VALID_TRANSACTIONS) const EXCLUSIVE_LOCKS_REQUIRED(
Check whether this block index entry is valid up to the passed validity level.
const CChainParams & GetParams() const
Optional argument for which the default value is omitted from help text for one of two reasons: ...
size_t GetNodeCount(ConnectionDirection) const
std::vector< CTransactionRef > vtx
bilingual_str GetWarnings(bool verbose)
Format a string that describes several potential problems detected by the core.
bool IsTestChain() const
If this chain is exclusively used for testing.
CTxMemPool stores valid-according-to-the-current-best-chain transactions that may be included in the ...
const char * name
Deployment name.
bool error(const char *fmt, const Args &... args)
The block chain is a tree shaped structure starting with the genesis block at the root...
const CChainParams & Params()
Return the currently selected parameters.
void pushKV(std::string key, UniValue val)
Serialized script, used inside transaction inputs and outputs.
int RPCSerializationFlags()
static UniValue GetNetworkHashPS(int lookup, int height, const CChain &active_chain)
Return average network hashes per second based on the last 'lookup' blocks, or from the last difficul...
ChainstateManager & EnsureChainman(const NodeContext &node)
static const int PROTOCOL_VERSION
network protocol versioning
const UniValue & get_obj() const
bool IsInitialBlockDownload() const
Check whether we are doing an initial block download (synchronizing from disk or network) ...
std::vector< uint8_t > signet_challenge
static RPCHelpMan generatetoaddress()
CBlockIndex * Tip() const
Returns the index entry for the tip of this chain, or nullptr if none.
bool DecodeHexTx(CMutableTransaction &tx, const std::string &hex_tx, bool try_no_witness=false, bool try_witness=true)
std::string GetHex() const
static RPCHelpMan getprioritisedtransactions()
static RPCHelpMan generate()
std::string EncodeHexTx(const CTransaction &tx, const int serializeFlags=0)
const UniValue NullUniValue
static RPCHelpMan getmininginfo()
unsigned int GetTransactionsUpdated() const
arith_uint256 & SetCompact(uint32_t nCompact, bool *pfNegative=nullptr, bool *pfOverflow=nullptr)
The "compact" format is a representation of a whole number N using an unsigned 32bit number similar t...
A mutable version of CTransaction.
CTransactionRef get(const uint256 &hash) const
static const unsigned int MAX_BLOCK_SERIALIZED_SIZE
The maximum allowed size for a serialized block, in bytes (only for buffer size limits) ...
std::string GetHex() const
bool ParseHashStr(const std::string &strHex, uint256 &result)
Parse a hex string into 256 bits.
The basic transaction that is broadcasted on the network and contained in blocks. ...
int nHeight
height of the entry in the chain. The genesis block has height 0
bool TestBlockValidity(BlockValidationState &state, const CChainParams &chainparams, Chainstate &chainstate, const CBlock &block, CBlockIndex *pindexPrev, const std::function< NodeClock::time_point()> &adjusted_time_callback, bool fCheckPOW, bool fCheckMerkleRoot)
Check a block is completely valid from start to finish (only works on top of our current best block) ...
const Consensus::Params & GetConsensus() const
int bit
Bit position to select the particular bit in nVersion.
Special dictionary with keys that are not literals.
std::string GetRejectReason() const
Still downloading initial blocks.
CTxDestination DecodeDestination(const std::string &str, std::string &error_msg, std::vector< int > *error_locations)
ChainstateManager & EnsureAnyChainman(const std::any &context)
int64_t GetTime()
DEPRECATED, see GetTime.
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate...
void RegenerateCommitments(CBlock &block, ChainstateManager &chainman)
Update an old GenerateCoinbaseCommitment from CreateNewBlock after the block txs have changed...
void PrioritiseTransaction(const uint256 &hash, const CAmount &nFeeDelta)
Affect CreateNewBlock prioritisation of transactions.
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...
NodeContext & EnsureAnyNodeContext(const std::any &context)
BIP9Deployment vDeployments[MAX_VERSION_BITS_DEPLOYMENTS]
Error parsing or validating structure in raw format.
CConnman & EnsureConnman(const NodeContext &node)
const std::string UNIX_EPOCH_TIME
String used to describe UNIX epoch time in documentation, factored out to a constant for consistency...
GlobalMutex g_best_block_mutex
bool ProcessNewBlockHeaders(const std::vector< CBlockHeader > &block, bool min_pow_checked, BlockValidationState &state, const CBlockIndex **ppindex=nullptr) LOCKS_EXCLUDED(cs_main)
Process incoming block headers.
static bool GenerateBlock(ChainstateManager &chainman, CBlock &block, uint64_t &max_tries, std::shared_ptr< const CBlock > &block_out, bool process_new_block)