Skip to content

Latest commit

 

History

History
137 lines (92 loc) · 5.13 KB

README.md

File metadata and controls

137 lines (92 loc) · 5.13 KB

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

Start Knots, Fulcrum, MariaDB, Redis and the Faucet website. Since Knots is booting in custom signet mode Knots and Fulcrum will finish their setup almost immediately, as there is no blockchain to download.

$ docker compose up -d knots fulcrum mariadb redis

Now run a one-time process that will store in Knots' wallet the private key that is used for the signet challenge:

$ docker compose run --rm wallet-setup

With the private key stored in Knots you can now start the miner and mempool processes:

$ docker compose up -d miner mempool-api mempool-web faucet

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