NAME Crypt::Passphrase::Bcrypt::AES - A peppered AES-encrypted Bcrypt encoder for Crypt::Passphrase SYNOPSIS my $passphrase = Crypt::Passphrase->new( encoder => { module => 'Bcrypt::AES', peppers => { 1 => pack('H*', '0123456789ABCDEF...'), 2 => pack('H*', 'FEDCBA9876543210...'), }, }, ); DESCRIPTION This class implements peppering by encrypting the hash using AES (unlike Crypt::Passphrase::Pepper::Simple which hashes the input instead). Configuration This module takes all arguments also taken by Crypt::Passphrase::Bcrypt, with the following additions: * peppers This is a map of identifier to pepper value. The identifiers should be (probably small) numbers, the values should be random binary strings that must be either 16, 24 or 32 bytes long. * active This is the identifier of the active pepper. By default it will be the identifier with the highest (numerical) value. * mode This is the mode that will be used with AES. Values values are 'cfb', 'ofb' and 'ctr' (the default). Supported crypt types This supports any sequence of <bcrypt->, (sha256 | sha385 | sha512), -encrypted-aes-, (ctr | cfb | ofb). E.g. bcrypt-sha384-encrypted-aes-ctr AUTHOR Leon Timmermans <fawaka@gmail.com> COPYRIGHT AND LICENSE This software is copyright (c) 2024 by Leon Timmermans. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.