NAME

Bitcoin::Crypto::BIP44 - BIP44 implementation

SYNOPSIS

use Bitcoin::Crypto::BIP44;

my $path = Bitcoin::Crypto::BIP44->new(
	coin_type => Bitcoin::Crypto::Network->get('bitcoin_testnet'), # can also be a number or a key instance
	index => 43,
	# account => 0,
	# change => 0,
);

# stringifies automatically
say "$path";

# can be used in key derivation
$ext_private_key->derive_key($path);

DESCRIPTION

This class is a helper for constructing BIP44-compilant key derivation paths. BIP44 describes the mechanism the HD (Hierarchical Deterministic) wallets use to decide derivation paths for coins. BIP49 and BIP84 are constructed the same way, but used for compat and segwit addresses respectively.

Each coin has its own coin_type constant, a list of which is maintained here: https://github.com/satoshilabs/slips/blob/master/slip-0044.md. Bitcoin::Crypto::Network instances hold these constants under the bip44_coin property.

BIP44 objects stringify automatically and can be directly used in "derive_key" in Bitcoin::Crypto::Key::ExtPrivate method. In return, any key object can be used as coin_type in "new", which will automatically fetch coin_type number from the key's current network.

INTERFACE

Attributes

Refer to https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki for details of those attributes.

All of these attributes can be fetched using a method with the same name.

purpose

Purpose contains the BIP document number that you wish to use. Can be either 44, 49 or 84.

By default, number 44 will be used.

coin_type

Needs to be a non-negative integer number. It should be less than 2^31 (but will not check for that).

Will also accept key objects and network objects, as it is possible to fetch the constant for them. In this case, it might raise an exception if the network does not contain the bip44_coin constant.

This value should be in line with the table of BIP44 constants mentioned above.

By default, the value defined in the current default network will be used: see Bitcoin::Crypto::Network.

account

Needs to be a non-negative integer number. It should be less than 2^31 (but will not check for that).

By default, the value 0 is used.

change

Needs to be a number 1 (for addresses to be used as change outputs) or 0 (for addresses that are to be used only internally).

By default, the value 0 is used.

index

Needs to be a non-negative integer number. It should be less than 2^31 (but will not check for that).

By default, the value 0 is used.

public

Use public if you want to derive a public extended key. This is a must when deriving BIP44 from extended public keys.

Since it isn't possible to derive full BIP44 path with public derivation scheme, this will assume "get_from_account".

get_account

If passed 1, the resulting derivation path will only go as far as to the account part. "index" and "change" values will be ignored. Use this to get extended key for the account.

By default, you will get the full derivation path.

get_from_account

If passed 1, the resulting derivation path will start after the account part. "purpose", "coin_type" and "account" values will be ignored. Use this to further derive key that was only derived up to the account part.

By default, you will get the full derivation path.

Methods

new

$bip_object = $class->new(%data)

This is a standard Moo constructor, which can be used to create the object. It takes arguments specified in "Attributes".

Returns class instance.

as_string

$path = $object->as_string()

Stringifies the object as BIP44-compilant key derivation path. Can be used indirectly by just stringifying the object.

EXCEPTIONS

This module throws an instance of Bitcoin::Crypto::Exception if it encounters an error. It can produce the following error types from the Bitcoin::Crypto::Exception namespace:

  • NetworkConfig - incomplete or corrupted network configuration

SEE ALSO

Bitcoin::Crypto::Key::ExtPrivate

https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki