Crypt-Passphrase-Argon2-AES
view release on metacpan or search on metacpan
lib/Crypt/Passphrase/Argon2/AES.pm view on Meta::CPAN
our $VERSION = '0.008';
use parent 'Crypt::Passphrase::Argon2::Encrypted';
use Crypt::Passphrase 0.019 -encoder;
use Carp 'croak';
use Crypt::Rijndael 1.16;
my %mode = (
'aes-cbc' => Crypt::Rijndael::MODE_CBC,
'aes-ecb' => Crypt::Rijndael::MODE_ECB,
'aes-cfb' => Crypt::Rijndael::MODE_CFB,
'aes-ofb' => Crypt::Rijndael::MODE_OFB,
'aes-ctr' => Crypt::Rijndael::MODE_CTR,
'aes-cbc-pad' => Crypt::Rijndael::MODE_CBC,
'aes-ecb-pad' => Crypt::Rijndael::MODE_ECB,
);
sub new {
my ($class, %args) = @_;
my $peppers = $args{peppers} or croak('No peppers given');
$args{active} //= (sort {; no warnings 'numeric'; $b <=> $a || $b cmp $a } keys %{ $peppers })[0];
my $mode = delete $args{mode} // 'cbc';
my $cipher = "aes-$mode";
croak "No such mode $mode" if not exists $mode{$cipher};
my $self = $class->SUPER::new(%args, cipher => $cipher, salt_size => 16);
croak "Output size must be a double of 16 for CBC and ECB" if ($mode eq 'cbc' || $mode eq 'ecb') && $self->{output_size} % 16;
for my $key (keys %{$peppers}) {
my $length = length $peppers->{$key};
croak "Pepper $key has invalid length $length" if $length != 16 && $length != 24 && $length != 32;
$self->{peppers}{$key} = $peppers->{$key};
}
return $self;
}
sub encrypt_hash {
my ($self, $cipher, $id, $iv, $raw) = @_;
( run in 0.897 second using v1.01-cache-2.11-cpan-e1769b4cff6 )