=encoding utf8 =head1 NAME Mail::Message::Head::SpamGroup - spam fighting related header fields =head1 INHERITANCE Mail::Message::Head::SpamGroup is a Mail::Message::Head::FieldGroup is a Mail::Reporter =head1 SYNOPSIS my $sg = Mail::Message::Head::SpamGroup->new(head => $head, ...); $head->addSpamGroup($sg); my $sg = $head->addSpamGroup( ); $sg->delete; my @sgs = $head->spamGroups; =head1 DESCRIPTION A I is a set of header fields which are added by spam detection and spam fighting software. This class knows various details about that software. Extends L<"DESCRIPTION" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"DESCRIPTION">. =head1 METHODS Extends L<"METHODS" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"METHODS">. =head2 Constructors Extends L<"Constructors" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"Constructors">. =over 4 =item $obj-EB() Inherited, see L =item $obj-EB( $name, [$settings] ) =item Mail::Message::Head::SpamGroup-EB( $name, [$settings] ) Get the $settings of a certain spam-fighter, optionally after setting them. The L method returns the defined names. The names are case-sensitive. -Option --Default fields isspam version undef =over 2 =item fields => REGEXP The regular expression which indicates which of the header fields are added by the spam fighter software. =item 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. =item 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. =back 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 } ); =item $obj-EB($head|$message, %options) Returns a list of C objects, based on the specified $message or message $head. -Option--Default types undef =over 2 =item 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. =back =item $obj-EB( [$message|$head] ) =item Mail::Message::Head::SpamGroup-EB( [$message|$head] ) Returns a true value if the $message or $head contains C 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) { ... } =item $obj-EB() =item Mail::Message::Head::SpamGroup-EB() Inherited, see L =item $obj-EB($name) =item Mail::Message::Head::SpamGroup-EB($name) =item $obj-EB() =item Mail::Message::Head::SpamGroup-EB() 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 L method. =item Mail::Message::Head::SpamGroup-EB($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 =over 2 =item head => HEAD =item log => LEVEL =item software => STRING =item trace => LEVEL =item type => STRING =item version => STRING =back =item $obj-EB( [BOOLEAN] ) Returns (after setting) whether this group of spam headers thinks that this is spam. See L. example: die if $head->spamDetected; foreach my $sg ($head->spamGroups) { print $sg->type." found spam\n" if $sg->spamDetected; } =back =head2 The header Extends L<"The header" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"The header">. =over 4 =item $obj-EB( <$field, $value> | $object ) Inherited, see L =item $obj-EB( [$fieldnames] ) Inherited, see L =item $obj-EB($head) Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =back =head2 Access to the header Extends L<"Access to the header" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"Access to the header">. =over 4 =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =back =head2 Internals Extends L<"Internals" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"Internals">. =over 4 =item $obj-EB( [$name] ) Inherited, see L =item $obj-EB($type, $software, $version) Inherited, see L =back =head2 Error handling Extends L<"Error handling" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"Error handling">. =over 4 =item $obj-EB() Inherited, see L =item $obj-EB($object) Inherited, see L =item $obj-EB( [$level]|[$loglevel, $tracelevel]|[$level, $callback] ) =item Mail::Message::Head::SpamGroup-EB( [$level]|[$loglevel, $tracelevel]|[$level, $callback] ) Inherited, see L =item $obj-EB
() Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB( [$level, [$strings]] ) =item Mail::Message::Head::SpamGroup-EB( [$level, [$strings]] ) Inherited, see L =item $obj-EB($level) =item Mail::Message::Head::SpamGroup-EB($level) Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB() Inherited, see L =item $obj-EB( [$fh] ) Inherited, see L =item $obj-EB( [$level] ) Inherited, see L =item $obj-EB( [$level] ) Inherited, see L =item $obj-EB( [$level] ) Inherited, see L =item $obj-EB() Inherited, see L =back =head2 Cleanup Extends L<"Cleanup" in Mail::Message::Head::FieldGroup|Mail::Message::Head::FieldGroup/"Cleanup">. =over 4 =item $obj-EB() Inherited, see L =back =head1 DETAILS =head2 Spam fighting fields =head3 Detected spam fighting software The L class can be used to detect fields which were produced by different spam fighting software. =over 4 =item * SpamAssassin These fields are added by L, which is the central implementation of the spam-assassin package. The homepage of this GPL'ed project can be found at L. =item * Habeas-SWE 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 L for all the details on this commercial product. =item * MailScanner The MailScanner filter is developed and maintained by transtec Computers. The software is available for free download from L. Commercial support is provided via L. =back =head1 DIAGNOSTICS =over 4 =item 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. =back =head1 SEE ALSO This module is part of Mail-Message distribution version 3.012, built on February 11, 2022. Website: F =head1 LICENSE Copyrights 2001-2022 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 F