%PDF- %PDF-
Direktori : /proc/25810/root/usr/share/perl5/vendor_perl/Mail/DKIM/Canonicalization/ |
Current File : //proc/25810/root/usr/share/perl5/vendor_perl/Mail/DKIM/Canonicalization/relaxed.pm |
#!/usr/bin/perl # Copyright 2005 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::relaxed; use base "Mail::DKIM::Canonicalization::DkimCommon"; use Carp; sub init { my $self = shift; $self->SUPER::init; $self->{canonicalize_body_empty_lines} = 0; } sub canonicalize_header { my $self = shift; croak "wrong number of parameters" unless (@_ == 1); my ($line) = @_; # # step 1: convert all header field names (not the header field values) # to lower case # if ($line =~ /^([^:]+):(.*)/s) { # lowercase field name $line = lc($1) . ":$2"; } # # step 2: unwrap all header field continuation lines... i.e. # remove any CRLF sequences that are followed by WSP # $line =~ s/\015\012(\s)/$1/g; # # step 3: convert all sequences of one or more WSP characters to # a single SP character # $line =~ s/[ \t]+/ /g; # # step 4: delete all WSP characters at the end of the header field value # $line =~ s/ \z//s; # # step 5: delete any WSP character remaining before and after the colon # separating the header field name from the header field value # $line =~ s/^([^:\s]+)\s*:\s*/$1:/; return $line; } sub canonicalize_body { my $self = shift; my ($multiline) = @_; $multiline =~ s/\015\012\z//s; # # step 1: ignore all white space at the end of lines # $multiline =~ s/[ \t]+(?=\015\012|\z)//g; # # step 2: reduce all sequences of WSP within a line to a single # SP character # $multiline =~ s/[ \t]+/ /g; $multiline .= "\015\012"; # # step 3: ignore empty lines at the end of the message body # (i.e. do not emit empty lines until a following nonempty line # is found) # my $empty_lines = $self->{canonicalize_body_empty_lines}; if ( $multiline =~ s/^((?:\015\012)+)// ) { # count & strip leading empty lines $empty_lines += length($1)/2; } if ($empty_lines > 0 && length($multiline) > 0) { # re-insert leading white if any nonempty lines exist $multiline = ("\015\012" x $empty_lines) . $multiline; $empty_lines = 0; } while ($multiline =~ /\015\012\015\012\z/) { # count & strip trailing empty lines chop $multiline; chop $multiline; $empty_lines++; } $self->{canonicalize_body_empty_lines} = $empty_lines; return $multiline; } 1;