This updates the hdkeychain module dependencies, the copyright year in the files modified since the previous release, and serves as a base for hdkeychain/v3.1.1. The updated direct dependencies in this commit are as follows: - github.com/decred/base58@v1.0.5 - github.com/decred/dcrd/chaincfg/v3@v3.2.0 - github.com/decred/dcrd/crypto/blake256@v1.0.1 - github.com/decred/dcrd/crypto/ripemd160@v1.0.2 - github.com/decred/dcrd/dcrec/secp256k1/v4@v4.2.0 - github.com/decred/dcrd/txscript/v4@v4.1.0 The updated indirect dependencies in this commit are as follows: - github.com/dchest/siphash@v1.2.3 - github.com/decred/dcrd/chaincfg/chainhash@v1.0.4 - github.com/decred/dcrd/dcrec@v1.0.1 - github.com/decred/dcrd/dcrec/edwards/v2@v2.0.3 - github.com/decred/dcrd/wire@v1.6.0 - github.com/klauspost/cpuid/v2@v2.0.9 - lukechampine.com/blake3@v1.2.1 The full list of updated direct dependencies since the previous hdkeychain/v3.1.0 release are the same as above. The full list of updated indirect dependencies since the previous hdkeychain/v3.1.0 release are as follows: - github.com/agl/ed25519@v0.0.0-20170116200512-5312a6153412 - github.com/dchest/siphash@v1.2.3 - github.com/decred/dcrd/chaincfg/chainhash@v1.0.4 - github.com/decred/dcrd/dcrec@v1.0.1 - github.com/decred/dcrd/dcrec/edwards/v2@v2.0.3 - github.com/decred/dcrd/wire@v1.6.0 - github.com/decred/slog@v1.2.0 - github.com/klauspost/cpuid/v2@v2.0.9 - lukechampine.com/blake3@v1.2.1 Finally, all modules in the repository are tidied to ensure they are updated to use the latest versions hoisted forward as a result. |
||
|---|---|---|
| .. | ||
| bench_test.go | ||
| doc.go | ||
| example_test.go | ||
| extendedkey_test.go | ||
| extendedkey.go | ||
| go.mod | ||
| go.sum | ||
| README.md | ||
hdkeychain
Package hdkeychain provides an API for Decred hierarchical deterministic extended keys (based on BIP0032).
A comprehensive suite of tests is provided to ensure proper functionality.
Feature Overview
- Full BIP0032 implementation
- Single type for private and public extended keys
- Convenient cryptographically secure seed generation
- Simple creation of master nodes
- Support for multi-layer derivation
- Easy serialization and deserialization for both private and public extended keys
- Support for custom networks by accepting a network parameters interface
- Allows obtaining the underlying serialized secp256k1 pubkeys and privkeys directly so they can either be used directly or optionally converted to the secp256k1 types which provide powerful tools for working with them to do things like sign transactions and generate payment scripts
- Uses the highly-optimized secp256k1 package
- Code examples including:
- Generating a cryptographically secure random seed and deriving a master node from it
- Default HD wallet layout as described by BIP0032
- Audits use case as described by BIP0032
- Comprehensive test coverage including the BIP0032 test vectors
- Benchmarks
BIP0032 Conformity
Two different child key derivation functions are provided: the Child function derives extended keys using a modified scheme based on BIP0032, whereas ChildBIP32Std produces keys that strictly conform to the standard. The Child function should be used for Decred wallet key derivation for legacy reasons.
Installation and Updating
This package is part of the github.com/decred/dcrd/hdkeychain/v3 module. Use
the standard go tooling for working with modules to incorporate it.
Examples
- NewMaster Example Demonstrates how to generate a cryptographically random seed then use it to create a new master node (extended key).
- Default Wallet Layout Example Demonstrates the default hierarchical deterministic wallet layout as described in BIP0032.
- Audits Use Case Example Demonstrates the audits use case in BIP0032.
License
Package hdkeychain is licensed under the copyfree ISC License.