NAME
Bitcoin::Crypto::Key::Private - Bitcoin private keys
SYNOPSIS
use Bitcoin::Crypto::Key::Private;
# get Bitcoin::Crypto::Key::Public instance from private key
my $pub = $priv->get_public_key();
# create signature using private key (sha256 of string byte representation)
my $sig = $priv->sign_message("Hello world");
# signature is returned as byte string
# use unpack to get the representation you need
my $sig_hex = unpack "H*", $sig;
# signature verification
$priv->verify_message("Hello world", $sig);
DESCRIPTION
This class allows you to create a private key instance.
You can use a private key to:
generate public keys
sign and verify messages
Please note that any keys generated are by default compressed.
see Bitcoin::Crypto::Network if you want to work with other networks than Bitcoin Mainnet.
METHODS
from_bytes
$key_object = $class->from_bytes($data)
Use this method to create a PrivateKey instance from a byte string. Data $data
will be used as a private key entropy.
Returns class instance.
new
$key_object = $class->new($data)
This works exactly the same as from_bytes
to_bytes
$bytestring = $object->to_bytes()
Does the opposite of from_bytes on a target object
from_hex
$key_object = $class->from_hex($hex)
Use this method to create a PrivateKey instance from a hexadecimal number. Number $hex
will be used as a private key entropy.
Returns class instance.
to_hex
$hex_string = $object->to_hex()
Does the opposite of from_hex on a target object
from_wif
$key_object = $class->from_wif($str, $network = undef)
Creates a new private key from Wallet Import Format string.
Takes an additional optional argument, which is network name. It may be useful if you use many networks and some have the same WIF byte.
This method will change compression and network states of the created private key, as this data is included in WIF format.
Returns class instance.
to_wif
$wif_string = $object->to_wif()
Does the opposite of from_wif on a target object
set_compressed
$key_object = $object->set_compressed($val)
Change key's compression state to $val
(1/0). This will change the WIF generated by toWif() method and also enable creation of uncompressed public keys. If $val
is omitted it is set to 1.
Returns current key instance.
set_network
$key_object = $object->set_network($val)
Change key's network state to $val
. It can be either network name present in Bitcoin::Crypto::Network package or an instance of this class.
Returns current key instance.
get_public_key
$public_key_object = $object->get_public_key()
Returns instance of Bitcoin::Crypto::Key::Public generated from the private key.
sign_message
$signature = $object->sign_message($message, $algo = "sha256")
Signs a digest of $message
(using $algo
digest algorithm) with a private key.
$algo
must be available in Digest package.
Returns a byte string containing signature.
Character encoding note: $message
should be encoded in the proper encoding before passing it to this method. Passing Unicode string will cause the function to fail. You can encode like this (for UTF-8):
use Encode qw(encode);
$message = encode('UTF-8', $message);
Caution: libtomcrypt cryptographic package that is generating signatures does not currently offer a deterministic mechanism. For this reason the sign_message method will complain with a warning. You should install an optional Crypt::Perl package, which supports deterministic signatures, which will disable the warning. Non-deterministic signatures can lead to leaking private keys if the random number generator's entropy is insufficient.
verify_message
$signature_valid = $object->verify_message($message, $signature, $algo = "sha256")
Verifies $signature
against digest of $message
(with $algo
digest algorithm) using private key.
$algo
must be available in Digest package.
Returns boolean.
Character encoding note: $message
should be encoded in the proper encoding before passing it to this method. Passing Unicode string will cause the function to fail. You can encode like this (for UTF-8):
use Encode qw(encode);
$message = encode('UTF-8', $message);
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:
Sign - couldn't sign the message correctly
Verify - couldn't verify the message correctly
KeyCreate - key couldn't be created correctly
NetworkConfig - incomplete or corrupted network configuration