]> git.sesse.net Git - nms/commitdiff
Refactor a bit into a module.
authorroot <root@sysrq>
Tue, 3 Apr 2007 09:40:10 +0000 (11:40 +0200)
committerroot <root@sysrq>
Tue, 3 Apr 2007 09:40:10 +0000 (11:40 +0200)
mbd/mbd.pl
mbd/mbd.pm [new file with mode: 0644]

index 90ee4d6b63bc50bc6cb9b2f7fbb765d2512b7d96..0993e436fd7819371c38f0f5a77ad7c8fc58ae9e 100644 (file)
@@ -6,30 +6,7 @@ use Net::CIDR;
 use Net::RawIP;
 require './access_list.pl';
 require './nets.pl';
-
-sub expand_range {
-       my $range = shift;
-
-       if ($range =~ /^(\d+)\.\.(\d+)$/) {
-               return $1..$2;
-       } else {
-               return $range;
-       }
-}
-
-sub match_ranges {
-       my ($elem, $ranges) = @_;
-       
-       for my $range (@$ranges) {
-               if ($range =~ /^(\d+)\.\.(\d+)$/) {
-                       return 1 if ($elem >= $1 && $elem <= $2);
-               } else {
-                       return 1 if ($elem == $range);
-               }
-       }
-
-       return 0;
-}
+require './mbd.pm';
 
 sub fhbits {
        my $bits = 0;
@@ -39,16 +16,7 @@ sub fhbits {
        return $bits;
 }
 
-# Find what ports we need to listen on
-my %port_hash = ();
-for my $e (@Config::access_list) {
-       for my $r (@{$e->{'ports'}}) {
-               for my $p (expand_range($r)) {
-                       $port_hash{$p} = 1;
-               }
-       }
-}
-my @ports = sort { $a <=> $b } keys %port_hash;
+my @ports = mbd::find_all_ports();
 
 # Open a socket for each port
 my @socks = ();
diff --git a/mbd/mbd.pm b/mbd/mbd.pm
new file mode 100644 (file)
index 0000000..b844e5b
--- /dev/null
@@ -0,0 +1,50 @@
+#! /usr/bin/perl
+use strict;
+use warnings;
+use Socket;
+use Net::CIDR;
+use Net::RawIP;
+require './access_list.pl';
+require './nets.pl';
+
+package mbd;
+
+sub expand_range {
+       my $range = shift;
+
+       if ($range =~ /^(\d+)\.\.(\d+)$/) {
+               return $1..$2;
+       } else {
+               return $range;
+       }
+}
+
+sub match_ranges {
+       my ($elem, $ranges) = @_;
+       
+       for my $range (@$ranges) {
+               if ($range =~ /^(\d+)\.\.(\d+)$/) {
+                       return 1 if ($elem >= $1 && $elem <= $2);
+               } else {
+                       return 1 if ($elem == $range);
+               }
+       }
+
+       return 0;
+}
+
+sub find_all_ports {
+       # Find what ports we need to listen on
+       my %port_hash = ();
+       for my $e (@Config::access_list) {
+               for my $r (@{$e->{'ports'}}) {
+                       for my $p (expand_range($r)) {
+                               $port_hash{$p} = 1;
+                       }
+               }
+       }
+       my @ports = sort { $a <=> $b } keys %port_hash;
+       return @ports;
+}
+
+1;