Documentation ¶
Overview ¶
Package chaincfg defines chain configuration parameters.
In addition to the main Bitcoin network, which is intended for the transfer of monetary value, there also exists two currently active standard networks: regression test and testnet (version 3). These networks are incompatible with each other (each sharing a different genesis block) and software should handle errors where input intended for one network is used on an application instance running on a different network.
For library packages, chaincfg provides the ability to lookup chain parameters and encoding magics when passed a *Params. Older APIs not updated to the new convention of passing a *Params may lookup the parameters for a wire.BitcoinNet using ParamsForNet, but be aware that this usage is deprecated and will be removed from chaincfg in the future.
For main packages, a (typically global) var may be assigned the address of one of the standard Param vars for use as the application's "active" network. When a network parameter is needed, it may then be looked up through this variable (either directly, or hidden in a library call).
package main import ( "flag" "fmt" "log" "github.com/HorizenOfficial/rosetta-zen/btcutil" "github.com/HorizenOfficial/rosetta-zen/btcd/chaincfg" ) var testnet = flag.Bool("testnet", false, "operate on the testnet Bitcoin network") // By default (without -testnet), use mainnet. var chainParams = &chaincfg.MainNetParams func main() { flag.Parse() // Modify active network parameters if operating on testnet. if *testnet { chainParams = &chaincfg.TestNet3Params } // later... // Create and print new payment address, specific to the active network. pubKeyHash := make([]byte, 20) addr, err := btcutil.NewAddressPubKeyHash(pubKeyHash, chainParams) if err != nil { log.Fatal(err) } fmt.Println(addr) }
If an application does not use one of the three standard Bitcoin networks, a new Params struct may be created which defines the parameters for the non-standard network. As a general rule of thumb, all network parameters should be unique to the network, but parameter collisions can still occur (unfortunately, this is the case with regtest and testnet3 sharing magics).
Index ¶
- Constants
- Variables
- func HDPrivateKeyToPublicKeyID(id []byte) ([]byte, error)
- func IsBech32SegwitPrefix(prefix string) bool
- func IsPubKeyHashAddrID(id uint16) bool
- func IsScriptHashAddrID(id uint16) bool
- func Register(params *Params) error
- func RegisterHDKeyID(hdPublicKeyID []byte, hdPrivateKeyID []byte) error
- type Checkpoint
- type ConsensusDeployment
- type DNSSeed
- type Params
Constants ¶
const ( // DeploymentTestDummy defines the rule change deployment ID for testing // purposes. DeploymentTestDummy = iota // DeploymentCSV defines the rule change deployment ID for the CSV // soft-fork package. The CSV package includes the deployment of BIPS // 68, 112, and 113. DeploymentCSV // DeploymentSegwit defines the rule change deployment ID for the // Segregated Witness (segwit) soft-fork package. The segwit package // includes the deployment of BIPS 141, 142, 144, 145, 147 and 173. DeploymentSegwit // DefinedDeployments is the number of currently defined deployments. DefinedDeployments )
Constants that define the deployment offset in the deployments field of the parameters for each deployment. This is useful to be able to get the details of a specific deployment by name.
Variables ¶
var ( // ErrDuplicateNet describes an error where the parameters for a Bitcoin // network could not be set due to the network already being a standard // network or previously-registered into this package. ErrDuplicateNet = errors.New("duplicate Bitcoin network") // ErrUnknownHDKeyID describes an error where the provided id which // is intended to identify the network for a hierarchical deterministic // private extended key is not registered. ErrUnknownHDKeyID = errors.New("unknown hd private extended key bytes") // ErrInvalidHDKeyID describes an error where the provided hierarchical // deterministic version bytes, or hd key id, is malformed. ErrInvalidHDKeyID = errors.New("invalid hd extended key version bytes") )
var MainNetParams = Params{ Name: "mainnet", Net: wire.MainNet, DefaultPort: "9033", DNSSeeds: []DNSSeed{ {"dnsseed.horizen.global", false}, {"dnsseed.zensystem.io", false}, {"mainnet.horizen.global", false}, {"mainnet.zensytem.io", false}, {"node1.zenchain.info", false}, }, GenesisBlock: &genesisBlock, GenesisHash: &genesisHash, BIP0034Height: 0, BIP0065Height: 0, BIP0066Height: 0, CoinbaseMaturity: 100, Checkpoints: []Checkpoint{ {0, newHashFromStr("0007104ccda289427919efc39dc9e4d499804b7bebc22df55f8b834301260602")}, {30000, newHashFromStr("000000005c2ad200c3c7c8e627f67b306659efca1268c9bb014335fdadc0c392")}, {96577, newHashFromStr("0000000177751545bd1af3ccf276ec2920d258453ab01f3d2f8f7fcc5f3a37b8")}, {110000, newHashFromStr("000000003f5d6ba1385c6cd2d4f836dfc5adf7f98834309ad67e26faef462454")}, {139200, newHashFromStr("00000001ea53c09a45e3f097ba8f48a4c117b5b368031c4eb2fa02cb5a84c99e")}, {294072, newHashFromStr("000000005f9ceecc87d9e5eaab2cf548c787231829ad6f609975fadd10fff5be")}, {429014, newHashFromStr("000000000dc4f58375d9fa6dc4cb1bfc4b0afefbf4f7e1ee2cc755d6ca3b40b0")}, {491000, newHashFromStr("0000000018d0b189de58bcd8ff5048d2e4d1c652b98912ff002c8f07c6f81b8c")}, {543000, newHashFromStr("00000000111469e247ecb152e57c371147775b56173260950075dcb471614fed")}, {596000, newHashFromStr("000000000656846513b2d3faf3a70f59dc22fffcb8e14401ec5a17eec8994410")}, {671000, newHashFromStr("00000000097174dacaf850075917d1a24145fce88a800881ece709bb8f8746cf")}, {724100, newHashFromStr("000000000ab34fd9c61be9f10a11a97f63a0f26c8f530e67a6397fb9934709dc")}, }, RuleChangeActivationThreshold: 1916, MinerConfirmationWindow: 2016, PubKeyHashAddrID: 0x2089, ScriptHashAddrID: 0x2096, PrivateKeyID: 0x80, HDPrivateKeyID: [4]byte{0x04, 0x88, 0xad, 0xe4}, HDPublicKeyID: [4]byte{0x04, 0x88, 0xb2, 0x1e}, }
MainNetParams defines the network parameters for the main Bitcoin network.
var RegressionNetParams = Params{ Name: "test", Net: wire.TestNet, DefaultPort: "19033", DNSSeeds: []DNSSeed{ {"dnsseed.testnet.horizen.global", false}, {"dnsseed.testnet.zensystem.io", false}, {"testnet.horizen.global", false}, {"tesntet.zensytem.io", false}, {"node1.zenchain.info", false}, }, GenesisBlock: &testNetGenesisBlock, GenesisHash: &testnetGenesisHash, CoinbaseMaturity: 100, BIP0034Height: 0, BIP0065Height: 0, BIP0066Height: 0, Checkpoints: []Checkpoint{ {0, newHashFromStr("03e1c4bb705c871bf9bfda3e74b7f8f86bff267993c215a89d5795e3708e5e1f")}, {38000, newHashFromStr("001e9a2d2e2892b88e9998cf7b079b41d59dd085423a921fe8386cecc42287b8")}, {362210, newHashFromStr("00023d5c074a7c2ccf130dac34b2b6f77e3c4466cfed0b72c3f3715157c92949")}, {423000, newHashFromStr("000d04b28067fe99445961f795ee7436f1dbbffc3a045f6890868e605209d170")}, {467550, newHashFromStr("0007f73f339ea99e920e83da38d7537ce7d0028d48e709c88b1b89adf521b4f9")}, {520000, newHashFromStr("00052e65426a0ffbb90893208a6c89a82816abbed328fa2be5a647828609e61a")}, {595000, newHashFromStr("0000da85ddc79fdd297e996d6b6b887fc5b345619b7a6726c496941dcf830966")}, {643000, newHashFromStr("0000cabf39e3ac435d54b95c32e6173d6bb1b060066ecb7453d2146a0dd40947")}, }, RuleChangeActivationThreshold: 1512, MinerConfirmationWindow: 2016, PubKeyHashAddrID: 0x2098, ScriptHashAddrID: 0x2092, PrivateKeyID: 0xef, HDPrivateKeyID: [4]byte{0x04, 0x35, 0x83, 0x94}, HDPublicKeyID: [4]byte{0x04, 0x35, 0x87, 0xcf}, }
RegressionNetParams defines the network parameters for the regression test Bitcoin network. Not to be confused with the test Bitcoin network (version 3), this network is sometimes simply called "testnet".
var RegtestParams = Params{ Name: "regtest", Net: wire.Regtest, DefaultPort: "19133", DNSSeeds: []DNSSeed{}, GenesisBlock: ®TestGenesisBlock, GenesisHash: ®testGenesisHash, BIP0034Height: 0, BIP0065Height: 0, BIP0066Height: 0, CoinbaseMaturity: 100, Checkpoints: []Checkpoint{ {0, newHashFromStr("0da5ee723b7923feb580518541c6f098206330dbc711a6678922c11f2ccf1abb")}, }, RuleChangeActivationThreshold: 108, MinerConfirmationWindow: 144, PubKeyHashAddrID: 0x2098, ScriptHashAddrID: 0x2092, PrivateKeyID: 0xef, HDPrivateKeyID: [4]byte{0x04, 0x35, 0x83, 0x94}, HDPublicKeyID: [4]byte{0x04, 0x35, 0x87, 0xcf}, }
TestNet3Params defines the network parameters for the test Bitcoin network (version 3). Not to be confused with the regression test network, this network is sometimes simply called "testnet".
Functions ¶
func HDPrivateKeyToPublicKeyID ¶
HDPrivateKeyToPublicKeyID accepts a private hierarchical deterministic extended key id and returns the associated public key id. When the provided id is not registered, the ErrUnknownHDKeyID error will be returned.
func IsBech32SegwitPrefix ¶
IsBech32SegwitPrefix returns whether the prefix is a known prefix for segwit addresses on any default or registered network. This is used when decoding an address string into a specific address type.
func IsPubKeyHashAddrID ¶
IsPubKeyHashAddrID returns whether the id is an identifier known to prefix a pay-to-pubkey-hash address on any default or registered network. This is used when decoding an address string into a specific address type. It is up to the caller to check both this and IsScriptHashAddrID and decide whether an address is a pubkey hash address, script hash address, neither, or undeterminable (if both return true).
func IsScriptHashAddrID ¶
IsScriptHashAddrID returns whether the id is an identifier known to prefix a pay-to-script-hash address on any default or registered network. This is used when decoding an address string into a specific address type. It is up to the caller to check both this and IsPubKeyHashAddrID and decide whether an address is a pubkey hash address, script hash address, neither, or undeterminable (if both return true).
func Register ¶
Register registers the network parameters for a Bitcoin network. This may error with ErrDuplicateNet if the network is already registered (either due to a previous Register call, or the network being one of the default networks).
Network parameters should be registered into this package by a main package as early as possible. Then, library packages may lookup networks or network parameters based on inputs and work regardless of the network being standard or not.
func RegisterHDKeyID ¶
RegisterHDKeyID registers a public and private hierarchical deterministic extended key ID pair.
Non-standard HD version bytes, such as the ones documented in SLIP-0132, should be registered using this method for library packages to lookup key IDs (aka HD version bytes). When the provided key IDs are invalid, the ErrInvalidHDKeyID error will be returned.
Reference:
SLIP-0132 : Registered HD version bytes for BIP-0032 https://github.com/satoshilabs/slips/blob/master/slip-0132.md
Types ¶
type Checkpoint ¶
Checkpoint identifies a known good point in the block chain. Using checkpoints allows a few optimizations for old blocks during initial download and also prevents forks from old blocks.
Each checkpoint is selected based upon several factors. See the documentation for blockchain.IsCheckpointCandidate for details on the selection criteria.
type ConsensusDeployment ¶
type ConsensusDeployment struct { // BitNumber defines the specific bit number within the block version // this particular soft-fork deployment refers to. BitNumber uint8 // StartTime is the median block time after which voting on the // deployment starts. StartTime uint64 // ExpireTime is the median block time after which the attempted // deployment expires. ExpireTime uint64 }
ConsensusDeployment defines details related to a specific consensus rule change that is voted in. This is part of BIP0009.
type DNSSeed ¶
type DNSSeed struct { // Host defines the hostname of the seed. Host string // HasFiltering defines whether the seed supports filtering // by service flags (wire.ServiceFlag). HasFiltering bool }
DNSSeed identifies a DNS seed.
type Params ¶
type Params struct { // Name defines a human-readable identifier for the network. Name string // Net defines the magic bytes used to identify the network. Net wire.BitcoinNet // DefaultPort defines the default peer-to-peer port for the network. DefaultPort string // DNSSeeds defines a list of DNS seeds for the network that are used // as one method to discover peers. DNSSeeds []DNSSeed // GenesisBlock defines the first block of the chain. GenesisBlock *wire.MsgBlock // GenesisHash is the starting block hash. GenesisHash *chainhash.Hash // These fields define the block heights at which the specified softfork // BIP became active. BIP0034Height int32 BIP0065Height int32 BIP0066Height int32 // CoinbaseMaturity is the number of blocks required before newly mined // coins (coinbase transactions) can be spent. CoinbaseMaturity uint16 // Checkpoints ordered from oldest to newest. Checkpoints []Checkpoint // These fields are related to voting on consensus rule changes as // defined by BIP0009. // // RuleChangeActivationThreshold is the number of blocks in a threshold // state retarget window for which a positive vote for a rule change // must be cast in order to lock in a rule change. It should typically // be 95% for the main network and 75% for test networks. // // MinerConfirmationWindow is the number of blocks in each threshold // state retarget window. // // Deployments define the specific consensus rule changes to be voted // on. RuleChangeActivationThreshold uint32 MinerConfirmationWindow uint32 // Address encoding magics PubKeyHashAddrID uint16 // First 2 bytes of a P2PKH address ScriptHashAddrID uint16 // First 2 bytes of a P2SH address PrivateKeyID byte // First byte of a WIF private key // BIP32 hierarchical deterministic extended key magics HDPrivateKeyID [4]byte HDPublicKeyID [4]byte }
Params defines a Bitcoin network by its parameters. These parameters may be used by Bitcoin applications to differentiate networks as well as addresses and keys for one network from those intended for use on another network.