Mail::Message::Head::SpamGroup - spam fighting related header fields


NAME

Mail::Message::Head::SpamGroup - spam fighting related header fields


INHERITANCE

 Mail::Message::Head::SpamGroup
   is a Mail::Message::Head::FieldGroup
   is a Mail::Reporter


SYNOPSIS

 my $sg = Mail::Message::Head::SpamGroup->new(head => $head, ...);
 $head->addSpamGroup($sg);
 my $sg = $head->addSpamGroup( <options> );
 $sg->delete;

 my @sgs = $head->spamGroups;


DESCRIPTION

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.


METHODS

Constructors

$obj->clone

See Constructors in the Mail::Message::Head::FieldGroup manpage

$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   Defined in       Default   
 fields                    <required>
 isspam                    <required>
 version                   C<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  Defined in  Default 
 types               C<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 Constructors in the Mail::Message::Head::FieldGroup manpage

$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      L<Mail::Message::Head::FieldGroup>  C<undef>     
 log       L<Mail::Reporter>  C<'WARNINGS'>
 software  L<Mail::Message::Head::FieldGroup>  C<undef>     
 trace     L<Mail::Reporter>  C<'WARNINGS'>
 type      L<Mail::Message::Head::FieldGroup>  C<undef>     
 version   L<Mail::Message::Head::FieldGroup>  C<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;
  }

The header

$obj->add((FIELD, VALUE) | OBJECT)

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->addFields([FIELDNAMES])

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->attach(HEAD)

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->delete

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->fieldNames

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->fields

See The header in the Mail::Message::Head::FieldGroup manpage

$obj->head

See The header in the Mail::Message::Head::FieldGroup manpage

Access to the header

$obj->software

See Access to the header in the Mail::Message::Head::FieldGroup manpage

$obj->type

See Access to the header in the Mail::Message::Head::FieldGroup manpage

$obj->version

See Access to the header in the Mail::Message::Head::FieldGroup manpage

Internals

$obj->collectFields([NAME])

See Internals in the Mail::Message::Head::FieldGroup manpage

$obj->detected(TYPE, SOFTWARE, VERSION)

See Internals in the Mail::Message::Head::FieldGroup manpage

Error handling

$obj->AUTOLOAD

See Error handling in the Mail::Reporter manpage

$obj->addReport(OBJECT)

See Error handling in the Mail::Reporter manpage

$obj->defaultTrace([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK])

Mail::Message::Head::SpamGroup->defaultTrace([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK])

See Error handling in the Mail::Reporter manpage

$obj->details

See Error handling in the Mail::Message::Head::FieldGroup manpage

$obj->errors

See Error handling in the Mail::Reporter manpage

$obj->log([LEVEL [,STRINGS]])

Mail::Message::Head::SpamGroup->log([LEVEL [,STRINGS]])

See Error handling in the Mail::Reporter manpage

$obj->logPriority(LEVEL)

Mail::Message::Head::SpamGroup->logPriority(LEVEL)

See Error handling in the Mail::Reporter manpage

$obj->logSettings

See Error handling in the Mail::Reporter manpage

$obj->notImplemented

See Error handling in the Mail::Reporter manpage

$obj->print([FILEHANDLE])

See Error handling in the Mail::Message::Head::FieldGroup manpage

$obj->report([LEVEL])

See Error handling in the Mail::Reporter manpage

$obj->reportAll([LEVEL])

See Error handling in the Mail::Reporter manpage

$obj->trace([LEVEL])

See Error handling in the Mail::Reporter manpage

$obj->warnings

See Error handling in the Mail::Reporter manpage

Cleanup

$obj->DESTROY

See Cleanup in the Mail::Reporter manpage

$obj->inGlobalDestruction

See Cleanup in the Mail::Reporter manpage


DIAGNOSTICS

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.


DETAILS

Spam fighting fields

Detected spam fighting software

The Mail::Message::Head::SpamGroup class can be used to detect fields which were produced by different spam fighting software.


REFERENCES

See the MailBox website at http://perl.overmeer.net/mailbox/ for more details.


COPYRIGHTS

Distribution version 2.059. Written by Mark Overmeer (mark@overmeer.net) See the ChangeLog for other contributors.

Copyright (c) 2001-2003 by the author(s). All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

 Mail::Message::Head::SpamGroup - spam fighting related header fields