CryptX
view release on metacpan or search on metacpan
lib/Crypt/PK/X448.pm view on Meta::CPAN
$pub->import_key(\$public_der);
my $private_pem = $source->export_key_pem('private', 'secret', 'AES-256-CBC');
my $priv = Crypt::PK::X448->new();
$priv->import_key(\$private_pem, 'secret');
$pk->import_key({
curve => "x448",
pub => "CF807AB0FC3EFA03108469F29E499DB2EEFEFEB12544D8D4E711F187385AAF31B4F38C8F84A3DD9E43DA309FD410C3816A50E644B5500C05",
priv => "10D418B111401956ABC5A92C2FBB8406D1D646BA930FDEFA2108EFE68F2000973755AA952BE018F640947C05135FBF9925EBD4DA828D86EC",
});
$pk->import_key({
kty => "OKP",
crv => "X448",
d => "ENQYsRFAGVarxaksL7uEBtHWRrqTD976IQjv5o8gAJc3VaqVK-AY9kCUfAUTX7-ZJevU2oKNhuw",
x => "z4B6sPw--gMQhGnynkmdsu7-_rElRNjU5xHxhzharzG084yPhKPdnkPaMJ_UEMOBalDmRLVQDAU",
});
The same method also accepts filenames instead of buffers.
=head2 import_key_raw
Import raw public/private key bytes.
$pk->import_key_raw($key, 'public');
$pk->import_key_raw($key, 'private');
The raw key must be exactly 56 bytes long.
=head2 export_key_der
Returns the key as a binary DER-encoded string.
my $der = $pk->export_key_der('private');
my $der = $pk->export_key_der('public');
=head2 export_key_pem
Returns the key as a PEM-encoded string (ASCII).
my $pem = $pk->export_key_pem('private');
my $pem = $pk->export_key_pem('public');
my $pem = $pk->export_key_pem('private', $password, 'AES-256-CBC');
=head2 export_key_jwk
Returns a JSON string, or a hashref if the optional second argument is true.
my $json = $pk->export_key_jwk('private');
my $hash = $pk->export_key_jwk('public', 1);
=head2 export_key_raw
Returns the raw key as a binary string.
my $raw = $pk->export_key_raw('private');
my $raw = $pk->export_key_raw('public');
=head2 shared_secret
Returns the shared secret as a binary string (raw bytes).
my $shared_secret = $private_key->shared_secret($public_key);
=head2 is_private
my $rv = $pk->is_private;
=head2 key2hash
Returns a hashref with the key components, or C<undef> if no key is loaded.
my $hash = $pk->key2hash;
Returns a hash like:
{
curve => "x448",
pub => "CF807AB0FC3EFA03108469F29E499DB2EEFEFEB12544D8D4E711F187385AAF31B4F38C8F84A3DD9E43DA309FD410C3816A50E644B5500C05",
priv => "10D418B111401956ABC5A92C2FBB8406D1D646BA930FDEFA2108EFE68F2000973755AA952BE018F640947C05135FBF9925EBD4DA828D86EC",
}
=head1 OpenSSL interoperability
# Generate a key with OpenSSL
# openssl genpkey -algorithm x448 -out x448_priv.pem
# openssl pkey -in x448_priv.pem -pubout -out x448_pub.pem
# Load the OpenSSL-generated key in CryptX
use Crypt::PK::X448;
my $alice = Crypt::PK::X448->new("x448_priv.pem");
my $bob_pub = Crypt::PK::X448->new("bob_x448_pub.pem");
# Derive shared secret
my $shared_secret = $alice->shared_secret($bob_pub);
# Export CryptX key for OpenSSL
my $pem = $alice->export_key_pem('private');
# then: openssl pkey -in priv.pem -text -noout
=head1 SEE ALSO
=over
=item * L<https://www.rfc-editor.org/rfc/rfc7748>
=item * L<Crypt::PK::X25519>
=back
=cut
( run in 0.659 second using v1.01-cache-2.11-cpan-d8267643d1d )