mirror of
https://github.com/webmin/webmin.git
synced 2026-02-03 06:03:28 +00:00
Add Digest:HMAC as can be missing outside of Virtualmin install
This commit is contained in:
125
vendor_perl/Digest/HMAC.pm
Normal file
125
vendor_perl/Digest/HMAC.pm
Normal file
@@ -0,0 +1,125 @@
|
||||
package Digest::HMAC;
|
||||
our $VERSION = '1.04'; # VERSION
|
||||
our $AUTHORITY = 'cpan:ARODLAND'; # AUTHORITY
|
||||
|
||||
use strict;
|
||||
|
||||
# OO interface
|
||||
|
||||
sub new
|
||||
{
|
||||
my($class, $key, $hasher, $block_size) = @_;
|
||||
$block_size ||= 64;
|
||||
$key = $hasher->new->add($key)->digest if length($key) > $block_size;
|
||||
|
||||
my $self = bless {}, $class;
|
||||
$self->{k_ipad} = $key ^ (chr(0x36) x $block_size);
|
||||
$self->{k_opad} = $key ^ (chr(0x5c) x $block_size);
|
||||
$self->{hasher} = $hasher->new->add($self->{k_ipad});
|
||||
$self;
|
||||
}
|
||||
|
||||
sub reset
|
||||
{
|
||||
my $self = shift;
|
||||
$self->{hasher}->reset->add($self->{k_ipad});
|
||||
$self;
|
||||
}
|
||||
|
||||
sub add { my $self = shift; $self->{hasher}->add(@_); $self; }
|
||||
sub addfile { my $self = shift; $self->{hasher}->addfile(@_); $self; }
|
||||
|
||||
sub _digest
|
||||
{
|
||||
my $self = shift;
|
||||
my $inner_digest = $self->{hasher}->digest;
|
||||
$self->{hasher}->reset->add($self->{k_opad}, $inner_digest);
|
||||
}
|
||||
|
||||
sub digest { shift->_digest->digest; }
|
||||
sub hexdigest { shift->_digest->hexdigest; }
|
||||
sub b64digest { shift->_digest->b64digest; }
|
||||
|
||||
|
||||
# Functional interface
|
||||
|
||||
require Exporter;
|
||||
*import = \&Exporter::import;
|
||||
use vars qw(@EXPORT_OK);
|
||||
@EXPORT_OK = qw(hmac hmac_hex);
|
||||
|
||||
sub hmac
|
||||
{
|
||||
my($data, $key, $hash_func, $block_size) = @_;
|
||||
$block_size ||= 64;
|
||||
$key = &$hash_func($key) if length($key) > $block_size;
|
||||
|
||||
my $k_ipad = $key ^ (chr(0x36) x $block_size);
|
||||
my $k_opad = $key ^ (chr(0x5c) x $block_size);
|
||||
|
||||
&$hash_func($k_opad, &$hash_func($k_ipad, $data));
|
||||
}
|
||||
|
||||
sub hmac_hex { unpack("H*", &hmac); }
|
||||
|
||||
1;
|
||||
|
||||
__END__
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Digest::HMAC - Keyed-Hashing for Message Authentication
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
# Functional style
|
||||
use Digest::HMAC qw(hmac hmac_hex);
|
||||
$digest = hmac($data, $key, \&myhash);
|
||||
print hmac_hex($data, $key, \&myhash);
|
||||
|
||||
# OO style
|
||||
use Digest::HMAC;
|
||||
$hmac = Digest::HMAC->new($key, "Digest::MyHash");
|
||||
|
||||
$hmac->add($data);
|
||||
$hmac->addfile(*FILE);
|
||||
|
||||
$digest = $hmac->digest;
|
||||
$digest = $hmac->hexdigest;
|
||||
$digest = $hmac->b64digest;
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
HMAC is used for message integrity checks between two parties that
|
||||
share a secret key, and works in combination with some other Digest
|
||||
algorithm, usually MD5 or SHA-1. The HMAC mechanism is described in
|
||||
RFC 2104.
|
||||
|
||||
HMAC follow the common C<Digest::> interface, but the constructor
|
||||
takes the secret key and the name of some other simple C<Digest::>
|
||||
as argument.
|
||||
|
||||
The hmac() and hmac_hex() functions and the Digest::HMAC->new() constructor
|
||||
takes an optional $blocksize argument as well. The HMAC algorithm assumes the
|
||||
digester to hash by iterating a basic compression function on blocks of data
|
||||
and the $blocksize should match the byte-length of such blocks.
|
||||
|
||||
The default $blocksize is 64 which is suitable for the MD5 and SHA-1 digest
|
||||
functions. For stronger algorithms the blocksize probably needs to be
|
||||
increased.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<Digest::HMAC_MD5>, L<Digest::HMAC_SHA1>
|
||||
|
||||
RFC 2104
|
||||
|
||||
=head1 MAINTAINER
|
||||
|
||||
Andrew Rodland <arodland@cpan.org>
|
||||
|
||||
=head1 ORIGINAL AUTHORS
|
||||
|
||||
Graham Barr <gbarr@ti.com>, Gisle Aas <gisle@aas.no>
|
||||
|
||||
=cut
|
||||
76
vendor_perl/Digest/HMAC_MD5.pm
Normal file
76
vendor_perl/Digest/HMAC_MD5.pm
Normal file
@@ -0,0 +1,76 @@
|
||||
package Digest::HMAC_MD5;
|
||||
our $VERSION = '1.04'; # VERSION
|
||||
our $AUTHORITY = 'cpan:ARODLAND'; # AUTHORITY
|
||||
|
||||
use strict;
|
||||
use Digest::MD5 qw(md5);
|
||||
use Digest::HMAC qw(hmac);
|
||||
|
||||
# OO interface
|
||||
use vars qw(@ISA);
|
||||
@ISA=qw(Digest::HMAC);
|
||||
sub new
|
||||
{
|
||||
my $class = shift;
|
||||
$class->SUPER::new($_[0], "Digest::MD5", 64);
|
||||
}
|
||||
|
||||
# Functional interface
|
||||
require Exporter;
|
||||
*import = \&Exporter::import;
|
||||
use vars qw(@EXPORT_OK);
|
||||
@EXPORT_OK=qw(hmac_md5 hmac_md5_hex);
|
||||
|
||||
sub hmac_md5
|
||||
{
|
||||
hmac($_[0], $_[1], \&md5, 64);
|
||||
}
|
||||
|
||||
sub hmac_md5_hex
|
||||
{
|
||||
unpack("H*", &hmac_md5)
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
__END__
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Digest::HMAC_MD5 - Keyed-Hashing for Message Authentication
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
# Functional style
|
||||
use Digest::HMAC_MD5 qw(hmac_md5 hmac_md5_hex);
|
||||
$digest = hmac_md5($data, $key);
|
||||
print hmac_md5_hex($data, $key);
|
||||
|
||||
# OO style
|
||||
use Digest::HMAC_MD5;
|
||||
$hmac = Digest::HMAC_MD5->new($key);
|
||||
|
||||
$hmac->add($data);
|
||||
$hmac->addfile(*FILE);
|
||||
|
||||
$digest = $hmac->digest;
|
||||
$digest = $hmac->hexdigest;
|
||||
$digest = $hmac->b64digest;
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
This module provide HMAC-MD5 hashing.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<Digest::HMAC>, L<Digest::MD5>, L<Digest::HMAC_SHA1>
|
||||
|
||||
=head1 MAINTAINER
|
||||
|
||||
Andrew Rodland <arodland@cpan.org>
|
||||
|
||||
=head1 ORIGINAL AUTHOR
|
||||
|
||||
Gisle Aas <gisle@aas.no>
|
||||
|
||||
=cut
|
||||
76
vendor_perl/Digest/HMAC_SHA1.pm
Normal file
76
vendor_perl/Digest/HMAC_SHA1.pm
Normal file
@@ -0,0 +1,76 @@
|
||||
package Digest::HMAC_SHA1;
|
||||
our $VERSION = '1.04'; # VERSION
|
||||
our $AUTHORITY = 'cpan:ARODLAND'; # AUTHORITY
|
||||
|
||||
use strict;
|
||||
use Digest::SHA qw(sha1);
|
||||
use Digest::HMAC qw(hmac);
|
||||
|
||||
# OO interface
|
||||
use vars qw(@ISA);
|
||||
@ISA=qw(Digest::HMAC);
|
||||
sub new
|
||||
{
|
||||
my $class = shift;
|
||||
$class->SUPER::new($_[0], "Digest::SHA", 64); # Digest::SHA defaults to SHA-1
|
||||
}
|
||||
|
||||
# Functional interface
|
||||
require Exporter;
|
||||
*import = \&Exporter::import;
|
||||
use vars qw(@EXPORT_OK);
|
||||
@EXPORT_OK=qw(hmac_sha1 hmac_sha1_hex);
|
||||
|
||||
sub hmac_sha1
|
||||
{
|
||||
hmac($_[0], $_[1], \&sha1, 64);
|
||||
}
|
||||
|
||||
sub hmac_sha1_hex
|
||||
{
|
||||
unpack("H*", &hmac_sha1)
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
__END__
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Digest::HMAC_SHA1 - Keyed-Hashing for Message Authentication
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
# Functional style
|
||||
use Digest::HMAC_SHA1 qw(hmac_sha1 hmac_sha1_hex);
|
||||
$digest = hmac_sha1($data, $key);
|
||||
print hmac_sha1_hex($data, $key);
|
||||
|
||||
# OO style
|
||||
use Digest::HMAC_SHA1;
|
||||
$hmac = Digest::HMAC_SHA1->new($key);
|
||||
|
||||
$hmac->add($data);
|
||||
$hmac->addfile(*FILE);
|
||||
|
||||
$digest = $hmac->digest;
|
||||
$digest = $hmac->hexdigest;
|
||||
$digest = $hmac->b64digest;
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
This module provide HMAC-SHA-1 hashing.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<Digest::HMAC>, L<Digest::SHA>, L<Digest::HMAC_MD5>
|
||||
|
||||
=head1 MAINTAINER
|
||||
|
||||
Andrew Rodland <arodland@cpan.org>
|
||||
|
||||
=head1 ORIGINAL AUTHOR
|
||||
|
||||
Gisle Aas <gisle@aas.no>
|
||||
|
||||
=cut
|
||||
Reference in New Issue
Block a user