X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=lib%2FFile%2FKDBX%2FDumper%2FV3.pm;h=cf1f1ed85dae3d5ee7f17bc4bffc4ef444a03e7f;hb=fe0093f5f317cd136a2328abb7b0c31a69d4fe33;hp=890af02ab518593dd1313f07cd133362afd9fc85;hpb=f63182fc62b25269b1c38588dca2b3535ed1a1a2;p=chaz%2Fp5-File-KDBX diff --git a/lib/File/KDBX/Dumper/V3.pm b/lib/File/KDBX/Dumper/V3.pm index 890af02..cf1f1ed 100644 --- a/lib/File/KDBX/Dumper/V3.pm +++ b/lib/File/KDBX/Dumper/V3.pm @@ -8,13 +8,13 @@ use Crypt::Digest qw(digest_data); use Encode qw(encode); use File::KDBX::Constants qw(:header :compression); use File::KDBX::Error; -use File::KDBX::Util qw(:empty assert_64bit erase_scoped); +use File::KDBX::IO::Crypt; +use File::KDBX::IO::HashBlock; +use File::KDBX::Util qw(:class :empty :load assert_64bit erase_scoped); use IO::Handle; -use PerlIO::via::File::KDBX::Crypt; -use PerlIO::via::File::KDBX::HashBlock; use namespace::clean; -use parent 'File::KDBX::Dumper'; +extends 'File::KDBX::Dumper'; our $VERSION = '999.999'; # VERSION @@ -59,7 +59,7 @@ sub _write_header { my $type = shift; my $val = shift // ''; - $type = KDBX_HEADER($type); + $type = to_header_constant($type); if ($type == HEADER_END) { $val = "\r\n\r\n"; } @@ -148,20 +148,23 @@ sub _write_body { push @cleanup, erase_scoped $final_key; my $cipher = $kdbx->cipher(key => $final_key); - PerlIO::via::File::KDBX::Crypt->push($fh, $cipher); + $fh = File::KDBX::IO::Crypt->new($fh, cipher => $cipher); $fh->print($kdbx->headers->{+HEADER_STREAM_START_BYTES}) or throw 'Failed to write start bytes'; - $fh->flush; $kdbx->key($key); - PerlIO::via::File::KDBX::HashBlock->push($fh); + $fh = File::KDBX::IO::HashBlock->new($fh); my $compress = $kdbx->headers->{+HEADER_COMPRESSION_FLAGS}; if ($compress == COMPRESSION_GZIP) { - require PerlIO::via::File::KDBX::Compression; - PerlIO::via::File::KDBX::Compression->push($fh); + load_optional('IO::Compress::Gzip'); + $fh = IO::Compress::Gzip->new($fh, + -Level => IO::Compress::Gzip::Z_BEST_COMPRESSION(), + -TextFlag => 1, + ) or throw "Failed to initialize compression library: $IO::Compress::Gzip::GzipError", + error => $IO::Compress::Gzip::GzipError; } elsif ($compress != COMPRESSION_NONE) { throw "Unsupported compression ($compress)\n", compression_flags => $compress; @@ -169,9 +172,6 @@ sub _write_body { my $header_hash = digest_data('SHA256', $header_data); $self->_write_inner_body($fh, $header_hash); - - binmode($fh, ':pop') if $compress; - binmode($fh, ':pop:pop'); } 1;