Mail-DKIM
view release on metacpan or search on metacpan
lib/Mail/DKIM/Algorithm/dk_rsa_sha1.pm view on Meta::CPAN
{
my $sender = $self->{canon}->{interesting_header}->{sender};
$sender = defined($sender) && ( Mail::Address->parse($sender) )[0];
my $author = $self->{canon}->{interesting_header}->{from};
$author = defined($author) && ( Mail::Address->parse($author) )[0];
if ($sender) {
$s->init_identity( $sender->address, 'header.sender' );
}
elsif ($author) {
$s->init_identity( $author->address, 'header.from' );
}
}
return;
}
sub get_canonicalization_class {
my $self = shift;
croak 'wrong number of arguments' unless ( @_ == 1 );
my ($method) = @_;
my $class =
$method eq 'nofws' ? 'Mail::DKIM::Canonicalization::dk_nofws'
: $method eq 'simple' ? 'Mail::DKIM::Canonicalization::dk_simple'
: die "unknown method $method\n";
return $class;
}
sub init {
my $self = shift;
die 'no signature' unless $self->{Signature};
$self->{mode} = $self->{Signature}->signature ? 'verify' : 'sign';
# allows subclasses to set the header_digest and body_digest
# properties
$self->init_digests;
my $method = $self->{Signature}->canonicalization;
my $canon_class = $self->get_canonicalization_class($method);
$self->{canon} = $canon_class->new(
output_digest => $self->{header_digest},
Signature => $self->{Signature},
Debug_Canonicalization => $self->{Debug_Canonicalization}
);
}
sub init_digests {
my $self = shift;
# initialize a SHA-1 Digest
$self->{header_digest} = Digest::SHA->new(1);
$self->{body_digest} = $self->{header_digest};
}
sub sign {
my $self = shift;
croak 'wrong number of arguments' unless ( @_ == 1 );
my ($private_key) = @_;
my $digest = $self->{header_digest}->digest;
my $signature = $private_key->sign_digest( 'SHA-1', $digest );
return encode_base64( $signature, '' );
}
sub verify {
my $self = shift;
croak 'wrong number of arguments' unless ( @_ == 0 );
my $base64 = $self->signature->data;
my $public_key = $self->signature->get_public_key;
my $digest = $self->{header_digest}->digest;
my $sig = decode_base64($base64);
return $public_key->verify_digest( 'SHA-1', $digest, $sig );
}
sub finish_message {
my $self = shift;
# DomainKeys doesn't include the signature in the digest,
# but we still want it to look "pretty" :).
if ( $self->{mode} eq 'sign' ) {
$self->{Signature}->prettify;
}
}
sub wants_pre_signature_headers {
return 0;
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Mail::DKIM::Algorithm::dk_rsa_sha1 - Base algorithm class
=head1 VERSION
version 1.20240923
=head1 AUTHORS
=over 4
=item *
Jason Long <jason@long.name>
=item *
Marc Bradshaw <marc@marcbradshaw.net>
=item *
( run in 0.876 second using v1.01-cache-2.11-cpan-5a3173703d6 )