Bitcoin Developers Basics 02: Crypto + Digital Signatures, Dive deep into the cryptography and digital signatures that keep Bitcoin secure.
Course Description
So you’ve heard about bitcoin? Ever wondered what’s going on with the data in a transaction, or how bitcoin gets locked up and transferred from one holder to another?
This course by Base58 instructor niftynei, will take you on a deep dive of the fields, bytes, and scripts that make up the bitcoin blockchain data. In an software engineer focused manner, we’ll go over everything you need to know to build your own bitcoin transaction parser, write your very own custom bitcoin locking scripts, and adapt your transactions to the modern SegWit format.
Step 1: Let’s learn about Elliptic Curve Cryptogaphy
First we figure out what the building blocks for making digital signatures on blockchains are: elliptic curves! We’ll do a very basic walk through of how these work and work through where Bitcoin’s secp256k1 curve comes from. Finally we’ll pick some private keys and learn how to find the public key version of it.
Topics: elliptic curves over finite fields, secp256k1, public and private keys
Step 2: P2PK, P2PKH:Â Locking Bitcoin up to Public Keys
Now that we’ve got some private and public keys, we’re ready to learn about standard Bitcoin scripts with signatures. We’ll write some P2PK, P2PKH, and P2WPKH scripts and lock bitcoin up to them (so we can unlock it later).
Topics: compressed keys, P2PK, P2PKH, P2WPKH
Step 3:Â Digital Signatures
Now that we’ve got Bitcoin locked up to some public keys, we need to learn how to make signatures to unlock it. We’ll walk through how ECDSA works.
Topics: digital siganatures, ECDSA
Step 4: Sighashes
Now that we’ve got ECDSA under our belt, we’re ready to make signatures to spend the bitcoin we locked to our public keys. Here we use sighashes to build the message to sign with ECDSA. Sighashes are how we commit to data in a transaction, to prevent anyone else from tampering with the data on its way into a block.
Topics:Â sighashes, SegWit, legacy, SIGHASH_ALL, SIGHASH_NONE, SIGHASH_SINGLE
Step 5: Multisig
Finally, we’ll take a look at how you can lock bitcoin up to threshold signatures using OP_CHECKMULTISIG.
Topics:Â multisigs, OP_CHECKMULTISIG, Script