Skip to content
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

Update bdk_bitcoind_rpc module to work with a pruned bitcoind node #1371

Open
notmandatory opened this issue Mar 6, 2024 · 9 comments
Open
Assignees
Labels
module-blockchain summer-of-bitcoin Summer of Bitcoin Project Proposal
Milestone

Comments

@notmandatory
Copy link
Member

notmandatory commented Mar 6, 2024

Summer of Bitcoin Project Proposal

Description

The current bdk_bitcoind_rpc module requires full access to transaction history using a non-pruned node (a node storing the full blockchain, which at the time of writing is over 400GB).

However, even without a wallet's full transaction history it is still possible to compute the wallet balance and be able to spend with only a pruned bitcoind node using the RPC method scantxoutset. This project will update the existing bdk_bitcoind_rpc module to work with a pruned bitcoind node.

Expected Outcomes

  • Updatefull_scan to use the scantxoutset if the bitcoind node is pruned.
  • Create tests to confirm full_scan works with a pruned node.
  • Update rpc examples and test with a pruned bitcoind node.

Resources

Skills Required

Mentor(s)
@notmandatory

Difficulty
Hard

Competency Test

  • Install rust, compile and run all bdk examples and tests.
  • Setup a local Bitcoin Core pruned node daemon in regtest mode.
  • Make a wallet with example_bitcoind_rpc_polling example wallet and receive and send regtest bitcoin.
@notmandatory notmandatory added the summer-of-bitcoin Summer of Bitcoin Project Proposal label Mar 6, 2024
@notmandatory notmandatory self-assigned this Mar 6, 2024
@notmandatory notmandatory added this to BDK Mar 6, 2024
@notmandatory notmandatory moved this to Todo in BDK Mar 6, 2024
@notmandatory notmandatory removed their assignment Mar 18, 2024
@rustaceanrob
Copy link
Contributor

Mind if I work on this? I'm not SOB but I am doing a similar program haha

@c0llinx
Copy link

c0llinx commented Apr 4, 2024

Is this still open? Would like to give it a shot

@LLFourn
Copy link
Contributor

LLFourn commented Apr 5, 2024

Not sure if our architecture actually supports this kind of usage. The problem is how do you figure out when an output has been spent? The only way is that it is no longer returned from the scantxoutset output. But in bdk_chain we tell it outputs are spent by providing a full transaction that spent it. We can't get that here.

It can be used to find your current balance, but can't be used in a way where you persist anything. So the workflow would be to just scantxout then get the outputs, create a transaction from them and spend them. You could .insert_txout them into a temporary Wallet and create transactions from there. I think that's the only way to get value from bdk with this atm.

@star-gazer111
Copy link

Hey @notmandatory the link you shared for rpc commands (https://developer.bitcoin.org/reference/rpc/) is somehow not working.

@star-gazer111
Copy link

Hey @notmandatory the link you shared for rpc commands (https://developer.bitcoin.org/reference/rpc/) is somehow not working.

I think this can be a good alternative resource for the same.

@jaoleal
Copy link

jaoleal commented Apr 8, 2024

@star-gazer111 https://chainquery.com/bitcoin-cli i prefer to use this one, its kinda better.

@notmandatory
Copy link
Member Author

@LLFourn what if we use the RPC syncing as it is now but with a bitcoind node set to "manual" pruning? then we just have to add functionality to call the "pruneblockchain" command after syncing to remove old (maybe older than 1000 deep or so) already ingested blocks.

@LLFourn
Copy link
Contributor

LLFourn commented Apr 9, 2024

@notmandatory yeah cool I didn't know about this setting but that also works. I feel like the usage is a little niche:

  1. You don't want to run an archival node
  2. You can guarantee your wallet will come online often enough to drain the blocks and prune.
  3. You only have one wallet system.

Certainly not an unlikely situation within a small Bitcoin startup. Also can exist in user facing software that actually embeds a pruned node.

@luisschwab
Copy link
Contributor

This looks interesting, I think I will give it a shot

@notmandatory notmandatory moved this from Todo to In Progress in BDK Aug 22, 2024
@notmandatory notmandatory added this to the 1.1.0 milestone Aug 22, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
module-blockchain summer-of-bitcoin Summer of Bitcoin Project Proposal
Projects
Status: In Progress
Development

No branches or pull requests

7 participants