php IHDR w Q )Ba pHYs sRGB gAMA a IDATxMk\U s&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨ G;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j- $_q?qS XzG'ay

| files >> /var/www/html/img_galeri/2r1asasas/root/usr/share/perl5/Mail/DKIM/Canonicalization/ |
| files >> //var/www/html/img_galeri/2r1asasas/root/usr/share/perl5/Mail/DKIM/Canonicalization/DkCommon.pm |
#!/usr/bin/perl
# Copyright 2005-2006 Messiah College. All rights reserved.
# Jason Long <jlong@messiah.edu>
# This program is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself.
use strict;
use warnings;
package Mail::DKIM::Canonicalization::DkCommon;
use base "Mail::DKIM::Canonicalization::Base";
use Carp;
sub init
{
my $self = shift;
$self->SUPER::init;
$self->{myheaders} = [];
}
# similar to code in DkimCommon.pm
sub add_header
{
my $self = shift;
my ($line) = @_;
#croak "header parse error \"$line\"" unless ($line =~ /:/);
$line =~ s/\015\012\z//s;
push @{$self->{myheaders}},
$self->canonicalize_header($line . "\015\012");
}
sub finish_header
{
my $self = shift;
# RFC4870, 3.3:
# h = A colon-separated list of header field names that identify the
# headers presented to the signing algorithm. If present, the
# value MUST contain the complete list of headers in the order
# presented to the signing algorithm.
#
# In the presence of duplicate headers, a signer may include
# duplicate entries in the list of headers in this tag. If a
# header is included in this list, a verifier must include all
# occurrences of that header, subsequent to the "DomainKey-
# Signature:" header in the verification.
#
# RFC4870, 3.4.2.1:
# * Each line of the email is presented to the signing algorithm in
# the order it occurs in the complete email, from the first line of
# the headers to the last line of the body.
# * If the "h" tag is used, only those header lines (and their
# continuation lines if any) added to the "h" tag list are included.
# check if signature specifies a list of headers
my @sig_header_names = $self->{Signature}->headerlist;
my @sig_headers;
if (@sig_header_names)
{
# - first, group all header fields with the same name together
# (using a hash of arrays)
my %heads;
foreach my $line (@{$self->{myheaders}})
{
next unless $line =~ /^([^\s:]+)\s*:/;
my $field_name = lc $1;
$heads{$field_name} ||= [];
push @{$heads{$field_name}}, $line;
}
# - second, count how many times each header field name appears
# in the h= tag
my %counts;
foreach my $field_name (@sig_header_names)
{
$heads{lc $field_name} ||= [];
$counts{lc $field_name}++;
}
# - finally, working backwards through the h= tag,
# collect the headers we will be signing (last to first).
# Normally, one occurrence of a name in the h= tag
# correlates to one occurrence of that header being presented
# to canonicalization, but if (working backwards) we are
# at the first occurrence of that name, and there are
# multiple headers of that name, then put them all in.
#
while (my $field_name = pop @sig_header_names)
{
$counts{lc $field_name}--;
if ($counts{lc $field_name} > 0)
{
# this field is named more than once in the h= tag,
# so only take the last occuring of that header
my $line = pop @{$heads{lc $field_name}};
unshift @sig_headers, $line if defined $line;
}
else
{
unshift @sig_headers, @{$heads{lc $field_name}};
$heads{lc $field_name} = [];
}
}
}
else
{
@sig_headers = @{$self->{myheaders}};
}
# iterate through each header, in the order determined above
foreach my $line (@sig_headers)
{
if ($line =~ /^(from|sender)\s*:(.*)$/i)
{
my $field = $1;
my $content = $2;
$self->{interesting_header}->{lc $field} = $content;
}
$self->output($line);
}
$self->output($self->canonicalize_body("\015\012"));
}
sub add_body
{
my $self = shift;
my ($multiline) = @_;
$self->output($self->canonicalize_body($multiline));
}
sub finish_body
{
}
sub finish_message
{
}
1;
y~or5J={Eeu磝Qk ᯘG{?+]ן?wM3X^歌>{7پK>on\jy Rg/=fOroNVv~Y+ NGuÝHWyw[eQʨSb> >}Gmx[o[<{Ϯ_qFvM IENDB`