X-Git-Url: https://defaria.com/gitweb/?a=blobdiff_plain;f=maps%2Fbin%2Fadd2blacklist.cgi;h=cbc395f0465095d46c9e4aaf361781a527bf0224;hb=fabecda8b02db16f5321ae8b958b3bc3ac30a49c;hp=06c81250f438a3328c2c4db388493d34dcfdf417;hpb=4e9f478e1417a38297ea9d3d659d9ce4cd572a57;p=clearscm.git diff --git a/maps/bin/add2blacklist.cgi b/maps/bin/add2blacklist.cgi index 06c8125..cbc395f 100755 --- a/maps/bin/add2blacklist.cgi +++ b/maps/bin/add2blacklist.cgi @@ -16,92 +16,123 @@ use strict; use warnings; use FindBin; -$0 = $FindBin::Script; +local $0 = $FindBin::Script; use lib "$FindBin::Bin/../lib"; +use lib "$FindBin::Bin/../../lib"; + +use Utils; use MAPS; use MAPSLog; use MAPSWeb; -use MAPSUtil; use CGI qw/:standard *table/; use CGI::Carp 'fatalsToBrowser'; -my $userid; -my $Userid; -my $type = 'black'; +sub Add2List(%) { + my (%rec) = @_; + + CheckParms(['userid', 'type'], \%rec); -sub Add2List() { - my $sender = ''; - my $nextseq = GetNextSequenceNo($userid, $type); + my $nextseq = GetNextSequenceNo(%rec); + + my $Userid = ucfirst $rec{userid}; while () { - my $pattern = param "pattern$nextseq"; - my $domain = param "domain$nextseq"; - my $comment = param "comment$nextseq"; + $rec{pattern} = param "pattern$nextseq"; + $rec{domain} = param "domain$nextseq"; + $rec{comment} = param "comment$nextseq"; + $rec{hit_count} = param "hit_count$nextseq"; + $rec{retention} = param "retention$nextseq"; - last if ((!defined $pattern || $pattern eq '') && - (!defined $domain || $domain eq '')); + last unless $rec{pattern} or $rec{domain}; - $sender = CheckEmail $pattern, $domain; + $rec{sender} = CheckEmail $rec{pattern}, $rec{domain}; - my ($status, $rule) = OnBlacklist($sender); + my ($status) = OnBlacklist($rec{sender}); - if ($status != 0) { - print br {-class => 'error'}, "The email address $sender is already on ${Userid}'s $type list"; + if ($status) { + print br {-class => 'error'}, + "The email address $rec{sender} is already on ${Userid}'s $rec{type} list"; } else { - Add2Blacklist($sender, $userid, $comment); - print br "The email address, $sender, has been added to ${Userid}'s $type list"; + my ($messages, $msg) = Add2Blacklist(%rec); + + if ($messages < -1) { + print br {-class => 'error'}, "Unable to add $rec{sender} to $rec{type} list"; + return; + } else { + print br "The email address, $rec{sender}, has been added to ${Userid}'s $rec{type} list"; + } # if # Now remove this entry from the other lists (if present) for my $otherlist ('white', 'null') { - my $sth = FindList $otherlist, $sender; - my ($sequence, $count); + FindList( + userid => $rec{userid}, + type => $otherlist, + sender => $rec{sender}, + ); + + my $seq = GetList; - ($_, $_, $_, $_, $_, $sequence) = GetList($sth); + if ($seq->{sequence}) { + my $err; - if ($sequence) { - $count = DeleteList($otherlist, $sequence); - print br "Removed $sender from ${Userid}'s " . ucfirst $otherlist . ' list' - if $count > 0; + ($err, $msg) = DeleteList( + userid => $rec{userid}, + type => $otherlist, + sequence => $seq->{sequence}, + ); - ResequenceList($userid, $otherlist); + croak $msg if $err < 0; + + print br "Removed $rec{sender} from ${Userid}'s " . ucfirst $otherlist . ' list' + if $err > 0; + + ResequenceList( + userid => $rec{userid}, + type => $otherlist, + ); } # if } # for } # if $nextseq++; } # while + + return; } # Add2List # Main -$userid = Heading( +my $userid = Heading( 'getcookie', '', 'Add to Black List', 'Add to Black List', ); -$Userid = ucfirst $userid; +$userid ||= $ENV{USER}; + +my $type = 'black'; SetContext($userid); NavigationBar($userid); -Add2List; +Add2List( + userid => $userid, + type => $type, +); print start_form { - -method => 'post', - -action => 'processaction.cgi', - -name => 'list' + -method => 'post', + -action => 'processaction.cgi', + -name => 'list', }; print '

', - hidden ({-name => 'type', - -default => $type}), - submit ({-name => 'action', - -value => 'Add'}), + hidden ({-name => 'type', -default => $type}), + submit ({-name => 'action', -value => 'Add'}), '
'; Footing;