mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-11 20:32:35 -03:00
Merge bitcoin/bitcoin#24226: rpc: warn that nodes ignore requests for old stale blocks
f39d9269eb
rpc: warn that nodes ignore requests for old stale blocks (Sjors Provoost) Pull request description: Adds warning to RPC help that `getblockfrompeer` is of little use for stale blocks that are more than a month old. This is an anti-fingerprinting measure. See `BlockRequestAllowed` in `net_processing`. It's been in Bitcoin Core since 2014, introduced in #2910 and later improved to not rely on checkpoints. Older and alternative clients might still serve these blocks, so not throwing an error. Allowing whitelisted nodes to fetch these blocks anyway might be nice. ACKs for top commit: fjahr: Code review ACKf39d9269eb
Tree-SHA512: db88f9f7521289640c5e629c840dda1c2c3ab70d458e9e7136c60fbaeb02acfb36dc093502d83d4c098c331e22aab81bf8f4c4961d805e3bde0f8f3cfe68d968
This commit is contained in:
commit
5b3f05b7eb
2 changed files with 5 additions and 1 deletions
|
@ -1743,6 +1743,8 @@ std::optional<std::string> PeerManagerImpl::FetchBlock(NodeId peer_id, const CBl
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
// Mark block as in-flight unless it already is (for this peer).
|
// Mark block as in-flight unless it already is (for this peer).
|
||||||
|
// If the peer does not send us a block, vBlocksInFlight remains non-empty,
|
||||||
|
// causing us to timeout and disconnect.
|
||||||
// If a block was already in-flight for a different peer, its BLOCKTXN
|
// If a block was already in-flight for a different peer, its BLOCKTXN
|
||||||
// response will be dropped.
|
// response will be dropped.
|
||||||
if (!BlockRequested(peer_id, block_index)) return "Already requested from this peer";
|
if (!BlockRequested(peer_id, block_index)) return "Already requested from this peer";
|
||||||
|
|
|
@ -428,7 +428,9 @@ static RPCHelpMan getblockfrompeer()
|
||||||
"getblockfrompeer",
|
"getblockfrompeer",
|
||||||
"Attempt to fetch block from a given peer.\n\n"
|
"Attempt to fetch block from a given peer.\n\n"
|
||||||
"We must have the header for this block, e.g. using submitheader.\n"
|
"We must have the header for this block, e.g. using submitheader.\n"
|
||||||
"Subsequent calls for the same block and a new peer will cause the response from the previous peer to be ignored.\n\n"
|
"Subsequent calls for the same block and a new peer will cause the response from the previous peer to be ignored.\n"
|
||||||
|
"Peers generally ignore requests for a stale block that they never fully verified, or one that is more than a month old.\n"
|
||||||
|
"When a peer does not respond with a block, we will disconnect.\n\n"
|
||||||
"Returns an empty JSON object if the request was successfully scheduled.",
|
"Returns an empty JSON object if the request was successfully scheduled.",
|
||||||
{
|
{
|
||||||
{"blockhash", RPCArg::Type::STR_HEX, RPCArg::Optional::NO, "The block hash to try to fetch"},
|
{"blockhash", RPCArg::Type::STR_HEX, RPCArg::Optional::NO, "The block hash to try to fetch"},
|
||||||
|
|
Loading…
Reference in a new issue