package Mail::DMARC::Result::Reason;
our $VERSION = '1.20170222'; # VERSION
use strict;
use warnings;
use Carp;
sub new {
my ( $class, @args ) = @_;
croak "invalid arguments" if @args % 2;
my %args = @args;
my $self = bless {}, $class;
foreach my $key ( keys %args ) {
$self->$key( $args{$key} );
}
return $self;
}
sub type {
return $_[0]->{type} if 1 == scalar @_;
croak "invalid type"
if 0 == grep {/^$_[1]$/ix}
qw/ forwarded sampled_out trusted_forwarder
mailing_list local_policy other /;
return $_[0]->{type} = $_[1];
}
sub comment {
return $_[0]->{comment} if 1 == scalar @_;
# comment is optional and requires no validation
return $_[0]->{comment} = $_[1];
}
1;
# ABSTRACT: policy override reason
__END__
=pod
=head1 NAME
Mail::DMARC::Result::Reason - policy override reason
=head1 VERSION
version 1.20170222
=head1 METHODS
=head2 type
Type is the type of override used, and is one of a number of fixed strings.
=head2 comment
Comment may or may not be present, and may be anything.
=head1 AUTHORS
=over 4
=item *
Matt Simerson <msimerson@cpan.org>
=item *
Davide Migliavacca <shari@cpan.org>
=back
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Matt Simerson.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut