source: trunk/dnsbl/export-dnsbl@ 3

Last change on this file since 3 was 3, checked in by Kris Deugau, 15 years ago

/trunk/dnsbl

Fix another behavioural bug in export - don't export all classful entries

in a CIDR block if that block isn't OOB or volume-listed itself

Irrelevant test-case selections added in browse.cgi and export-dnsbl
Fix export for rbldnsd by passing the mode to export() on full export
Checkpoint segment of export-dnsbl that may not be needed due to above

  • Property svn:executable set to *
  • Property svn:keywords set to Date Rev Author Id
File size: 2.5 KB
Line 
1#!/usr/bin/perl
2# Export DNSBL data
3# 2009/05/26 kdeugau@deepnet.cx
4# need to stub it out so it can use a module to actually write zone
5# data for different NS software
6# completed 2008/08/14
7
8use strict;
9use warnings;
10use DBI;
11
12use DNSBL;
13
14my $dnsbl = new DNSBL;
15
16$dnsbl->connect;
17
18my %iplist;
19my $ipref = \%iplist;
20
21my $mode = $ARGV[0] || 'tiny';
22
23#$dnsbl->export($ipref,$mode,1,'65.60/18');
24#$dnsbl->export($ipref,$mode,1,'67.136.0.0/14');
25#$dnsbl->export($ipref,$mode,1,'83.76/15');
26#$dnsbl->export($ipref,$mode,1,'76.73.0.0/17');
27#$dnsbl->export($ipref,$mode,1,'174.36.0.0/15');
28$dnsbl->export($ipref,$mode);
29
30##fixme - mode should pick actual output, not just export mode
31if ($mode eq 'cidr') {
32 # more or less raw CIDR block-and-IP info
33 foreach (sort ipcmp keys %iplist) {
34 print "$_:127.0.0.$iplist{$_}:".
35 ($iplist{$_} & 2 ? '$ relayed a reported spam' : 'Netblock listed on one or more criteria')."\n";
36 }
37} elsif ($mode eq 'rbldnsd') {
38 # need extra cmd args
39 die "need subgroup spec (iplist, cidrlist) as well\n" if !$ARGV[1];
40 if ($ARGV[1] eq 'iplist') {
41 foreach (sort ipcmp keys %iplist) {
42 print "$_:127.0.0.$iplist{$_}:\$ relayed a reported spam\n" if $iplist{$_} & 2;
43 }
44 } elsif ($ARGV[1] eq 'cidrlist') {
45 foreach (sort ipcmp keys %iplist) {
46 print "$_:127.0.0.$iplist{$_}:Netblock listed on one or more criteria\n" if ! ($iplist{$_} & 2);
47 }
48 }
49 # no output if second arg is unknown.
50} else {
51 foreach (sort ipcmp keys %iplist) {
52#foreach (sort keys %iplist) {
53 my ($o1,$o2,$o3,$o4) = (/^(\d+)\.([\d*]+)(?:\.([\d*]+)(?:\.([\d*]+))?)?$/);
54 print "+".(defined($o4) ? "$o4." : '').(defined($o3) ? "$o3." : '').(defined($o2) ? "$o2." : '').
55 "$o1.spamhosts.company.com:127.0.0.$iplist{$_}:900:::\n";
56 }
57}
58
59exit 0;
60
61# IP address comparison sub
62sub ipcmp {
63 my ($a1,$a2,$a3,$a4,$a5) = ($a =~ /^(\d+)\.([\d*]+)(?:\.([\d*]+)(?:\.([\d*]+))?)?(?:\/(\d+))?$/);
64 my ($b1,$b2,$b3,$b4,$b5) = ($b =~ /^(\d+)\.([\d*]+)(?:\.([\d*]+)(?:\.([\d*]+))?)?(?:\/(\d+))?$/);
65# le sigh. knew it wasn't going to be simple...
66 $b2 = -1 if $b2 && $b2 eq '*';
67 $b3 = -1 if $b3 && $b3 eq '*';
68 $b4 = -1 if $b4 && $b4 eq '*';
69 $b5 = 128 if !defined($b5);
70 $a2 = -1 if $a2 && $a2 eq '*';
71 $a3 = -1 if $a3 && $a3 eq '*';
72 $a4 = -1 if $a4 && $a4 eq '*';
73 $a5 = 128 if !defined($a5);
74 return 1 if $a1 > $b1;
75 return -1 if $a1 < $b1;
76 return 1 if $a2 > $b2;
77 return -1 if $a2 < $b2;
78 return 1 if $a3 > $b3;
79 return -1 if $a3 < $b3;
80 return 1 if $a4 > $b4;
81 return -1 if $a4 < $b4;
82 return 1 if $a5 > $b5;
83 return -1 if $a5 < $b5;
84 return 0;
85}
Note: See TracBrowser for help on using the repository browser.