From 942b9047343a178386167abe83283cb64502c07e Mon Sep 17 00:00:00 2001 From: minima Date: Mon, 9 Oct 2006 15:01:40 +0000 Subject: [PATCH] fix problems with empty/corrupt filters --- Changes | 2 ++ perl/Filter.pm | 27 ++++++++++++++++++--------- 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/Changes b/Changes index 9e9106dc..00e5fb9c 100644 --- a/Changes +++ b/Changes @@ -1,3 +1,5 @@ +09Oct06======================================================================= +1. fix problems with bad filters pointed by Thomas DL3SBB. 27Jul06======================================================================= 1. merge in official issue version of wpxloc.raw (with one change: 4U1V). 26Jul06======================================================================= diff --git a/perl/Filter.pm b/perl/Filter.pm index 74f74d44..3009883b 100644 --- a/perl/Filter.pm +++ b/perl/Filter.pm @@ -35,8 +35,10 @@ use Prefix; use strict; use vars qw($VERSION $BRANCH); - -main::mkver($VERSION = q$Revision$); +$VERSION = sprintf( "%d.%03d", q$Revision$ =~ /(\d+)\.(\d+)/ ); +$BRANCH = sprintf( "%d.%03d", q$Revision$ =~ /\d+\.\d+\.(\d+)\.(\d+)/ || (0,0)); +$main::build += $VERSION; +$main::branch += $BRANCH; use vars qw ($filterbasefn $in); @@ -114,17 +116,25 @@ sub read_in $in = undef; my $s = readfilestr($fn); my $newin = eval $s; - dbg($@) if $@; + if ($@) { + dbg($@); + unlink($fn); + return undef; + } if ($in) { $newin = new('Filter::Old', $sort, $call, $flag); $newin->{filter} = $in; - } else { + } elsif (ref $newin && $newin->can('getfilkeys')) { my $filter; my $key; foreach $key ($newin->getfilkeys) { $newin->compile($key, 'reject'); $newin->compile($key, 'accept'); } + } else { + # error on reading file, delete and exit + unlink($fn); + return undef; } return $newin; } @@ -196,7 +206,6 @@ sub it my $key; my $type = 'Dunno'; my $asc = '?'; - my $data = ref $_[0] ? shift : \@_; my $r = @keys > 0 ? 0 : 1; foreach $key (@keys) { @@ -204,7 +213,7 @@ sub it if ($filter->{reject} && exists $filter->{reject}->{code}) { $type = 'reject'; $asc = $filter->{reject}->{user}; - if (&{$filter->{reject}->{code}}($data)) { + if (&{$filter->{reject}->{code}}(\@_)) { $r = 0; last; } else { @@ -214,7 +223,7 @@ sub it if ($filter->{accept} && exists $filter->{accept}->{code}) { $type = 'accept'; $asc = $filter->{accept}->{user}; - if (&{$filter->{accept}->{code}}($data)) { + if (&{$filter->{accept}->{code}}(\@_)) { $r = 1; last; } else { @@ -227,7 +236,7 @@ sub it my $hops = $self->{hops} if exists $self->{hops}; if (isdbg('filter')) { - my $args = join '\',\'', map {defined $_ ? $_ : 'undef'} @$data; + my $args = join '\',\'', map {defined $_ ? $_ : 'undef'} @_; my $true = $r ? "OK " : "REJ"; my $sort = $self->{sort}; my $dir = $self->{name} =~ /^in_/i ? "IN " : "OUT"; @@ -302,7 +311,7 @@ sub install my $dxchan; my @dxchan; if ($name eq 'NODE_DEFAULT') { - @dxchan = grep{$_->is_node || $_->is_aranea} DXChannel::get_all(); + @dxchan = DXChannel::get_all_nodes(); } elsif ($name eq 'USER_DEFAULT') { @dxchan = DXChannel::get_all_users(); } else { -- 2.43.0