Documentation ¶
Index ¶
Constants ¶
View Source
const ( // FirstHardenedChild is the index of the firxt "harded" child key as per the // bip32 spec FirstHardenedChild = uint32(0x80000000) // PublicKeyCompressedLength is the byte count of a compressed public key PublicKeyCompressedLength = 33 // NetworkTestNet is the string for BTC TestNet network NetworkTestNet = "testnet" // NetworkMainNet is the string for BTC MainNet network NetworkMainNet = "mainnet" )
Variables ¶
View Source
var ( // BTCNetwork is the BTC network on which the wallet is valid (decides public/private version flags) BTCNetwork = NetworkMainNet // PrivateWalletVersion is the version flag for serialized private keys for set BTCNetwork PrivateWalletVersion []byte // PublicWalletVersion is the version flag for serialized public keys for set BTCNetwork PublicWalletVersion []byte // PrivateMainNetWalletVersion is the version flag for mainnet serialized private keys PrivateMainNetWalletVersion, _ = hex.DecodeString("0488ADE4") // PublicMainNetWalletVersion is the version flag for mainnet serialized public keys PublicMainNetWalletVersion, _ = hex.DecodeString("0488B21E") // PrivateTestNetWalletVersion is the version flag for testnet serialized private keys PrivateTestNetWalletVersion, _ = hex.DecodeString("04358394") // PublicTestNetWalletVersion is the version flag for testnet serialized public keys PublicTestNetWalletVersion, _ = hex.DecodeString("043587cf") // ErrInvalidBTCNetwork is returned when trying to set a BTC network // which is not currently supported ErrInvalidBTCNetwork = errors.New("Invalid BTC network") // ErrSerializedKeyWrongSize is returned when trying to deserialize a key that // has an incorrect length ErrSerializedKeyWrongSize = errors.New("Serialized keys should by exactly 82 bytes") // ErrHardnedChildPublicKey is returned when trying to create a harded child // of the public key ErrHardnedChildPublicKey = errors.New("Can't create hardened child for public key") // ErrInvalidChecksum is returned when deserializing a key with an incorrect // checksum ErrInvalidChecksum = errors.New("Checksum doesn't match") // ErrInvalidPrivateKey is returned when a derived private key is invalid ErrInvalidPrivateKey = errors.New("Invalid private key") // ErrInvalidPublicKey is returned when a derived public key is invalid ErrInvalidPublicKey = errors.New("Invalid public key") )
View Source
var ( // BitcoinBase58Encoding is the encoding used for bitcoin addresses BitcoinBase58Encoding = basen.NewEncoding("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz") )
Functions ¶
func SetBTCNetwork ¶
SetBTCNetwork sets BTCNetwork to the given network string if supported
Types ¶
type Key ¶
type Key struct { Key []byte // 33 bytes Version []byte // 4 bytes ChildNumber []byte // 4 bytes FingerPrint []byte // 4 bytes ChainCode []byte // 32 bytes Depth byte // 1 bytes IsPrivate bool // unserialized }
Key represents a bip32 extended key
func B58Deserialize ¶
B58Deserialize deserializes a Key encoded in base58 encoding
func NewMasterKey ¶
NewMasterKey creates a new master extended key from a seed
func (*Key) B58Serialize ¶
B58Serialize encodes the Key in the standard Bitcoin base58 encoding
func (*Key) NewChildKey ¶
NewChildKey derives a child key from a given parent as outlined by bip32
func (*Key) PublicKey ¶
PublicKey returns the public version of key or return a copy The 'Neuter' function from the bip32 spec
Click to show internal directories.
Click to hide internal directories.