|
|
@ -11,18 +11,13 @@ use warnings;
|
|
|
|
use Digest::MD5 qw (md5_hex);
|
|
|
|
use Digest::MD5 qw (md5_hex);
|
|
|
|
use Digest::SHA qw (sha1_hex);
|
|
|
|
use Digest::SHA qw (sha1_hex);
|
|
|
|
|
|
|
|
|
|
|
|
sub module_constraints { [[0, 256], [1, 256], [0, 55], [-1, -1], [-1, -1]] }
|
|
|
|
sub module_constraints { [[0, 256], [0, 256], [0, 55], [0, 55], [0, 55]] }
|
|
|
|
|
|
|
|
|
|
|
|
sub module_generate_hash
|
|
|
|
sub module_generate_hash
|
|
|
|
{
|
|
|
|
{
|
|
|
|
my $word = shift;
|
|
|
|
my $word = shift;
|
|
|
|
my $salt = shift;
|
|
|
|
my $salt = shift;
|
|
|
|
|
|
|
|
|
|
|
|
if (length $salt == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
$salt = random_hex_string (1, 256);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
my $digest = md5_hex ($salt . sha1_hex ($salt . $word));
|
|
|
|
my $digest = md5_hex ($salt . sha1_hex ($salt . $word));
|
|
|
|
|
|
|
|
|
|
|
|
my $hash = sprintf ("%s:%s", $digest, $salt);
|
|
|
|
my $hash = sprintf ("%s:%s", $digest, $salt);
|
|
|
|