diff options
| author | ivan <ivan> | 2003-07-15 13:16:32 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2003-07-15 13:16:32 +0000 | 
| commit | 0ebeec96313dd7edfca340f01f8fbbbac1f4aa1d (patch) | |
| tree | 64e852c61cbf09007d52cd6978bfddea721d00d2 /rt/lib/RT/Interface/Email | |
| parent | c0567c688084e89fcd11bf82348b6c418f1254ac (diff) | |
| parent | 945721f48f74d5cfffef7c7cf3a3d6bc2521f5dd (diff) | |
This commit was generated by cvs2svn to compensate for changes in r2526,
which included commits to RCS files with non-trunk default branches.
Diffstat (limited to 'rt/lib/RT/Interface/Email')
| -rw-r--r-- | rt/lib/RT/Interface/Email/Auth/MailFrom.pm | 131 | ||||
| -rw-r--r-- | rt/lib/RT/Interface/Email/Filter/SpamAssassin.pm | 63 | 
2 files changed, 194 insertions, 0 deletions
| diff --git a/rt/lib/RT/Interface/Email/Auth/MailFrom.pm b/rt/lib/RT/Interface/Email/Auth/MailFrom.pm new file mode 100644 index 000000000..eb778ff30 --- /dev/null +++ b/rt/lib/RT/Interface/Email/Auth/MailFrom.pm @@ -0,0 +1,131 @@ +# BEGIN LICENSE BLOCK +#  +# Copyright (c) 1996-2003 Jesse Vincent <jesse@bestpractical.com> +#  +# (Except where explictly superceded by other copyright notices) +#  +# This work is made available to you under the terms of Version 2 of +# the GNU General Public License. A copy of that license should have +# been provided with this software, but in any event can be snarfed +# from www.gnu.org. +#  +# This work is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU +# General Public License for more details. +#  +# Unless otherwise specified, all modifications, corrections or +# extensions to this work which alter its source code become the +# property of Best Practical Solutions, LLC when submitted for +# inclusion in the work. +#  +#  +# END LICENSE BLOCK +package RT::Interface::Email::Auth::MailFrom; +use RT::Interface::Email qw(ParseSenderAddressFromHead CreateUser); + +# This is what the ordinary, non-enhanced gateway does at the moment. + +sub GetCurrentUser { +    my %args = ( Message     => undef, +                 CurrentUser => undef, +                 AuthLevel   => undef, +                 Ticket      => undef, +                 Queue       => undef, +                 Action      => undef, +                 @_ ); + +    # We don't need to do any external lookups +    my ( $Address, $Name ) = ParseSenderAddressFromHead( $args{'Message'}->head ); +    my $CurrentUser = RT::CurrentUser->new(); +    $CurrentUser->LoadByEmail($Address); + +    unless ( $CurrentUser->Id ) { +        $CurrentUser->LoadByName($Address); +    } + +    if ( $CurrentUser->Id ) { +        return ( $CurrentUser, 1 ); +    } +     + + +    # If the user can't be loaded, we may need to create one. Figure out the acl situation. +    my $unpriv = RT::Group->new($RT::SystemUser); +    $unpriv->LoadSystemInternalGroup('Unprivileged'); +    unless ( $unpriv->Id ) { +        $RT::Logger->crit( "Auth::MailFrom couldn't find the 'Unprivileged' internal group" ); +        return ( $args{'CurrentUser'}, -1 ); +    } + +    my $everyone = RT::Group->new($RT::SystemUser); +    $everyone->LoadSystemInternalGroup('Everyone'); +    unless ( $everyone->Id ) { +        $RT::Logger->crit( "Auth::MailFrom couldn't find the 'Everyone' internal group"); +        return ( $args{'CurrentUser'}, -1 ); +    } + +    # but before we do that, we need to make sure that the created user would have the right +    # to do what we're doing. +    if ( $args{'Ticket'} && $args{'Ticket'}->Id ) { +        # We have a ticket. that means we're commenting or corresponding +        if ( $args{'Action'} =~ /^comment$/i ) { + +            # check to see whether "Everybody" or "Unprivileged users" can comment on tickets +            unless ( $everyone->PrincipalObj->HasRight( +                                                      Object => $args{'Queue'}, +                                                      Right => 'CommentOnTicket' +                     ) +                     || $unpriv->PrincipalObj->HasRight( +                                                      Object => $args{'Queue'}, +                                                      Right => 'CommentOnTicket' +                     ) +              ) { +                return ( $args{'CurrentUser'}, 0 ); +            } +        } +        elsif ( $args{'Action'} =~ /^correspond$/i ) { + +            # check to see whether "Everybody" or "Unprivileged users" can correspond on tickets +            unless ( $everyone->PrincipalObj->HasRight(Object => $args{'Queue'}, +                                                       Right  => 'ReplyToTicket' +                     ) +                     || $unpriv->PrincipalObj->HasRight( +                                                       Object => $args{'Queue'}, +                                                       Right  => 'ReplyToTicket' +                     ) +              ) { +                return ( $args{'CurrentUser'}, 0 ); +            } + +        } +        else { +            return ( $args{'CurrentUser'}, 0 ); +        } +    } + +    # We're creating a ticket +    elsif ( $args{'Queue'} && $args{'Queue'}->Id ) { + +        # check to see whether "Everybody" or "Unprivileged users" can create tickets in this queue +        unless ( $everyone->PrincipalObj->HasRight( Object => $args{'Queue'}, +                                                    Right  => 'CreateTicket' ) +                 || $unpriv->PrincipalObj->HasRight( Object => $args{'Queue'}, +                                                     Right  => 'CreateTicket' ) +          ) { +            return ( $args{'CurrentUser'}, 0 ); +        } + +    } + +    $CurrentUser = CreateUser( undef, $Address, $Name, $args{'Message'} ); + +    return ( $CurrentUser, 1 ); +} + +eval "require RT::Interface::Email::Auth::MailFrom_Vendor"; +die $@ if ($@ && $@ !~ qr{^Can't locate RT/Interface/Email/Auth/MailFrom_Vendor.pm}); +eval "require RT::Interface::Email::Auth::MailFrom_Local"; +die $@ if ($@ && $@ !~ qr{^Can't locate RT/Interface/Email/Auth/MailFrom_Local.pm}); + +1; diff --git a/rt/lib/RT/Interface/Email/Filter/SpamAssassin.pm b/rt/lib/RT/Interface/Email/Filter/SpamAssassin.pm new file mode 100644 index 000000000..f00e2d82b --- /dev/null +++ b/rt/lib/RT/Interface/Email/Filter/SpamAssassin.pm @@ -0,0 +1,63 @@ +# BEGIN LICENSE BLOCK +#  +# Copyright (c) 1996-2003 Jesse Vincent <jesse@bestpractical.com> +#  +# (Except where explictly superceded by other copyright notices) +#  +# This work is made available to you under the terms of Version 2 of +# the GNU General Public License. A copy of that license should have +# been provided with this software, but in any event can be snarfed +# from www.gnu.org. +#  +# This work is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU +# General Public License for more details. +#  +# Unless otherwise specified, all modifications, corrections or +# extensions to this work which alter its source code become the +# property of Best Practical Solutions, LLC when submitted for +# inclusion in the work. +#  +#  +# END LICENSE BLOCK +package RT::Interface::Email::Filter::SpamAssassin; + +use Mail::SpamAssassin; +my $spamtest = Mail::SpamAssassin->new(); + +sub GetCurrentUser { +    my $item = shift; +    my $status = $spamtest->check ($item); +    return (undef, 0) unless $status->is_spam(); +    eval { $status->rewrite_mail() }; +    if ($status->get_hits > $status->get_required_hits()*1.5) {  +        # Spammy indeed +        return (undef, -1); +    } +    return (undef, 0); +} + +=head1 NAME + +RT::Interface::Email::Filter::SpamAssassin - Spam filter for RT + +=head1 SYNOPSIS + +    @RT::MailPlugins = ("Filter::SpamAssassin", ...); + +=head1 DESCRIPTION + +This plugin checks to see if an incoming mail is spam (using +C<spamassassin>) and if so, rewrites its headers. If the mail is very +definitely spam - 1.5x more hits than required - then it is dropped on +the floor; otherwise, it is passed on as normal. + +=cut + +eval "require RT::Interface::Email::Filter::SpamAssassin_Vendor"; +die $@ if ($@ && $@ !~ qr{^Can't locate RT/Interface/Email/Filter/SpamAssassin_Vendor.pm}); +eval "require RT::Interface::Email::Filter::SpamAssassin_Local"; +die $@ if ($@ && $@ !~ qr{^Can't locate RT/Interface/Email/Filter/SpamAssassin_Local.pm}); + +1; | 
