use Crypt::Digest qw(digest_data);
use File::KDBX::Constants qw(:bool :kdf);
use File::KDBX::Error;
-use File::KDBX::Util qw(:load can_fork);
+use File::KDBX::Util qw(:class :load can_fork);
use namespace::clean;
-use parent 'File::KDBX::KDF';
+extends 'File::KDBX::KDF';
our $VERSION = '999.999'; # VERSION
my $FORK_OPTIMIZATION_THRESHOLD = 100_000;
BEGIN {
- my $use_fork = $ENV{NO_FORK} || !can_fork ? FALSE : TRUE;
- *_USE_FORK = sub() { $use_fork };
-}
-
-sub init {
- my $self = shift;
- my %args = @_;
- return $self->SUPER::init(
- KDF_PARAM_AES_ROUNDS() => $args{+KDF_PARAM_AES_ROUNDS} // $args{rounds},
- KDF_PARAM_AES_SEED() => $args{+KDF_PARAM_AES_SEED} // $args{seed},
- );
+ my $use_fork = $ENV{NO_FORK} || !can_fork;
+ *_USE_FORK = $use_fork ? \&TRUE : \&FALSE;
}
=attr rounds
sub rounds { $_[0]->{+KDF_PARAM_AES_ROUNDS} || KDF_DEFAULT_AES_ROUNDS }
sub seed { $_[0]->{+KDF_PARAM_AES_SEED} }
+sub init {
+ my $self = shift;
+ my %args = @_;
+ return $self->SUPER::init(
+ KDF_PARAM_AES_ROUNDS() => $args{+KDF_PARAM_AES_ROUNDS} // $args{rounds},
+ KDF_PARAM_AES_SEED() => $args{+KDF_PARAM_AES_SEED} // $args{seed},
+ );
+}
+
sub _transform {
my $self = shift;
my $key = shift;