-
Notifications
You must be signed in to change notification settings - Fork 912
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fetch block from a peer if we don't have it #7240
Fetch block from a peer if we don't have it #7240
Conversation
This allows us to intercept getblock on a non 0 exit when the block was not found. We fill this with something meaningull in future commits. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
We move the `geblock` call into a separate function. This allows us to call if from various places in the future. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
We introduce the peers array that contains the known set of connected peers for future reference in case that we couldn't find the block we are looking for. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
In the case that we have peers left in the peers array and that we could not find the block yet, we ask the next peer for the desired block. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
`getblockfrompeer` was introduced in v23.0.0, we want to skip this path if the version of bitcoind used is below that. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
Changelog-Changed: Plugins: bcli: Add a path that tries to fetch blocks from a peer if we can not find them locally. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGMT, we should add also some information regarding the bitcoin core version supported.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Minor comments only, looks good!
I would also really like some tests! This can be done using our inbuilt mocks for bitcoind; you can give a made-up blockhash, let it fail (since there are no peers), but also can fake up some peers and check it does indeed iterate through them. |
@rustyrussell I am a bit confused about the tests. There are already a few tests using a mocked bitcoind that test the peer iteration in |
Using `getblockfrompeer` requires a version equal or above 23.0.0 Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
It is simpler to just iterate through the peerlist backwards. Signed-off-by: Peter Neuroth <pet.v.ne@gmail.com>
Hmm, how did I miss that commit? Sorry, these look good! |
This PR adds a path in the
bcli
plugin that utilizesgetblockfrompeer
to try to fetch a block from a peer in case that we don't know about the block. This is something that happens when core lightning tries to fetch a block from bitcoind that has already been pruned by bitcoind.getblockfrompeer
has been introduced inv23.0.0
. The call asks a given peer for a block that the local node does not know about. Even thoughgetblockfrompeer
does not make any guarantees about whether the block will be fetched (or pruned again right away), the success probabilities are really high if we just try long enough.Here is a brief description about what happens now if core lightning asks for a block
a) get blockhash for height x
b) try to get block from bitcoind:
resolves #7201