dcrd/hdkeychain
Dave Collins 256f81f703
hdkeychain: Prepare v3.1.1.
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.
2023-06-08 12:48:14 -05:00
..
bench_test.go hdkeychain: Use mock net params in tests. 2019-03-29 11:26:40 -05:00
doc.go multi: Go 1.19 doc comment formatting. 2022-07-30 04:08:58 -05:00
example_test.go hdkeychain: Convert to use new stdaddr package. 2021-04-09 13:39:19 -05:00
extendedkey_test.go hdkeychain: Prepare v3.1.1. 2023-06-08 12:48:14 -05:00
extendedkey.go hdkeychain: Limit decode to max possible size. 2022-01-01 03:09:15 -06:00
go.mod hdkeychain: Prepare v3.1.1. 2023-06-08 12:48:14 -05:00
go.sum hdkeychain: Prepare v3.1.1. 2023-06-08 12:48:14 -05:00
README.md hdkeychain: Add a strict BIP32 child derivation method. 2021-12-13 22:46:25 -06:00

hdkeychain

Build Status ISC License Doc

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

License

Package hdkeychain is licensed under the copyfree ISC License.