Mail::Message::Head::SpamGroup - spam fighting related header fields
Mail::Message::Head::SpamGroup is a Mail::Message::Head::FieldGroup is a Mail::Reporter
my $sg = Mail::Message::Head::SpamGroup->new(head => $head, ...); $head->addSpamGroup($sg); my $sg = $head->addSpamGroup( <options> ); $sg->delete; my @sgs = $head->spamGroups;
A spam group is a set of header fields which are added by spam detection and spam fighting software. This class knows various details about that software.
$obj->clone
See Mail::Message::Head::FieldGroup/"Constructors"
$obj->fighter(NAME, [SETTINGS])
Mail::Message::Head::SpamGroup->fighter(NAME, [SETTINGS])
Get the SETTINGS of a certain spam-fighter, optionally after setting them. The knownFighters() method returns the defined names. The names are case-sensitive.
Option --Default fields <required> isspam <required> version undef
. fields => REGEXP
The regular expression which indicates which of the header fields are added by the spam fighter software.
. isspam => CODE
The CODE must return true or false, to indicate whether the spam fighter thinks that the message contains spam. The CODE ref is called with the spamgroup object (under construction) and the header which is inspected.
. version => CODE
Can be called to collect the official name and the version of the software which is used to detect spam. The CODE ref is called with the spamgroup object (under construction) and the header which is inspected.
example: adding your own spam-fighter definitions
Mail::Message::Head::SpamGroup->fighter( 'MY-OWN', fields => qw/^x-MY-SPAM-DETECTOR-/, isspam => sub { my ($sg, $head) = @_; $head->fields > 100 } );
$obj->from(HEAD|MESSAGE, OPTIONS)
Returns a list of Mail::Message::Head::SpamGroup
objects, based on the
specified MESSAGE or message HEAD.
Option--Default types undef
. types => ARRAY-OF-NAMES
Only the specified types will be tried. If the ARRAY is empty, an empty list is returned. Without this option, all sets are returned.
$obj->habeasSweFieldsCorrect([MESSAGE|HEAD])
Mail::Message::Head::SpamGroup->habeasSweFieldsCorrect([MESSAGE|HEAD])
Returns a true value if the MESSAGE or HEAD contains Habeas-SWE
fields
which are correct. Without argument, this is used as instance method on
an existing Spam-Group.
example: checking Habeas-SWE fields
if(Mail::Message::Head::SpamGroup->habeasSweFieldsCorrect($message)) { $message->label(spam => 0); } my $sg = $message->head->spamGroups('Habeas-SWE'); if($sg->habeasSweFieldsCorrect) { ... }; use List::Util 'first'; if(first {$_->habeasSweFieldsCorrect} $head->spamGroups) { ... }
$obj->implementedTypes
Mail::Message::Head::SpamGroup->implementedTypes
See Mail::Message::Head::FieldGroup/"Constructors"
$obj->isSpamGroupFieldName(NAME)
Mail::Message::Head::SpamGroup->isSpamGroupFieldName(NAME)
$obj->knownFighters
Mail::Message::Head::SpamGroup->knownFighters
Returns an unsorted list of all names representing pre-defined spam-fighter software. You can ask details about them, and register more fighters with the fighter() method.
Mail::Message::Head::SpamGroup->new(FIELDS, OPTIONS)
Construct an object which maintains one set of fields which were added by spam fighting software.
Option --Defined in --Default head Mail::Message::Head::FieldGroup undef log Mail::Reporter 'WARNINGS' software Mail::Message::Head::FieldGroup undef trace Mail::Reporter 'WARNINGS' type Mail::Message::Head::FieldGroup undef version Mail::Message::Head::FieldGroup undef
. head => HEAD
. log => LEVEL
. software => STRING
. trace => LEVEL
. type => STRING
. version => STRING
$obj->spamDetected([BOOLEAN])
Returns (after setting) whether this group of spam headers thinks that this is spam. See Mail::Message::Head::Complete::spamDetected().
example:
die if $head->spamDetected; foreach my $sg ($head->spamGroups) { print $sg->type." found spam\n" if $sg->spamDetected; }
$obj->add((FIELD, VALUE) | OBJECT)
See Mail::Message::Head::FieldGroup/"The header"
$obj->addFields([FIELDNAMES])
See Mail::Message::Head::FieldGroup/"The header"
$obj->attach(HEAD)
See Mail::Message::Head::FieldGroup/"The header"
$obj->delete
See Mail::Message::Head::FieldGroup/"The header"
$obj->fieldNames
See Mail::Message::Head::FieldGroup/"The header"
$obj->fields
See Mail::Message::Head::FieldGroup/"The header"
$obj->head
See Mail::Message::Head::FieldGroup/"The header"
$obj->software
See Mail::Message::Head::FieldGroup/"Access to the header"
$obj->type
See Mail::Message::Head::FieldGroup/"Access to the header"
$obj->version
See Mail::Message::Head::FieldGroup/"Access to the header"
$obj->collectFields([NAME])
See Mail::Message::Head::FieldGroup/"Internals"
$obj->detected(TYPE, SOFTWARE, VERSION)
See Mail::Message::Head::FieldGroup/"Internals"
$obj->AUTOLOAD
See Mail::Reporter/"Error handling"
$obj->addReport(OBJECT)
See Mail::Reporter/"Error handling"
$obj->defaultTrace([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK])
Mail::Message::Head::SpamGroup->defaultTrace([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK])
See Mail::Reporter/"Error handling"
$obj->details
See Mail::Message::Head::FieldGroup/"Error handling"
$obj->errors
See Mail::Reporter/"Error handling"
$obj->log([LEVEL [,STRINGS]])
Mail::Message::Head::SpamGroup->log([LEVEL [,STRINGS]])
See Mail::Reporter/"Error handling"
$obj->logPriority(LEVEL)
Mail::Message::Head::SpamGroup->logPriority(LEVEL)
See Mail::Reporter/"Error handling"
$obj->logSettings
See Mail::Reporter/"Error handling"
$obj->notImplemented
See Mail::Reporter/"Error handling"
$obj->print([FILEHANDLE])
See Mail::Message::Head::FieldGroup/"Error handling"
$obj->report([LEVEL])
See Mail::Reporter/"Error handling"
$obj->reportAll([LEVEL])
See Mail::Reporter/"Error handling"
$obj->trace([LEVEL])
See Mail::Reporter/"Error handling"
$obj->warnings
See Mail::Reporter/"Error handling"
$obj->DESTROY
$obj->inGlobalDestruction
The Mail::Message::Head::SpamGroup class can be used to detect fields which were produced by different spam fighting software.
Habeas tries to fight spam via the standard copyright protection mechanism: Sender Warranted E-mail (SWE). Only when you have a contract with Habeas, you are permitted to add a few copyrighted lines to your e-mail. Spam senders will be refused a contract. Mail clients which see these nine lines are (quite) sure that the message is sincere.
See http://www.habeas.com for all the details on this commercial product.
Error: Package $package does not implement $method.
Fatal error: the specific package (or one of its superclasses) does not implement this method where it should. This message means that some other related classes do implement this method however the class at hand does not. Probably you should investigate this and probably inform the author of the package.
This module is part of Mail-Box distribution version 2.082, built on April 28, 2008. Website: http://perl.overmeer.net/mailbox/
Copyrights 2001-2008 by Mark Overmeer. For other contributors see ChangeLog.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See http://www.perl.com/perl/misc/Artistic.html