Skip to content

BcnBitcoinOnly/signet-playground

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Signet Playground

A dockerized, self-contained Bitcoin Signet network to study how it works. It consists of:

Requirements

Recent Docker version with the Compose v2 plugin (i.e. docker compose instead of docker-compose).

Setup

$ docker compose up --wait
$ docker compose rm -f wallet-setup

Testing

Mempool Explorer

Browse the Signet chain at http://localhost:8080

Sparrow

Connect your Sparrow Wallet to the signet Fulcrum:

  1. Tools > Restart in Network > Signet
  2. File > Preferences > Server > Private Electrum > localhost:60601, no SSL, no Tor proxy.
  3. Wait until the blockchain has at least 100 blocks, then get some sats from the faucet at http://localhost:8123

bitcoin-cli

Interact directly with the node via the command line by running the bitcoin-cli of the knots container:

$ docker compose exec knots bitcoin-cli -getinfo
Chain: signet
Blocks: 101
Headers: 101
Verification progress: 100.0000%
Difficulty: 0.001126515290698186

Network: in 1, out 0, total 1
Version: 260100
Time offset (s): 0
Proxies: n/a
Min tx relay fee rate (BTC/kvB): 0.00001000

Wallet: BBO
Keypool size: 1000
Transaction fee rate (-paytxfee) (BTC/kvB): 0.00000000

Balance: 50.00000000

Warnings: (none)

Clean Up

Stop and remove all containers and data volumes with the usual Docker Compose command:

$ docker compose down -v

Wallet Organization

The wallet-setup step has been carefully designed to create a wallet with these characteristics:

  • It derives Taproot addresses.
  • The miner has a fresh address for each coinbase reward.
  • The wallet itself can still be used as a regular wallet from the command line.

By default, the createwallet command populates the wallet with 2 descriptors of each single-signature type (P2PKH, Nested SegWit, P2WPKH and P2TR). However, we pass the blank=true modifier to create an empty wallet with no descriptors in order to control how we set it up.

We then import 3 different Taproot descriptors based on the same master private key. The first two are the usual pair of descriptors for receiving and change addresses. The third one is non-standard, and is only meant to be used by the miner process. That's why it's marked as internal and inactive.

Descriptor use case Derivation path Internal Active
Receiving addresses 86h/1h/0h/0/* false true
Change addresses 86h/1h/0h/1/* true true
Mining rewards 86h/1h/0h/2/* true false

The mining script will send each reward to addresses from the third descriptor corresponding to the block height, so the reward for block 123 will go to address 86h/1h/0h/2/123 and so on. Bitcoin Knots is capable of spending UTXOs belonging to any of the three descriptors, but when sending bitcoin to itself it will generally do it an address of the first descriptor. Similarly, it will use addresses from the second descriptor as change addresses.

The tpub descriptor for the miner can be obtained with bitcoin-cli listdescriptors after having imported the 86h/1h/0h/2/* tprv. The fingerprint and derivation path hints inside square brackets at the start of the descriptor are not necessary.

If we didn't have a third descriptor for the mining rewards, addresses retrieved manually with bitcoin-cli getnewaddress would eventually be reused by the mining script.

The master private key must be known in advance because the signetchallenge parameter of Bitcoin Knots has to be hardcoded. The value we chose for the challenge is the Taproot scriptPubKey corresponding to the address 86h/1h/0h/2/0, as the block 0 has a special coinbase that cannot be spent.

References

Guides

Docker images

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published