snort/snort-update.sh

Wed, 08 Feb 2012 20:07:00 +0200

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 08 Feb 2012 20:07:00 +0200
changeset 588
300d43423c2e
permissions
-rw-r--r--

Update version, adapt patch, correct PID writing, correct build on newer
FreeBSD releases, and most importantly introduce new patch to try to
avoid segfault caused by multiple network interfaces with the same (or
no) address. This is common when configuring bridges and tunnels.

     1 #!/bin/sh
     2 ##
     3 ##  snort-update.sh -- Snort Rule Updating Utility
     4 ##  Copyright (c) 2005-2007 Ralf S. Engelschall <rse@engelschall.com> 
     5 ##
     7 #   command line parameters
     8 url="$1"
     9 if [ ".$url" = . ]; then
    10     echo "USAGE: $0 <url>" 1>&2
    11     exit 1
    12 fi
    14 #   configuration
    15 rulesdir="@l_prefix@/var/snort/rules"
    16 tmpdir="@l_prefix@/var/snort/tmp"
    17 oinkmaster="@l_prefix@/sbin/oinkmaster"
    18 logfile="@l_prefix@/var/snort/oinkmaster.log"
    19 statsfile="@l_prefix@/var/snort/snort.stats"
    21 #   parameter post-processing
    22 url=`echo "$url" |\
    23      sed -e 's;^oinkcode:\(.*\)$;http://www.snort.org/pub-bin/oinkmaster.cgi/\1/snortrules-snapshot-@V_rules@.tar.gz;' \
    24          -e 's;^\(/.*\)$;file://\1;'`
    26 #   ruleset updating
    27 ( echo "++ SNORT-UPDATE START (`date`)"
    28   echo "++ Update URL: \"$url\""
    29   $oinkmaster -q -o $rulesdir -u $url
    30   if [ ! -f $rulesdir/local.rules ]; then
    31       touch $rulesdir/local.rules
    32   fi
    33   @l_prefix@/lib/openpkg/shtool subst \
    34       -e 's;\(var HOME_NET\) any;\1 $(HOME_NET:-any);' \
    35       -e 's;\(var EXTERNAL_NET\) any;\1 $(EXTERNAL_NET:-any);' \
    36       -e 's; \([^ /]*\.map\); $(RULE_PATH)/\1;' \
    37       -e 's; \([^ /]*\.config\); $(RULE_PATH)/\1;' \
    38       -e "s;\\(var RULE_PATH\\).*;\\1 \$(RULE_PATH:-$rulesdir);" \
    39       -e "s;/var/snort/snort\.stats;$statsfile;" \
    40       $rulesdir/snort.conf
    41   echo "++ SNORT-UPDATE END (`date`)"
    42 ) >>$logfile 2>&1

mercurial