diff options
author | Marius Halden <marius.h@lden.org> | 2015-10-27 13:27:03 +0100 |
---|---|---|
committer | Marius Halden <marius.h@lden.org> | 2015-10-27 13:27:03 +0100 |
commit | 4fb5331abd2fa4c89ebeb89bc92a245fadd0aa19 (patch) | |
tree | 23632b448612e3845a6e8b1aed6490151395de2a /perllib/Utils/Email.pm | |
parent | e609613b5041a15491417eaa9ae129dd1e7531dd (diff) | |
parent | ac39951581a0eefe069c8a707bb89977227d0bce (diff) |
Merge tag 'v1.7' into fiksgatami-dev
Diffstat (limited to 'perllib/Utils/Email.pm')
-rw-r--r-- | perllib/Utils/Email.pm | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/perllib/Utils/Email.pm b/perllib/Utils/Email.pm new file mode 100644 index 000000000..a30e41c61 --- /dev/null +++ b/perllib/Utils/Email.pm @@ -0,0 +1,37 @@ +package Utils::Email; + +use Email::Address; +use Net::DNS::Resolver; + +# DMARC stabbity stab +sub test_dmarc { + my $email = shift; + + my $addr = (Email::Address->parse($email))[0]; + return unless $addr; + + my $domain = $addr->host; + my @answers = _send(Net::DNS::Resolver->new, "_dmarc.$domain", 'TXT'); + @answers = map { $_->txtdata } @answers; + my $dmarc = join(' ', @answers); + return unless $dmarc =~ /p *= *reject/; + + return 1; +} + +# Same as send->answer, but follows one CNAME and returns only matching results +sub _send { + my ($resolver, $domain, $type) = @_; + my $packet = $resolver->send($domain, $type); + my @answers; + foreach my $rr ($packet->answer) { + if ($rr->type eq 'CNAME') { + push @answers, $resolver->send($rr->cname, $type)->answer; + } else { + push @answers, $rr; + } + } + return grep { $_->type eq $type } @answers; +} + +1; |