Mail::Box::Search::SpamAssassin - select spam messages with Mail::SpamAssassin |
Mail::Box::Search::SpamAssassin - select spam messages with Mail::SpamAssassin
Mail::Box::Search::SpamAssassin is a Mail::Box::Search is a Mail::Reporter
use Mail::Box::Manager; my $mgr = Mail::Box::Manager->new; my $folder = $mgr->open('Inbox');
my $spam = Mail::Box::Search::SpamAssassin->new; if($spam->search($message)) {...}
my @msgs = $filter->search($folder); foreach my $msg ($folder->messages) { $msg->delete if $msg->label('spam'); }
my $spam2 = Mail::Box::Search::SpamAssassin ->new(deliver => 'DELETE'); $spam2->search($folder); $mgr->moveMessages($spamfolder, $folder->messages('spam'));
Spam means ``unsollicited e-mail'', and is as name derived from a Monty Python scatch. Although Monty Python is fun, spam is a pain: it needlessly spoils minutes of time from most people: telephone bills, overful mailboxes which block honest e-mail, and accidentally removal of honest e-mail which looks like spam. Spam is the pest of Internet.
Happily, Mail::Box can be used as spam filter, in combination with the useful Mail::SpamAssassin module (which must be installed separately). Each message which is searched is wrapped in a Mail::Message::Wrapper::SpamAssassin object.
The spam-assassin module version 2 is not really well adapted for Mail::Message objects, which will make this search even slower than spam-detection already is.
Mail::Box::Search::SpamAssassin->new(OPTIONS)
Create a spam filter. Internally, a Mail::SpamAssassin object is maintained.
Only the whole message can be searched; this is a limitation of the Mail::SpamAssassin module.
Option Defined in Default binaries L<Mail::Box::Search> <false> decode L<Mail::Box::Search> <true> delayed L<Mail::Box::Search> <true> deleted L<Mail::Box::Search> <false> deliver L<Mail::Box::Search> undef in L<Mail::Box::Search> C<'MESSAGE'> label c<'spam'> limit L<Mail::Box::Search> C<0> log L<Mail::Reporter> C<'WARNINGS'> logical L<Mail::Box::Search> C<'REPLACE'> multiparts L<Mail::Box::Search> <true> rewrite_mail <true> sa_options C<{ }> spam_assassin undef trace L<Mail::Reporter> C<'WARNINGS'>
. binaries BOOLEAN
. decode BOOLEAN
. delayed BOOLEAN
. deleted BOOLEAN
. deliver undef|CODE|'DELETE'
. in 'HEAD'|'BODY'|'MESSAGE'
. label STRING|undef
Mark all selected message with the specified STRING. If this
option is explicitly set to undef
, the label will not be set.
. limit NUMBER
. log LEVEL
. logical 'REPLACE'|'AND'|'OR'|'NOT'|'AND NOT'|'OR NOT'
. multiparts BOOLEAN
. rewrite_mail BOOLEAN
Add lines to the message header describing the results of the spam scan. See Mail::SpamAssassin::PerMsgStatus subroutine rewrite_mail.
. sa_options HASH
Options to create the internal Mail::SpamAssassin object; see its manual page for the available options. Other setting may be provided via SpamAssassins configuration file mechanism, which is explained in the Mail::SpamAssassin::Conf manpage.
. spam_assassin OBJECT
Provide a Mail::SpamAssassin object to be used for searching spam. If none is specified, one is created internally. The object can be retreived with assassinator().
. trace LEVEL
Example:
my $filter = Mail::Box::Search::SpamAssassin ->new( found => 'DELETE' );
$obj->assassinator
Returns the internally maintained assassinator object. You may want to reach this object for complex configuration.
$obj->inBody(PART, BODY)
See Searching in the Mail::Box::Search manpage
$obj->inHead(PART, HEAD)
See Searching in the Mail::Box::Search manpage
$obj->search(FOLDER|THREAD|MESSAGE|ARRAY-OF-MESSAGES)
See Searching in the Mail::Box::Search manpage
$obj->searchPart(PART)
See Searching in the Mail::Box::Search manpage
$obj->printMatch([FILEHANDLE], HASH)
See The Results in the Mail::Box::Search manpage
$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::Box::Search::SpamAssassin->defaultTrace([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK])
See Error handling in the Mail::Reporter manpage
$obj->errors
See Error handling in the Mail::Reporter manpage
$obj->log([LEVEL [,STRINGS]])
Mail::Box::Search::SpamAssassin->log([LEVEL [,STRINGS]])
See Error handling in the Mail::Reporter manpage
$obj->logPriority(LEVEL)
Mail::Box::Search::SpamAssassin->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->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
$obj->DESTROY
See Cleanup in the Mail::Reporter manpage
$obj->inGlobalDestruction
See Cleanup in the Mail::Reporter manpage
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.
See the MailBox website at http://perl.overmeer.net/mailbox/ for more details.
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::Box::Search::SpamAssassin - select spam messages with Mail::SpamAssassin |