package Crypt::Perl::ECDSA::NIST;
use strict;
use warnings;
use Symbol::Get ();
use Crypt::Perl::X ();
use constant JWK_CURVE_prime256v1 => 'P-256';
use constant JWK_CURVE_secp384r1 => 'P-384';
use constant JWK_CURVE_secp521r1 => 'P-521';
sub get_nist_for_curve_name {
my ($curve_name) = @_;
die Crypt::Perl::X::create('Generic', 'Need curve name!') if !length $curve_name;
my $cr = __PACKAGE__->can("JWK_CURVE_$curve_name") or do {
die Crypt::Perl::X::create('ECDSA::NoCurveForName', { name => $curve_name });
};
return $cr->();
}
sub get_curve_name_for_nist {
my ($nist_name) = @_;
die Crypt::Perl::X::create('Generic', 'Need NIST curve name!') if !length $nist_name;
for my $node ( Symbol::Get::get_names() ) {
next if $node !~ m<\AJWK_CURVE_(.+)>;
my $nist = __PACKAGE__->can($node)->();
return $1 if $nist eq $nist_name;
}
die Crypt::Perl::X::create('ECDSA::NoCurveForNISTName', { name => $nist_name });
}
1;