aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--network/amavisd-new/README10
-rw-r--r--network/amavisd-new/README.SBo16
-rw-r--r--network/amavisd-new/amavisd-new.SlackBuild36
-rw-r--r--network/amavisd-new/amavisd-new.info8
-rw-r--r--network/amavisd-new/amavisd-signer.patch17
-rw-r--r--network/amavisd-new/doinst.sh22
-rw-r--r--network/amavisd-new/rc.amavisd-new42
7 files changed, 110 insertions, 41 deletions
diff --git a/network/amavisd-new/README b/network/amavisd-new/README
index 29e0a20246c7..28d1a8765272 100644
--- a/network/amavisd-new/README
+++ b/network/amavisd-new/README
@@ -4,10 +4,6 @@ or more content checkers: virus scanners, SpamAssassin and/or dkim signing.
Please refer to README.SBo for detailed instructions and dependencies before
running the build script.
-Script and package changes introduced in version >= 2.6.6
-1. logrotate file is renamed amavisd-new.
-2. rc script is renamed to rc.amavisd-new
-3. logfile in the logrotate script is renamed to amavisd-new.log. Make sure
- you change the logfile in the amavisd.conf file and rename the log file.
- Look for, $LOGFILE directive in the configuration file.
-4. Remember to update your rc.local and rc.local_shutdown scripts accordingly.
+This requires: perl-Convert-TNEF, perl-Convert-UUlib, perl-Convert-BinHex,
+perl-Archive-Zip, perl-IO-stringy, perl-MIME-tools, perl-Unix-Syslog,
+perl-BerkeleyDB, perl-IO-Multiplex.
diff --git a/network/amavisd-new/README.SBo b/network/amavisd-new/README.SBo
index bf8b7c8aab88..9e62de8f7885 100644
--- a/network/amavisd-new/README.SBo
+++ b/network/amavisd-new/README.SBo
@@ -45,6 +45,19 @@ perl-IO-stringy
perl-MIME-tools
perl-Unix-Syslog
perl-BerkeleyDB
+perl-IO-Multiplex
+
+SLACKBUILD CHANGELOG:
+Script and package changes introduced in version >= 2.6.6
+1. logrotate file is renamed amavisd-new.
+2. rc script is renamed to rc.amavisd-new
+3. logfile in the logrotate script is renamed to amavisd-new.log. Make sure
+ you change the logfile in the amavisd.conf file and rename the log file.
+ Look for, $LOGFILE directive in the configuration file.
+4. Remember to update your rc.local and rc.local_shutdown scripts accordingly.
+5. With version 2.7, a new process amavisd-signer is spawned to take care
+ of dkim signing. Please read RELEASE_NOTES in the documentation.
+
SETUP:
1. Create amavis user/group, before running the script.
@@ -54,7 +67,7 @@ SETUP:
2. Make sure you have write perms for amavis group to amavis home (in this
case, /var/lib/amavis)
-3. Create /var/log/amavisd-new.log file, change perms to allow write access
+3. Create /var/log/amavisd.log file, change perms to allow write access
to amavisd user/group.
4. Add amavis user to clamav group and set "AllowSupplementaryGroups yes"
@@ -70,3 +83,4 @@ SETUP:
7. You can turn on debugging in log file with $sa_debug configuration
variable in /etc/amavisd.conf.
+
diff --git a/network/amavisd-new/amavisd-new.SlackBuild b/network/amavisd-new/amavisd-new.SlackBuild
index 2676af027ff4..7a8665d168ab 100644
--- a/network/amavisd-new/amavisd-new.SlackBuild
+++ b/network/amavisd-new/amavisd-new.SlackBuild
@@ -3,7 +3,7 @@
# Slackware Package Build Script for amavisd-new
# Home Page http://www.ijs.si/software/amavisd/
-# Copyright (c) 2009-2011, Nishant Limbachia, Hoffman Estates, IL, USA
+# Copyright (c) 2009-2012, Nishant Limbachia, Hoffman Estates, IL, USA
# <nishant _AT_ mnspace _DOT_ net>
# All rights reserved.
@@ -26,11 +26,12 @@
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
PRGNAM="amavisd-new"
-VERSION=${VERSION:-2.6.6}
-ARCH="noarch"
+VERSION=${VERSION:-2.7.1}
BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
+ARCH="noarch"
+
CWD=$(pwd)
TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
@@ -38,6 +39,20 @@ OUTPUT=${OUTPUT:-/tmp}
set -e
+if [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIRSUFFIX="64"
+else
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+fi
+
# Create system user and group for amavisd-new
if ! grep -q ^amavis: /etc/group ; then
echo " Please add a dedicated group to run amavisd-new"
@@ -64,11 +79,12 @@ QUARANTINE_DIR=${QUARANTINE_DIR:-$AMAVIS_HOME/quarantine}
DOCS="AAAREADME.first INSTALL TODO amavisd*.conf* LDAP*
RELEASE_NOTES LICENSE README_FILES test-messages"
-rm -fr $TMP/$PRGNAM-$VERSION $PKG
+rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
cd $TMP
+rm -rf $PRGNAM-$VERSION
tar xvf $CWD/$PRGNAM-$VERSION.tar.?z*
-cd $TMP/$PRGNAM-$VERSION
+cd $PRGNAM-$VERSION
chown -R root.root .
find . \
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
@@ -91,8 +107,11 @@ mkdir -p $PKG/$QUARANTINE_DIR/{clean,spam,banned,badh,virus}
mkdir -p $PKG/usr/{sbin,doc/$PRGNAM-$VERSION}
install -m 0755 -D amavisd $PKG/usr/sbin/$PRGNAM
( cd $PKG/usr/sbin; ln -sf $PRGNAM amavisd )
-install -m 0755 amavisd-agent amavisd-nanny amavisd-release \
- amavisd-snmp-subagent p0f-analyzer.pl $PKG/usr/sbin
+
+patch -p0 < $CWD/amavisd-signer.patch
+
+install -m 0755 amavisd-agent amavisd-nanny amavisd-release amavisd-signer \
+ amavisd-snmp-subagent amavisd-submit p0f-analyzer.pl $PKG/usr/sbin
install -m 0640 -D amavisd.conf $PKG/etc/amavisd.conf.new
# change permissions
@@ -100,7 +119,8 @@ chown $USER:$GROUP $PKG/etc/amavisd.conf.new
chown -R $USER:$GROUP $PKG/$AMAVIS_HOME $PKG/var/run/amavis $PKG/$QUARANTINE_DIR
chmod -R 0770 $PKG/$AMAVIS_HOME $PKG/var/run/amavis $PKG/$QUARANTINE_DIR
-cp -a $DOCS $PKG/usr/doc/$PRGNAM-$VERSION
+cp -r $DOCS $PKG/usr/doc/$PRGNAM-$VERSION
+chmod -R +r $PKG/usr/doc/$PRGNAM-$VERSION
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
### install rc script
diff --git a/network/amavisd-new/amavisd-new.info b/network/amavisd-new/amavisd-new.info
index 34906b3bde0a..3efdf7510c7c 100644
--- a/network/amavisd-new/amavisd-new.info
+++ b/network/amavisd-new/amavisd-new.info
@@ -1,10 +1,10 @@
PRGNAM="amavisd-new"
-VERSION="2.6.6"
+VERSION="2.7.1"
HOMEPAGE="http://www.ijs.si/software/amavisd/"
-DOWNLOAD="http://www.ijs.si/software/amavisd/amavisd-new-2.6.6.tar.gz"
-MD5SUM="6bddb725115c2682110b82d41494df73"
+DOWNLOAD="http://www.ijs.si/software/amavisd/amavisd-new-2.7.1.tar.gz"
+MD5SUM="87cd516d1c6349a4389947fb949ff1a2"
DOWNLOAD_x86_64=""
MD5SUM_x86_64=""
MAINTAINER="Nishant Limbachia"
EMAIL="nishant@mnspace.net"
-APPROVED="Niels Horn"
+APPROVED="dsomero"
diff --git a/network/amavisd-new/amavisd-signer.patch b/network/amavisd-new/amavisd-signer.patch
new file mode 100644
index 000000000000..a45110c8ad58
--- /dev/null
+++ b/network/amavisd-new/amavisd-signer.patch
@@ -0,0 +1,17 @@
+--- amavisd-signer.orig 2012-05-04 22:27:39.397598579 -0500
++++ amavisd-signer 2012-05-04 22:28:55.609603047 -0500
+@@ -83,11 +83,11 @@
+ # Please adjust the following settings as necessary:
+ #
+
+-$daemon_user = 'vscan';
+-$daemon_group = 'vscan';
++$daemon_user = 'amavis';
++$daemon_group = 'amavis';
+ # $daemon_chroot_dir = '/var/amavis'; # chroot directory or undef
+
+-# $daemonize = 1;
++$daemonize = 1;
+
+ $log_level = 2; # 0..5
+ $syslog_facility = 'mail';
diff --git a/network/amavisd-new/doinst.sh b/network/amavisd-new/doinst.sh
index 637ab6bc8260..ad648167ec14 100644
--- a/network/amavisd-new/doinst.sh
+++ b/network/amavisd-new/doinst.sh
@@ -11,13 +11,17 @@ config() {
# Otherwise, we leave the .new copy for the admin to consider...
}
-# Keep same perms on rc.amavisd.new:
-if [ -e etc/rc.d/rc.amavisd-new ]; then
- cp -a etc/rc.d/rc.amavisd-new etc/rc.d/rc.amavisd-new.new.incoming
- cat etc/rc.d/rc.amavisd-new.new > etc/rc.d/rc.amavisd-new.new.incoming
- mv etc/rc.d/rc.amavisd-new.new.incoming etc/rc.d/rc.amavisd-new.new
-fi
+preserve_perms() {
+ NEW="$1"
+ OLD="$(dirname $NEW)/$(basename $NEW .new)"
+ if [ -e $OLD ]; then
+ cp -a $OLD ${NEW}.incoming
+ cat $NEW > ${NEW}.incoming
+ mv ${NEW}.incoming $NEW
+ fi
+ config $NEW
+}
-config etc/rc.d/rc.amavisd-new.new
-config etc/amavisd.conf.new
-config etc/logrotate.d/amavisd-new.new
+preserve_perms etc/rc.d/rc.amavisd-new.new
+preserve_perms etc/amavisd.conf.new
+preserve_perms etc/logrotate.d/amavisd-new.new
diff --git a/network/amavisd-new/rc.amavisd-new b/network/amavisd-new/rc.amavisd-new
index 9d0de3dd68ca..3410eb18c26e 100644
--- a/network/amavisd-new/rc.amavisd-new
+++ b/network/amavisd-new/rc.amavisd-new
@@ -1,31 +1,42 @@
#!/bin/sh
-# Copyright (c) 2008-2011, Nishant Limbachia, Hoffman Estates, IL, USA
-# <nishant _AT_ mnspace _DOT_ net>
-# /etc/rc.d/rc.amavisd
-# start|stop|restart|status for amavisd-new
-# For automatic start at boot up, call this script from rc.local
+# Startup script for amavisd-new daemon for use on Slackware Linux x86|x86_64
+
+# Copyright (c) 2008-2012, Nishant Limbachia, Hoffman Estates, IL, USA
+# [nishant _AT_ mnspace _DOT_ net]
+# Usage: /etc/rc.d/rc.amavisd-new start|stop|restart|reload|status
+# For automatic startup at boot, call this script from rc.local
PIDFILE=/var/run/amavis/amavisd.pid
amavisd_start() {
if [ -x /etc/rc.d/rc.amavisd-new ]; then
+ # start amavisd-signer first
+ echo "Starting amavisd-signer daemon"
+ /usr/sbin/amavisd-signer
+
if [ -f $PIDFILE ]; then
echo "amavisd-new daemon running with PID: $(cat $PIDFILE)"
- echo "try /etc/rc.d/rc.amavisd-new stop|restart"
+ echo "Or we may have a stale pid file from previous run"
+ echo "try /etc/rc.d/rc.amavisd-new stop|restart Or"
+ echo "remove the stale pid file and try starting again"
echo ""
exit 1
else
echo "Starting amavisd-new daemon"
- /usr/sbin/amavisd start
+ /usr/sbin/amavisd-new start
fi
fi
}
amavisd_stop() {
+ # stop amavisd-signer first
+ echo "Stopping amavisd-signer daemon"
+ pkill amavisd-signer
+
if [ -f $PIDFILE ]; then
echo "Stopping amavisd-new daemon"
- /usr/sbin/amavisd stop
+ /usr/sbin/amavisd-new stop
else
echo "amavisd-new daemon is not running"
fi
@@ -33,13 +44,17 @@ amavisd_stop() {
amavisd_restart() {
echo "Restarting amavisd-new daemon"
- amavisd_stop
- sleep 5
- amavisd_start
+ /usr/sbin/amavisd-new restart
+}
+
+amavisd_reload() {
+ echo "Reloading amavisd-new daemon"
+ /usr/sbin/amavisd-new reload
}
amavisd_status() {
echo "amavisd-new daemon running with PID: $(cat $PIDFILE)"
+ echo "amavisd-signer daemon running with PID: $(pgrep amavisd-signer)"
}
case "$1" in
@@ -52,11 +67,14 @@ case "$1" in
'restart')
amavisd_restart
;;
+'reload')
+ amavisd_reload
+ ;;
'status')
amavisd_status
;;
*)
- echo "USAGE: $0 start|stop|restart|status"
+ echo "USAGE: $0 start|stop|restart|reload|status"
exit 1
;;
esac