aboutsummaryrefslogtreecommitdiff
path: root/network
diff options
context:
space:
mode:
authorDuncan Roe <duncan_roe@optusnet.com.au>2017-06-22 17:26:08 +0700
committerWilly Sudiarto Raharjo <willysr@slackbuilds.org>2017-06-24 08:32:21 +0700
commit888ec031aca7e4f81a72497f9ebc0259e07621cb (patch)
tree0fcfcba8c18643f6a6111d70b341326312acc27e /network
parenta8e78c52c72b342c5436f5ff39148a3f2e68f7ee (diff)
network/netqmail: Added (the qmail MTA).
Signed-off-by: Willy Sudiarto Raharjo <willysr@slackbuilds.org>
Diffstat (limited to 'network')
-rw-r--r--network/netqmail/LWQ_scripts/inst_check305
-rw-r--r--network/netqmail/LWQ_scripts/qmail-send-log-run2
-rw-r--r--network/netqmail/LWQ_scripts/qmail-send-run2
-rw-r--r--network/netqmail/LWQ_scripts/qmail-smtpd-log-run2
-rw-r--r--network/netqmail/LWQ_scripts/qmail-smtpd-run22
-rw-r--r--network/netqmail/LWQ_scripts/qmailctl-script-dt70109
-rw-r--r--network/netqmail/LWQ_scripts/rc7
-rw-r--r--network/netqmail/README17
-rw-r--r--network/netqmail/README.SBo88
-rw-r--r--network/netqmail/doinst.sh1
-rw-r--r--network/netqmail/doinst_config30
-rw-r--r--network/netqmail/doinst_new9
-rw-r--r--network/netqmail/doinst_service12
-rw-r--r--network/netqmail/doinst_users18
-rw-r--r--network/netqmail/dot_new.patch97
-rw-r--r--network/netqmail/fix_paths.patch55
-rw-r--r--network/netqmail/netqmail.SlackBuild271
-rw-r--r--network/netqmail/netqmail.info10
-rw-r--r--network/netqmail/slack-desc19
-rw-r--r--network/netqmail/tests/README31
-rw-r--r--network/netqmail/tests/makechroot74
-rw-r--r--network/netqmail/useradd_functions10
22 files changed, 1191 insertions, 0 deletions
diff --git a/network/netqmail/LWQ_scripts/inst_check b/network/netqmail/LWQ_scripts/inst_check
new file mode 100644
index 0000000000000..dec4627ccc31f
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/inst_check
@@ -0,0 +1,305 @@
+#!/bin/sh
+
+# Dave Sill, 2003-11-10
+# http://lifewithqmail.org/inst_check
+
+# set to n if you're not running a pop3 server, y if you are
+CHECKPOP=n
+
+QMHOME=/var/qmail
+LBIN=/usr/bin
+
+OK=1
+
+if [ $# -eq 1 ]; then
+ if [ "$1" = "-v" ]; then
+ VERB=y
+ else
+ VERB=n
+ fi
+fi
+
+if [ ! -d $QMHOME ]; then
+ echo "! Couldn't find qmail's home directory, $QMHOME!"
+else
+ if [ "$VERB" = y ]; then
+ echo "$QMHOME exists"
+ fi
+ for i in alias bin boot control queue supervise users; do
+ if [ ! -d $QMHOME/$i ]; then
+ echo "! Couldn't find $QMHOME/$i!"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$QMHOME/$i exists"
+ fi
+ done
+
+ if [ ! -f $QMHOME/rc ]; then
+ echo "! $QMHOME/rc is missing"
+ OK=0
+ elif [ ! -x $QMHOME/rc ]; then
+ echo "! $QMHOME/rc is not executable"
+ echo "...try: chmod 755 $QMHOME/rc"
+ OK=0
+ elif [ `head -1 $QMHOME/rc|cat -vet` != '#!/bin/sh$' ]; then
+ echo "! $QMHOME/rc has bad magic cookie"
+ echo "...try: dos2unix $QMHOME/rc"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$QMHOME/rc is executable and has a valid magic cookie"
+ fi
+fi
+
+for i in alias qmaild qmaill qmailp qmailq qmailr qmails; do
+ grep "^$i:" /etc/passwd >/dev/null
+ if [ $? -ne 0 ]; then
+ echo "! Couldn't find $i user in /etc/passwd"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i user exists"
+ fi
+done
+
+for i in qmail nofiles; do
+ grep "^$i:" /etc/group >/dev/null
+ if [ $? -ne 0 ]; then
+ echo "! Couldn't find $i group in /etc/group"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i group exists"
+ fi
+done
+
+for i in tcprules tcpserver; do
+ if [ ! -x $LBIN/$i ]; then
+ echo "! Couldn't find $LBIN/$i from ucspi-tcp"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i from ucspi-tcp is installed"
+ fi
+done
+
+for i in multilog softlimit setuidgid supervise svok svscan tai64nlocal; do
+ if [ ! -x $LBIN/$i ]; then
+ echo "! Couldn't find $LBIN/$i from daemontools"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i from daemontools is installed"
+fi
+done
+
+if [ ! -d /service ]; then
+ echo "! /service directory is missing"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "/service directory exists"
+fi
+
+if [ -f /etc/inittab ]; then
+ grep "^SV" /etc/inittab >/dev/null
+ if [ $? -ne 0 ]; then
+ echo "! Couldn't find SV entry in inittab"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "svscan /service is configured to run via /etc/inittab"
+ fi
+ PS="ps -ef"
+else
+ grep "svscanboot" /etc/rc.local >/dev/null
+ if [ $? -ne 0 ]; then
+ echo "! Couldn't find 'csh -cf '/command/svscanboot &' in /etc/rc.local"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "/command/svscanboot is configured to run via /etc/rc.local"
+ fi
+ PS="ps -waux"
+fi
+
+SVRUN=`$PS | grep "svscan /service" | grep -v grep`
+if [ -z "$SVRUN" ]; then
+ echo "'! svscan /service' doesn't seem to be running"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "svscan /service is running"
+fi
+
+if [ ! -f $QMHOME/control/defaultdelivery ]; then
+ echo "! Couldn't find $QMHOME/control/defaultdelivery"
+ OK=0
+elif [ ! -s $QMHOME/control/defaultdelivery ]; then
+ echo "! $QMHOME/control/defaultdelivery is empty"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "$QMHOME/control/defaultdelivery looks OK"
+fi
+
+if [ ! -f $QMHOME/bin/qmailctl ]; then
+ echo "! $QMHOME/bin/qmailctl is missing"
+ OK=0
+elif [ ! -s $QMHOME/bin/qmailctl ]; then
+ echo "! $QMHOME/bin/qmailctl is empty"
+ OK=0
+elif [ `head -1 $QMHOME/bin/qmailctl|cat -vet` != '#!/bin/sh$' ]; then
+ echo "! $QMHOME/bin/qmailctl has bad magic cookie"
+ echo "...try: dos2unix $QMHOME/bin/qmailctl"
+ OK=0
+elif [ ! -x $QMHOME/bin/qmailctl ]; then
+ echo "! $QMHOME/bin/qmailctl is not executable"
+ echo "...try: chmod 755 $QMHOME/bin/qmailctl"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "$QMHOME/bin/qmailctl looks OK"
+fi
+if [ ! -L /usr/bin/qmailctl ]; then
+ echo "! /usr/bin/qmailctl is missing"
+ echo "...try: ln -s $QMHOME/bin/qmailctl /usr/bin"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "/usr/bin/qmailctl exists"
+fi
+
+SVCDIRS="qmail-send qmail-send/log qmail-smtpd qmail-smtpd/log"
+if [ "$CHECKPOP" = "y" ]; then
+ SVCDIRS="$SVCDIRS qmail-pop3d qmail-pop3d/log"
+fi
+for i in $SVCDIRS; do
+ if [ ! -f $QMHOME/supervise/$i/run ]; then
+ echo "! $QMHOME/supervise/$i/run file is missing"
+ OK=0
+ elif [ `head -1 $QMHOME/supervise/$i/run|cat -vet` != '#!/bin/sh$' ]; then
+ echo "! $QMHOME/supervise/$i/run has bad magic cookie"
+ echo "...try: dos2unix $QMHOME/supervise/$i/run"
+ OK=0
+ elif [ ! -x $QMHOME/supervise/$i/run ]; then
+ echo "! $QMHOME/supervise/$i/run file is not executable"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$QMHOME/supervise/$i/run looks OK"
+ fi
+done
+
+if [ ! -f $QMHOME/control/concurrencyincoming ]; then
+ echo "! $QMHOME/control/concurrencyincoming is missing"
+ echo "...try: echo 20 >$QMHOME/control/concurrencyincoming"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "$QMHOME/control/concurrencyincoming looks OK"
+fi
+
+LOGDIRS="/var/log/qmail /var/log/qmail/smtpd"
+if [ "$CHECKPOP" = "y" ]; then
+ LOGDIRS="$LOGDIRS /var/log/qmail/pop3d"
+fi
+for i in $LOGDIRS; do
+ if [ ! -d $i ]; then
+ echo "! $i is missing"
+ echo "...try: mkdir -p $i"
+ OK=0
+ elif [ "`ls -ld $i|awk '{print $3}'`" != "qmaill" ]; then
+ echo "! $i has wrong owner, should be qmaill"
+ echo "...try: chown qmaill $i"
+ OK=0
+ elif [ "`ls -ld $i|awk '{print $1}'`" != "drwxr-xr-x" ]; then
+ echo "! $i has wrong mode, should be 755"
+ echo "...try: chmod 755 $i"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i looks OK"
+ fi
+done
+
+SVCLINKS="/service/qmail-send /service/qmail-smtpd"
+if [ "$CHECKPOP" = "y" ]; then
+ SVCLINKS="$SVCLINKS /service/qmail-pop3d"
+fi
+for i in $SVCLINKS; do
+ if [ ! -L $i ]; then
+ echo "! $i is missing"
+ echo "...try: ln -s $QMHOME$i $i"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i exists"
+ fi
+done
+
+if [ ! -f /etc/tcp.smtp ]; then
+ echo "! /etc/tcp.smtp is missing"
+ echo "...try: echo '127.:allow,RELAYCLIENT=\"\"' >>/etc/tcp.smtp"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "/etc/tcp.smtp exists"
+fi
+
+if [ ! -f /etc/tcp.smtp.cdb ]; then
+ echo "! /etc/tcp.smtp.cdb is missing"
+ echo "...try: $QMHOME/bin/qmailctl cdb"
+ OK=0
+elif [ "$VERB" = y ]; then
+ echo "/etc/tcp.smtp.cdb exists"
+fi
+
+AHOME=`grep "^alias:" /etc/passwd | awk -F: '{print $6}'`
+if [ -z "$AHOME" ]; then
+ echo "! Couldn't find user alias's home directory"
+ OK=0
+else
+ for i in root postmaster mailer-daemon; do
+ if [ ! -f $AHOME/.qmail-$i ]; then
+ echo "! Alias for $i is missing"
+ echo "...try: echo me >$AHOME/.qmail-$i"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i alias exists"
+ fi
+ done
+fi
+
+if netstat -a | grep smtp | grep -i listen >/dev/null; then
+ if $PS | grep sendmail | grep -v grep >/dev/null; then
+ echo "! Sendmail is still running"
+ echo "...try: $RCDIR/init.d/sendmail stop"
+ OK=0
+ elif $LBIN/svok /service/qmail-smtpd; then
+ if [ "$VERB" = y ]; then
+ echo "/service/qmail-smtpd is running"
+ fi
+ else
+ echo "! Something is listening on port 25 (not tcpserver/qmail-smtpd)"
+ echo "...try: disabling current MTA"
+ OK=0
+ fi
+fi
+
+if [ "$CHECKPOP" = "y" ]; then
+ if netstat -a | grep pop | grep -i listen >/dev/null; then
+ if $LBIN/svok /service/qmail-pop3d; then
+ if [ "$VERB" = y ]; then
+ echo "/service/qmail-pop3d is running"
+ fi
+ else
+ echo "! Something is listening on port 110 (not tcpserver/qmail-pop3d)"
+ echo "...try: disabling other POP server"
+ OK=0
+ fi
+ fi
+fi
+
+for i in /usr/lib/sendmail /usr/sbin/sendmail; do
+ if [ -f $i -a ! -L $i ]; then
+ echo "! $i is a file, should be a link"
+ echo "...try: uninstalling current MTA or: mv $i $i.old; ln -s $QMHOME/bin/sendmail $i"
+ OK=0
+ elif [ ! -f $i ];then
+ echo "! $i is missing"
+ echo "...try: ln -s $QMHOME/bin/sendmail $i"
+ OK=0
+ elif [ "$VERB" = y ]; then
+ echo "$i exists"
+ fi
+done
+
+if [ $OK -eq 1 ]; then
+ echo "Congratulations, your LWQ installation looks good!"
+elif [ "$VERB" = y ]; then
+ echo "! Potential problems were found with your LWQ installation"
+fi
diff --git a/network/netqmail/LWQ_scripts/qmail-send-log-run b/network/netqmail/LWQ_scripts/qmail-send-log-run
new file mode 100644
index 0000000000000..515baf38369d4
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/qmail-send-log-run
@@ -0,0 +1,2 @@
+#!/bin/sh
+exec /usr/bin/setuidgid qmaill /usr/bin/multilog t /var/log/qmail
diff --git a/network/netqmail/LWQ_scripts/qmail-send-run b/network/netqmail/LWQ_scripts/qmail-send-run
new file mode 100644
index 0000000000000..8dbd3adf524fe
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/qmail-send-run
@@ -0,0 +1,2 @@
+#!/bin/sh
+exec /var/qmail/rc
diff --git a/network/netqmail/LWQ_scripts/qmail-smtpd-log-run b/network/netqmail/LWQ_scripts/qmail-smtpd-log-run
new file mode 100644
index 0000000000000..a7a7d4fd37a96
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/qmail-smtpd-log-run
@@ -0,0 +1,2 @@
+#!/bin/sh
+exec /usr/bin/setuidgid qmaill /usr/bin/multilog t /var/log/qmail/smtpd
diff --git a/network/netqmail/LWQ_scripts/qmail-smtpd-run b/network/netqmail/LWQ_scripts/qmail-smtpd-run
new file mode 100644
index 0000000000000..b72b52f98b2ec
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/qmail-smtpd-run
@@ -0,0 +1,22 @@
+#!/bin/sh
+
+QMAILDUID=`id -u qmaild`
+NOFILESGID=`id -g qmaild`
+MAXSMTPD=`cat /var/qmail/control/concurrencyincoming`
+LOCAL=`head -1 /var/qmail/control/me`
+
+if [ -z "$QMAILDUID" -o -z "$NOFILESGID" -o -z "$MAXSMTPD" -o -z "$LOCAL" ]; then
+ echo QMAILDUID, NOFILESGID, MAXSMTPD, or LOCAL is unset in
+ echo /var/qmail/supervise/qmail-smtpd/run
+ exit 1
+fi
+
+if [ ! -f /var/qmail/control/rcpthosts ]; then
+ echo "No /var/qmail/control/rcpthosts!"
+ echo "Refusing to start SMTP listener because it'll create an open relay"
+ exit 1
+fi
+
+exec /usr/bin/softlimit -m 20000000 \
+ /usr/bin/tcpserver -v -R -l "$LOCAL" -x /etc/tcp.smtp.cdb -c "$MAXSMTPD" \
+ -u "$QMAILDUID" -g "$NOFILESGID" 0 smtp /var/qmail/bin/qmail-smtpd 2>&1
diff --git a/network/netqmail/LWQ_scripts/qmailctl-script-dt70 b/network/netqmail/LWQ_scripts/qmailctl-script-dt70
new file mode 100644
index 0000000000000..6fd795ca2454b
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/qmailctl-script-dt70
@@ -0,0 +1,109 @@
+#!/bin/sh
+
+# For Red Hat chkconfig
+# chkconfig: - 80 30
+# description: the qmail MTA
+
+PATH=/var/qmail/bin:/bin:/usr/bin:/usr/local/bin:/usr/local/sbin
+export PATH
+
+QMAILDUID=`id -u qmaild`
+NOFILESGID=`id -g qmaild`
+
+case "$1" in
+ start)
+ echo "Starting qmail"
+ if svok /service/qmail-send ; then
+ svc -u /service/qmail-send /service/qmail-send/log
+ else
+ echo "qmail-send supervise not running"
+ fi
+ if svok /service/qmail-smtpd ; then
+ svc -u /service/qmail-smtpd /service/qmail-smtpd/log
+ else
+ echo "qmail-smtpd supervise not running"
+ fi
+ if [ -d /var/lock/subsys ]; then
+ touch /var/lock/subsys/qmail
+ fi
+ ;;
+ stop)
+ echo "Stopping qmail..."
+ echo " qmail-smtpd"
+ svc -d /service/qmail-smtpd /service/qmail-smtpd/log
+ echo " qmail-send"
+ svc -d /service/qmail-send /service/qmail-send/log
+ if [ -f /var/lock/subsys/qmail ]; then
+ rm /var/lock/subsys/qmail
+ fi
+ ;;
+ stat)
+ svstat /service/qmail-send
+ svstat /service/qmail-send/log
+ svstat /service/qmail-smtpd
+ svstat /service/qmail-smtpd/log
+ qmail-qstat
+ ;;
+ doqueue|alrm|flush)
+ echo "Flushing timeout table and sending ALRM signal to qmail-send."
+ /var/qmail/bin/qmail-tcpok
+ svc -a /service/qmail-send
+ ;;
+ queue)
+ qmail-qstat
+ qmail-qread
+ ;;
+ reload|hup)
+ echo "Sending HUP signal to qmail-send."
+ svc -h /service/qmail-send
+ ;;
+ pause)
+ echo "Pausing qmail-send"
+ svc -p /service/qmail-send
+ echo "Pausing qmail-smtpd"
+ svc -p /service/qmail-smtpd
+ ;;
+ cont)
+ echo "Continuing qmail-send"
+ svc -c /service/qmail-send
+ echo "Continuing qmail-smtpd"
+ svc -c /service/qmail-smtpd
+ ;;
+ restart)
+ echo "Restarting qmail:"
+ echo "* Stopping qmail-smtpd."
+ svc -d /service/qmail-smtpd /service/qmail-smtpd/log
+ echo "* Sending qmail-send SIGTERM and restarting."
+ svc -t /service/qmail-send /service/qmail-send/log
+ echo "* Restarting qmail-smtpd."
+ svc -u /service/qmail-smtpd /service/qmail-smtpd/log
+ ;;
+ cdb)
+ tcprules /etc/tcp.smtp.cdb /etc/tcp.smtp.tmp < /etc/tcp.smtp
+ chmod 644 /etc/tcp.smtp.cdb
+ echo "Reloaded /etc/tcp.smtp."
+ ;;
+ help)
+ cat <<HELP
+ stop -- stops mail service (smtp connections refused, nothing goes out)
+ start -- starts mail service (smtp connection accepted, mail can go out)
+ pause -- temporarily stops mail service (connections accepted, nothing leaves)
+ cont -- continues paused mail service
+ stat -- displays status of mail service
+ cdb -- rebuild the tcpserver cdb file for smtp
+restart -- stops and restarts smtp, sends qmail-send a TERM & restarts it
+doqueue -- schedules queued messages for immediate delivery
+ reload -- sends qmail-send HUP, rereading locals and virtualdomains
+ queue -- shows status of queue
+ alrm -- same as doqueue
+ flush -- same as doqueue
+ hup -- same as reload
+HELP
+ ;;
+ *)
+ echo "Usage: $0 {start|stop|restart|doqueue|flush|reload|stat|pause|cont|cdb|queue|help}"
+ exit 1
+ ;;
+esac
+
+exit 0
diff --git a/network/netqmail/LWQ_scripts/rc b/network/netqmail/LWQ_scripts/rc
new file mode 100644
index 0000000000000..5af8ced80b926
--- /dev/null
+++ b/network/netqmail/LWQ_scripts/rc
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+# Using stdout for logging
+# Using control/defaultdelivery from qmail-local to deliver messages by default
+
+exec env - PATH="/var/qmail/bin:$PATH" \
+qmail-start "`cat /var/qmail/control/defaultdelivery`"
diff --git a/network/netqmail/README b/network/netqmail/README
new file mode 100644
index 0000000000000..bc385cb16b39f
--- /dev/null
+++ b/network/netqmail/README
@@ -0,0 +1,17 @@
+netqmail - djb's qmail mta.
+
+This package is intended for folk who are using qmail now and might
+like a clean way to install and remove the latest version there is.
+
+daemontools is an optional dependency, highly recommended.
+
+The following 2 changes are made to the installed layout:
+
+1. man pages formerly under /var/qmail/man are moved to /usr/man, and
+2. documentation formerly under /var/qmail/doc is moved to the usual
+ Slackware documentation location.
+
+Please see README.SBo for important information on how to build and
+install this package.
+
+You can perform test installs to a chroot environment - see tests/README.
diff --git a/network/netqmail/README.SBo b/network/netqmail/README.SBo
new file mode 100644
index 0000000000000..95ae23c2cae3e
--- /dev/null
+++ b/network/netqmail/README.SBo
@@ -0,0 +1,88 @@
+You must stop your running MTA before installing or upgrading netqmail,
+unless you built with DO_CONFIG=no (see below)
+If your running MTA is qmail, you can stop it by entering "qmailctl stop".
+
+The principal reference for how to install and configure qmail is "Life
+with qmail" herinafter referred to as LWQ. URL is
+http://www.lifewithqmail.org/lwq.html.
+
+This SlackBuild can be configured to perform all the steps in LWQ
+section 2 (Installation) except 2.9 (Test the Installation).
+
+SETTING TMP
+
+This SlackBuild uses mkchroot, which runs best if the TMP directory is on the
+same file system as /usr. If you normally mount /tmp, you may want to use
+
+ TMP=/usr/localtmp ./netqmail.SlackBuild
+
+otherwise if you are going to build using a mounted /tmp then put
+
+ MKCHROOT_IGNORE_LN_ERRORS=yes ./netqmail.SlackBuild
+
+to prevent copious error messages. The build will use >200M of file space.
+(when mkchroot fails to make a hard link, it does a "cp -a" instead. The errors
+are not suppressed so the user can ^C out and make the target somewhere else).
+
+QMAIL USERS AND GROUPS
+
+Qmail needs 7 users and 2 groups. By default, installing netqmail will create
+them if they do not already exist on the target system. To prevent this:
+
+ INSTALL_USERS=no ./netqmail.SlackBuild
+
+User and group ids have been assigned by SBo. However if usrs or groups already
+exist on the build system then their ids are used instead. If they don't exist
+on the build system, you can force them to be other than the default bu e.g.:
+
+ NOFILES_GROUP=1001 ALIAS_USER=1001 ./netqmail.SlackBuild
+
+At least some of the qmail users and groups are compiled into the C code. The
+compile is done in a chroot environment so the build system's /etc/passwd can
+be left untouched. uids & gids defined, discovered or defaulted as above are
+used in the chroot build.
+
+QMAIL CONFIGURATION
+
+By default, the SlackBuild implements a number of other steps from LWQ section 2
+(in addition to creating users, above). To completely disable this:
+
+ DO_CONFIG=no ./netqmail.SlackBuild
+
+If uou specified the above, the rest of this README does not apply: stop
+reading now.
+
+MAIL ADMININISTRATOR
+
+RFC 2821 requires that "postmaster" be a real user who can receive mail.
+qmail implements this requirement via its aliasing system. LWQ uses the example
+user "dave":
+
+ ADMIN_USER=dave ./netqmail.SlackBuild
+
+mail to postmaster will now be sent to dave. Mail to root is also sent to dave,
+via a separate entry in /var/wmail/alias. To see these, use "ls -A" since all
+files in /var/wmail/alias are hidden.
+User "mailer-daemon" is a de-facto standard recipient for some bounces. User
+"abuse" is a de facto standard recipient for abuse complaints. These 2 names are
+symlinked to the postmaster entry in /var/wmail/alias.
+
+AUTOMATIC START UP
+
+qmail was written to be controllable by daemontools. To configure that
+daemontools will start qmail, put:
+
+ ADMIN_USER=dave SYMLINK_SERVICE=yes ./netqmail.SlackBuild
+
+Note that it is an error to request automatic start up without specifying a
+mail admininistrator.
+With this option enabled, qmail should start by itself soon after installation.
+
+DEFAULT MAIL DELIVERY METHOD
+
+qmail supports delivery to the traditional mbox format (1 file per user) or the
+newer Maildir format (1 file per email). Users can set their preference in
+~/.qmail; otherwise they get the system default. The default built default
+method is mbox. To change this to Maildir, put:
+
+ MAILDIR=yes ./netqmail.SlackBuild
diff --git a/network/netqmail/doinst.sh b/network/netqmail/doinst.sh
new file mode 100644
index 0000000000000..729611d432933
--- /dev/null
+++ b/network/netqmail/doinst.sh
@@ -0,0 +1 @@
+chroot . /bin/sh /usr/doc/netqmail-1.06/install_scripts/doinst_sh
diff --git a/network/netqmail/doinst_config b/network/netqmail/doinst_config
new file mode 100644
index 0000000000000..d19f9a636acd3
--- /dev/null
+++ b/network/netqmail/doinst_config
@@ -0,0 +1,30 @@
+# LWQ 2.5.5
+cd /usr/doc/netqmail-1.06/install_scripts
+./config
+cd /var/qmail/control
+for i in me defaultdomain plusdomain locals rcpthosts
+do
+ config $i.new
+done
+
+#LWQ 2.8.2.3
+grep -q '127.:allow,RELAYCLIENT=""' /etc/tcp.smtp 2>/dev/null ||
+ echo '127.:allow,RELAYCLIENT=""' >>/etc/tcp.smtp
+qmailctl cdb
+
+# LWQ 2.8.3
+for i in /usr/lib /usr/sbin
+do
+ if [ -e $i/sendmail ]
+ then
+ if [ $(readlink -f $i/sendmail) != /var/qmail/bin/sendmail ]
+ then
+ mv $i/sendmail $i/sendmail.old
+ chmod 0 $i/sendmail.old
+ ln -s /var/qmail/bin/sendmail $i
+ fi
+ else
+ rm -f $i/sendmail # Could be a dangling symlink
+ ln -s /var/qmail/bin/sendmail $i
+ fi
+done
diff --git a/network/netqmail/doinst_new b/network/netqmail/doinst_new
new file mode 100644
index 0000000000000..d99dba1aac6c6
--- /dev/null
+++ b/network/netqmail/doinst_new
@@ -0,0 +1,9 @@
+config() {
+ NEW="$1"
+ OLD="$(dirname $NEW)/$(basename $NEW .new)"
+ if [ ! -r $OLD ]; then
+ mv $NEW $OLD
+ elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then
+ rm $NEW
+ fi
+}
diff --git a/network/netqmail/doinst_service b/network/netqmail/doinst_service
new file mode 100644
index 0000000000000..d08423b01b849
--- /dev/null
+++ b/network/netqmail/doinst_service
@@ -0,0 +1,12 @@
+# LWQ 2.8.2.2
+if [ -d /service ]
+then
+ for i in qmail-send qmail-smtpd
+ do
+ [ -L /service/$i -o -e /service/$i ] ||
+ ln -s /var/qmail/supervise/$i /service
+ done
+else
+ echo "There is no /service directory" >&2
+ echo "Did you install daemontools?" >&2
+fi
diff --git a/network/netqmail/doinst_users b/network/netqmail/doinst_users
new file mode 100644
index 0000000000000..f8e4c0b82f2f0
--- /dev/null
+++ b/network/netqmail/doinst_users
@@ -0,0 +1,18 @@
+grep -q ^nofiles: /etc/group ||
+ groupadd -g 340 nofiles
+grep -q ^alias: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail/alias -u 339 -s "" alias
+grep -q ^qmaild: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u 340 -s "" qmaild
+grep -q ^qmaill: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u 341 -s "" qmaill
+grep -q ^qmailp: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u 342 -s "" qmailp
+grep -q ^qmail: /etc/group ||
+ groupadd -g 339 qmail
+grep -q ^qmailq: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u 343 -s "" qmailq
+grep -q ^qmailr: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u 344 -s "" qmailr
+grep -q ^qmails: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u 345 -s "" qmails
diff --git a/network/netqmail/dot_new.patch b/network/netqmail/dot_new.patch
new file mode 100644
index 0000000000000..f5f44850676be
--- /dev/null
+++ b/network/netqmail/dot_new.patch
@@ -0,0 +1,97 @@
+--- config-fast.sh 1998/06/15 10:53:16 1.1
++++ config-fast.sh 2017/02/07 01:58:27
+@@ -2,29 +2,29 @@
+ echo Your fully qualified host name is "$fqdn".
+
+ echo Putting "$fqdn" into control/me...
+-echo "$fqdn" > QMAIL/control/me
+-chmod 644 QMAIL/control/me
++echo "$fqdn" > QMAIL/control/me.new
++chmod 644 QMAIL/control/me.new
+
+ ( echo "$fqdn" | sed 's/^\([^\.]*\)\.\([^\.]*\)\./\2\./' | (
+ read ddom
+ echo Putting "$ddom" into control/defaultdomain...
+- echo "$ddom" > QMAIL/control/defaultdomain
+- chmod 644 QMAIL/control/defaultdomain
++ echo "$ddom" > QMAIL/control/defaultdomain.new
++ chmod 644 QMAIL/control/defaultdomain.new
+ ) )
+
+ ( echo "$fqdn" | sed 's/^.*\.\([^\.]*\)\.\([^\.]*\)$/\1.\2/' | (
+ read pdom
+ echo Putting "$pdom" into control/plusdomain...
+- echo "$pdom" > QMAIL/control/plusdomain
+- chmod 644 QMAIL/control/plusdomain
++ echo "$pdom" > QMAIL/control/plusdomain.new
++ chmod 644 QMAIL/control/plusdomain.new
+ ) )
+
+ echo Putting "$fqdn" into control/locals...
+-echo "$fqdn" >> QMAIL/control/locals
+-chmod 644 QMAIL/control/locals
++echo "$fqdn" >> QMAIL/control/locals.new
++chmod 644 QMAIL/control/locals.new
+
+ echo Putting "$fqdn" into control/rcpthosts...
+-echo "$fqdn" >> QMAIL/control/rcpthosts
+-chmod 644 QMAIL/control/rcpthosts
++echo "$fqdn" >> QMAIL/control/rcpthosts.new
++chmod 644 QMAIL/control/rcpthosts.new
+ echo "Now qmail will refuse to accept SMTP messages except to $fqdn."
+ echo 'Make sure to change rcpthosts if you add hosts to locals or virtualdomains!'
+--- config.sh 1998/06/15 10:53:16 1.1
++++ config.sh 2017/02/07 01:51:04
+@@ -7,24 +7,24 @@
+ then
+ echo Your host\'s fully qualified name in DNS is "$fqdn".
+ echo Putting "$fqdn" into control/me...
+- echo "$fqdn" > QMAIL/control/me
+- chmod 644 QMAIL/control/me
++ echo "$fqdn" > QMAIL/control/me.new
++ chmod 644 QMAIL/control/me.new
+ ( echo "$fqdn" | sed 's/^\([^\.]*\)\.\([^\.]*\)\./\2\./' | (
+ read ddom
+ echo Putting "$ddom" into control/defaultdomain...
+- echo "$ddom" > QMAIL/control/defaultdomain
+- chmod 644 QMAIL/control/defaultdomain
++ echo "$ddom" > QMAIL/control/defaultdomain.new
++ chmod 644 QMAIL/control/defaultdomain.new
+ ) )
+ ( echo "$fqdn" | sed 's/^.*\.\([^\.]*\)\.\([^\.]*\)$/\1.\2/' | (
+ read pdom
+ echo Putting "$pdom" into control/plusdomain...
+- echo "$pdom" > QMAIL/control/plusdomain
+- chmod 644 QMAIL/control/plusdomain
++ echo "$pdom" > QMAIL/control/plusdomain.new
++ chmod 644 QMAIL/control/plusdomain.new
+ ) )
+ echo ' '
+ echo Checking local IP addresses:
+- : > QMAIL/control/locals
+- chmod 644 QMAIL/control/locals
++ : > QMAIL/control/locals.new
++ chmod 644 QMAIL/control/locals.new
+ ( ./dnsip "$fqdn"
+ ./ipmeprint ) | sort -u | \
+ (
+@@ -35,7 +35,7 @@
+ if read local
+ then
+ echo Adding "$local" to control/locals...
+- echo "$local" >> QMAIL/control/locals
++ echo "$local" >> QMAIL/control/locals.new
+ else
+ echo PTR lookup failed. I assume this address has no DNS name.
+ fi
+@@ -48,8 +48,8 @@
+ echo You don\'t have to worry about aliases, i.e., domains with CNAME records.
+ echo ' '
+ echo Copying QMAIL/control/locals to QMAIL/control/rcpthosts...
+- cp QMAIL/control/locals QMAIL/control/rcpthosts
+- chmod 644 QMAIL/control/rcpthosts
++ cp QMAIL/control/locals.new QMAIL/control/rcpthosts.new
++ chmod 644 QMAIL/control/rcpthosts.new
+ echo 'Now qmail will refuse to accept SMTP messages except to those hosts.'
+ echo 'Make sure to change rcpthosts if you add hosts to locals or virtualdomains!'
+ else
diff --git a/network/netqmail/fix_paths.patch b/network/netqmail/fix_paths.patch
new file mode 100644
index 0000000000000..c1ca92e790140
--- /dev/null
+++ b/network/netqmail/fix_paths.patch
@@ -0,0 +1,55 @@
+--- INSTALL.vsm 1998/06/15 10:53:16 1.1
++++ INSTALL.vsm 2017/02/20 08:47:19
+@@ -43,7 +43,7 @@
+ 3. Using sendmail's delivery agent
+
+ sendmail uses binmail to deliver to /var/spool/mail. binmail is shipped
+-with the operating system as /bin/mail or /usr/libexec/mail.local.
++with the operating system as /bin/mail or /usr/sbin/mail.local.
+
+ There is some variation in binmail syntax among systems. The most common
+ interfaces are shown in /var/qmail/boot/binm1, /var/qmail/boot/binm2,
+--- REMOVE.binmail 1998/06/15 10:53:16 1.1
++++ REMOVE.binmail 2017/02/20 08:47:19
+@@ -2,11 +2,11 @@
+ configured qmail to use binmail for local delivery.
+
+
+-1. Find the binmail binary on your system: /usr/libexec/mail.local if
++1. Find the binmail binary on your system: /usr/sbin/mail.local if
+ that exists, otherwise /bin/mail.
+
+ 2. Remove permissions from the binmail binary:
+- # chmod 0 /usr/libexec/mail.local
++ # chmod 0 /usr/sbin/mail.local
+
+ 3. If the binmail binary was /bin/mail, make sure that ``mail'' still
+ invokes a usable mailer. Under SVR4 you may want to link mail to
+--- binm1+df.sh 1998/06/15 10:53:16 1.1
++++ binm1+df.sh 2017/02/20 08:47:19
+@@ -3,9 +3,9 @@
+ # Using splogger to send the log through syslog.
+ # Using dot-forward to support sendmail-style ~/.forward files.
+ # Using binmail to deliver messages to /var/spool/mail/$USER by default.
+-# Using BSD 4.4 binmail interface: /usr/libexec/mail.local -r
++# Using BSD 4.4 binmail interface: /usr/sbin/mail.local -r
+
+ exec env - PATH="QMAIL/bin:$PATH" \
+ qmail-start '|dot-forward .forward
+-|preline -f /usr/libexec/mail.local -r "${SENDER:-MAILER-DAEMON}" -d "$USER"' \
++|preline -f /usr/sbin/mail.local -r "${SENDER:-MAILER-DAEMON}" -d "$USER"' \
+ splogger qmail
+--- binm1.sh 1998/06/15 10:53:16 1.1
++++ binm1.sh 2017/02/20 08:47:19
+@@ -2,9 +2,9 @@
+
+ # Using splogger to send the log through syslog.
+ # Using binmail to deliver messages to /var/spool/mail/$USER by default.
+-# Using BSD 4.4 binmail interface: /usr/libexec/mail.local -r
++# Using BSD 4.4 binmail interface: /usr/sbin/mail.local -r
+
+ exec env - PATH="QMAIL/bin:$PATH" \
+ qmail-start \
+-'|preline -f /usr/libexec/mail.local -r "${SENDER:-MAILER-DAEMON}" -d "$USER"' \
++'|preline -f /usr/sbin/mail.local -r "${SENDER:-MAILER-DAEMON}" -d "$USER"' \
+ splogger qmail
diff --git a/network/netqmail/netqmail.SlackBuild b/network/netqmail/netqmail.SlackBuild
new file mode 100644
index 0000000000000..fb16eef4a2541
--- /dev/null
+++ b/network/netqmail/netqmail.SlackBuild
@@ -0,0 +1,271 @@
+#!/bin/sh
+
+# Slackware build script for netqmail
+
+# Copyright 2017 Duncan Roe, Melbourne, Australia
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+PRGNAM=netqmail
+VERSION=${VERSION:-1.06}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i586 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+DOCDIR=$PKG/usr/doc/$PRGNAM-$VERSION
+CHROOT=$TMP/$PRGNAM
+DO_CONFIG=${DO_CONFIG:-yes}
+MAILDIR=${MAILDIR:-no}
+SYMLINK_SERVICE=${SYMLINK_SERVICE:-no}
+ADMIN_USER=${ADMIN_USER:-nobody}
+INSTALL_USERS=${INSTALL_USERS:-yes}
+VERBOSE_ADDCHROOT=${VERBOSE_ADDCHROOT:-yes}
+export VERBOSE_ADDCHROOT
+
+# Put here rather than /var/log/setup to keep different build variants
+INSTDIR=$DOCDIR/install_scripts
+
+[ "$ARCH" = "x86_64" ] && LIBDIRSUFFIX="64" || LIBDIRSUFFIX=""
+
+# These are the user and group ids allocated by SBo
+NOFILES_GROUP=${NOFILES_GROUP:-340}
+QMAIL_GROUP=${QMAIL_GROUP:-339}
+ALIAS_USER=${ALIAS_USER:-339}
+QMAILD_USER=${QMAILD_USER:-340}
+QMAILL_USER=${QMAILL_USER:-341}
+QMAILP_USER=${QMAILP_USER:-342}
+QMAILQ_USER=${QMAILQ_USER:-343}
+QMAILR_USER=${QMAILR_USER:-344}
+QMAILS_USER=${QMAILS_USER:-345}
+
+# It's an error to request to start qmail w/out specifying an admin user
+[ $SYMLINK_SERVICE = no -o $ADMIN_USER != nobody ] ||
+ { echo "You must provide an admin user to start qmail"; exit 1; }
+
+# If any users or groups are already configured, use their id instead
+for i in nofiles qmail
+do
+ grep -q ^$i: /etc/group &&
+ eval $(echo $i|tr a-z A-Z)_GROUP=$(grep ^$i: /etc/group|cut -f3 -d:)
+done
+for i in alias qmail{d,l,p,q,r,s}
+do
+ grep -q ^$i: /etc/passwd &&
+ eval $(echo $i|tr a-z A-Z)_USER=$(grep ^$i: /etc/passwd|cut -f3 -d:)
+done
+
+set -e
+
+rm -rf $PKG $CHROOT
+mkdir -p $INSTDIR $OUTPUT $CHROOT
+
+# Create doinst.sh fragment to add users & groups
+# (-r option stops creation of mailboxes)
+if [ "$INSTALL_USERS" = yes ]; then
+ cat >$INSTDIR/doinst_users <<////
+grep -q ^nofiles: /etc/group ||
+ groupadd -g $NOFILES_GROUP nofiles
+grep -q ^alias: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail/alias -u $ALIAS_USER -s "" alias
+grep -q ^qmaild: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u $QMAILD_USER -s "" qmaild
+grep -q ^qmaill: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u $QMAILL_USER -s "" qmaill
+grep -q ^qmailp: /etc/passwd ||
+ useradd -r -g nofiles -d /var/qmail -u $QMAILP_USER -s "" qmailp
+grep -q ^qmail: /etc/group ||
+ groupadd -g $QMAIL_GROUP qmail
+grep -q ^qmailq: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u $QMAILQ_USER -s "" qmailq
+grep -q ^qmailr: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u $QMAILR_USER -s "" qmailr
+grep -q ^qmails: /etc/passwd ||
+ useradd -r -g qmail -d /var/qmail -u $QMAILS_USER -s "" qmails
+////
+else
+ cat /dev/null >$INSTDIR/doinst_users
+fi
+
+cd $CHROOT
+rm -rf $PRGNAM-$VERSION
+tar xvf $CWD/$PRGNAM-$VERSION.tar.gz
+cd $PRGNAM-$VERSION
+chown -R root:root .
+find -L . \
+ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
+ -o -perm 511 \) -exec chmod 755 {} \; -o \
+ \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
+ -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
+
+for i in $CWD/*.patch
+do
+ cat $i|patch -p0
+done
+
+############################################################################
+# The build process requires all the qmail users to be registered, #
+# so do it in a chroot to avoid messing with the build system's etc/passwd #
+############################################################################
+
+cd $CHROOT
+export MKCHROOT_FOR_GCC=yes
+mkchroot .
+
+# need make + groff + sed
+addchroot . make guile gc libffi libunistring groff sed
+
+# need gcc, kernel headers, flex
+addchroot . binutils gcc libmpc kernel-headers flex
+
+mkdir -p var/qmail
+
+# install the qmail users and groups for chroot
+cat >>etc/group <<////
+nofiles:x:$NOFILES_GROUP:
+qmail:x:$QMAIL_GROUP:
+////
+cat >>etc/passwd <<////
+root:x:0:0::/root:/bin/bash
+alias:x:$ALIAS_USER:$NOFILES_GROUP::/var/qmail/alias:/bin/true
+qmaild:x:$QMAILD_USER:$NOFILES_GROUP::/var/qmail:/bin/true
+qmaill:x:$QMAILL_USER:$NOFILES_GROUP::/var/qmail:/bin/true
+qmailp:x:$QMAILP_USER:$NOFILES_GROUP::/var/qmail:/bin/true
+qmailq:x:$QMAILQ_USER:$QMAIL_GROUP::/var/qmail:/bin/true
+qmailr:x:$QMAILR_USER:$QMAIL_GROUP::/var/qmail:/bin/true
+qmails:x:$QMAILS_USER:$QMAIL_GROUP::/var/qmail:/bin/true
+////
+
+# Set up the commands to run in the chroot jail
+cat >commands <<////
+cd /$PRGNAM-$VERSION
+make
+make setup check
+////
+
+# Run the chroot commands
+chroot . /bin/sh /commands
+
+rm -r var/qmail/man/cat*
+mv var/qmail/doc/* $DOCDIR
+rmdir var/qmail/doc
+mv var/qmail/man $PKG/usr
+mv var $PKG
+
+find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \
+ | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
+
+find $PKG/usr/man -type f -exec gzip -9 {} \;
+for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
+
+cat $CWD/$PRGNAM.SlackBuild > $DOCDIR/$PRGNAM.SlackBuild
+cp -a $CHROOT/$PRGNAM-$VERSION/{BLURB*,CHANGES,COPYRIGHT,INTERNALS,README} $DOCDIR
+
+chown -R root: $PKG/usr
+
+mkdir -p $PKG/install
+cat $INSTDIR/doinst_users $CWD/doinst_new > $INSTDIR/doinst_sh
+
+###########################################################################
+# doinst.sh implements the configure advice in "Life with qmail" (LWQ). #
+# You can skip this step by secifying DO_CONFIG=no on the SlackBuild line #
+###########################################################################
+
+if [ $DO_CONFIG = yes ]
+then
+ # LWQ 2.5.5
+ cd $CHROOT/$PRGNAM-$VERSION
+ cp config hostname dnsfq dnsip ipmeprint dnsptr $INSTDIR
+ cat $CWD/doinst_config >> $INSTDIR/doinst_sh
+
+ # LWQ 2.8.1
+ cd $PKG
+ cat $CWD/LWQ_scripts/rc > var/qmail/rc
+ chmod 755 var/qmail/rc
+ mkdir -p var/log/qmail
+ [ "$MAILDIR" = no ] && i=./Mailbox || i=./Maildir/
+ echo $i > var/qmail/control/defaultdelivery
+
+ # LWQ 2.8.2.1
+ cat $CWD/LWQ_scripts/qmailctl-script-dt70 > var/qmail/bin/qmailctl
+ chmod 755 var/qmail/bin/qmailctl
+ cat $CWD/LWQ_scripts/inst_check > var/qmail/bin/inst_check
+ chmod 755 var/qmail/bin/inst_check # LWQ 2.9
+ mkdir usr/bin
+ ln -s ../../var/qmail/bin/{qmailctl,inst_check} usr/bin
+
+ # LWQ 2.8.2.2
+ mkdir -p var/qmail/supervise/qmail-send/log
+ mkdir -p var/qmail/supervise/qmail-smtpd/log
+ cat $CWD/LWQ_scripts/qmail-send-run > var/qmail/supervise/qmail-send/run
+ cat $CWD/LWQ_scripts/qmail-send-log-run \
+ > var/qmail/supervise/qmail-send/log/run
+ cat $CWD/LWQ_scripts/qmail-smtpd-run > var/qmail/supervise/qmail-smtpd/run
+ echo 20 > var/qmail/control/concurrencyincoming
+ chmod 644 var/qmail/control/concurrencyincoming
+ cat $CWD/LWQ_scripts/qmail-smtpd-log-run \
+ > var/qmail/supervise/qmail-smtpd/log/run
+ chmod 755 var/qmail/supervise/qmail-send/run
+ chmod 755 var/qmail/supervise/qmail-send/log/run
+ chmod 755 var/qmail/supervise/qmail-smtpd/run
+ chmod 755 var/qmail/supervise/qmail-smtpd/log/run
+ mkdir -p var/log/qmail/smtpd
+ chown $QMAILL_USER:$NOFILES_GROUP var/log/qmail var/log/qmail/smtpd
+ [ $SYMLINK_SERVICE = no ] || cat $CWD/doinst_service >> $INSTDIR/doinst_sh
+
+ # 2.8.3 is done in doinst_config
+
+ # LWQ 2.8.4
+ if [ $ADMIN_USER != nobody ]
+ then
+ echo $ADMIN_USER > var/qmail/alias/.qmail-root
+ echo $ADMIN_USER > var/qmail/alias/.qmail-postmaster
+ ln -s .qmail-postmaster var/qmail/alias/.qmail-mailer-daemon
+ ln -s .qmail-postmaster var/qmail/alias/.qmail-abuse
+ chmod 644 var/qmail/alias/.qmail-root var/qmail/alias/.qmail-postmaster
+ fi
+fi
+
+# qmail installer likes to put a sendmail symlink in /usr/lib
+mkdir -p $PKG/usr/lib
+
+# symlink useful programs to usr/bin
+mkdir -p $PKG/usr/bin
+ln -s ../../var/qmail/bin/maildirmake $PKG/usr/bin
+
+# Distribute the installer test suite
+mkdir $INSTDIR/tests
+cp -a $CWD/tests/{README,makechroot} $INSTDIR/tests/
+chown -R root: $INSTDIR/tests
+
+cat $CWD/slack-desc > $PKG/install/slack-desc
+cat $CWD/doinst.sh > $PKG/install/doinst.sh
+
+cd $PKG
+/sbin/makepkg -l n -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}
diff --git a/network/netqmail/netqmail.info b/network/netqmail/netqmail.info
new file mode 100644
index 0000000000000..7dd37b7c4fee6
--- /dev/null
+++ b/network/netqmail/netqmail.info
@@ -0,0 +1,10 @@
+PRGNAM="netqmail"
+VERSION="1.06"
+HOMEPAGE="http://qmail.ii.net/netqmail/"
+DOWNLOAD="http://qmail.ii.net/netqmail-1.06.tar.gz"
+MD5SUM="c922f776140b2c83043a6195901c67d3"
+DOWNLOAD_x86_64=""
+MD5SUM_x86_64=""
+REQUIRES="ucspi-tcp mkchroot"
+MAINTAINER="Duncan Roe"
+EMAIL="duncan_roe@optusnet.com.au"
diff --git a/network/netqmail/slack-desc b/network/netqmail/slack-desc
new file mode 100644
index 0000000000000..3cb9a631bd1b7
--- /dev/null
+++ b/network/netqmail/slack-desc
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description.
+# Line up the first '|' above the ':' following the base package name, and
+# the '|' on the right side marks the last column you can put a character in.
+# You must make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':' except on otherwise blank lines.
+
+ |-----handy-ruler------------------------------------------------------|
+netqmail: netqmail (the qmail MTA)
+netqmail:
+netqmail: netqmail is a source distribution of qmail 1.0.3. qmail is a secure,
+netqmail: reliable, efficient, simple message transfer agent. It is designed
+netqmail: for typical Internet-connected UNIX hosts. As of October 2001, qmail
+netqmail: was the second most common SMTP server on the Internet, and had by
+netqmail: far the fastest growth of any SMTP server. Nowadays its Internet
+netqmail: usage is about 10%.
+netqmail: qmail home page: http://qmail.ii.net/top.html
+netqmail: a gentler introduction: http://www.lifewithqmail.org/lwq.html
+netqmail:
diff --git a/network/netqmail/tests/README b/network/netqmail/tests/README
new file mode 100644
index 0000000000000..02b5e5286faa5
--- /dev/null
+++ b/network/netqmail/tests/README
@@ -0,0 +1,31 @@
+makechroot
+
+Make a chroot-able tree in which to run installpkg or explodepkg netqmail (i.e.
+from an interactive instance of chroot).
+Can also test installpkg --root to this tree.
+
+Whatever you do, you can step through the script commands in a root window.
+After explodepkg, you can step through the install scripts.
+
+See ../README.SBo for mkchroot caveats. Approximate disk usage: 1.5MB local
+$CHROOT, 131MB mounted $CHROOT.
+
+Set CHROOT to dir to buid (will be removed & re-created) (default is /tmp/t5).
+Set PKGDIR to directory containing SBo packages (default is /usr/packages).
+Set STRIP_INITTAB_SV=no to leave the SV line added by daemontools (dflt yes).
+Set INSTALL_DAEMONTOOLS=yes to install daemontools (default is no).
+Set STRIP_QMAIL_USERS_GROUPS=no to retain qmail users and groups (dflt yes).
+Set VERBOSE_ADDCHROOT=false to suppress install progress reporting (dflt true).
+Set MKCHROOT_IGNORE_LN_ERRORS=yes to suppress error messages from mounted chroot
+
+If you specified INSTALL_DAEMONTOOLS=yes, you can try running inst_check from an
+interactive chroot instance (qmail installation checker).
+inst_check will tell you to mount /proc - be sure to umount it afterwards.
+*if* the main system is running svscanboot, *and* the main system is not running
+an MTA, on re-running inst_check you should see
+
+ Congratulations, your LWQ installation looks good!
+
+Otherwise you should see a self-explanatory error message. If the main system is
+not runninmg svscanboot, you can start it in the chroot environment.
+Remember to umount /proc before exitting chroot.
diff --git a/network/netqmail/tests/makechroot b/network/netqmail/tests/makechroot
new file mode 100644
index 0000000000000..06435ef2d3d25
--- /dev/null
+++ b/network/netqmail/tests/makechroot
@@ -0,0 +1,74 @@
+#!/bin/sh
+#set -x
+
+# A function to make a file local (not hard-linked to the real file)
+# One should run this on any file that the test might modify
+make_local()
+{
+ while [ $# -gt 0 ]
+ do
+ cp -a $CHROOT/$1 $CHROOT/$1.new
+ mv $CHROOT/$1.new $CHROOT/$1
+ shift
+ done
+}
+
+CHROOT=${CHROOT:-/tmp/t5}
+VERBOSE_ADDCHROOT=${VERBOSE_ADDCHROOT:-true}
+export VERBOSE_ADDCHROOT
+PKGDIR=${PKGDIR:-/usr/packages}
+[ -n "$MKCHROOT_IGNORE_LN_ERRORS" ] && LNE='2>/dev/null' || LNE=
+
+# These are options
+INSTALL_DAEMONTOOLS=${INSTALL_DAEMONTOOLS:-no}
+STRIP_INITTAB_SV=${STRIP_INITTAB_SV:-yes}
+STRIP_QMAIL_USERS_GROUPS=${STRIP_QMAIL_USERS_GROUPS:-yes}
+
+[ ! -d $CHROOT/proc/1 ] || umount $CHROOT/proc
+rm -rf $CHROOT
+mkchroot $CHROOT
+addchroot $CHROOT tar pkgtools
+mkdir -p $CHROOT$PKGDIR
+eval ln $PKGDIR/netqmail* $PKGDIR/daemontools* $CHROOT$PKGDIR $LNE \|\| \
+ cp -a $PKGDIR/netqmail* $PKGDIR/daemontools* $CHROOT$PKGDIR
+addchroot $CHROOT ucspi-tcp mkchroot
+
+# Set up Slackware install DB for mkchroot
+for i in packages scripts
+do
+ mkdir $CHROOT/var/log/$i
+ (cd /var/log/$i; ls -1 | while read j; do [ -d $j ] ||
+ eval ln $j $CHROOT/var/log/$i $LNE \|\| cp -a $j $CHROOT/var/log/$i; done)
+done
+
+addchroot $CHROOT etc
+make_local etc/{group,gshadow,passwd,shadow}
+addchroot $CHROOT sysvinit
+addchroot $CHROOT sysvinit-scripts
+make_local etc/inittab
+[ $STRIP_INITTAB_SV != yes ] ||
+{
+ cat $CHROOT/etc/inittab | grep -E -v '^SV:' >$CHROOT/etc/inittab.new
+ mv $CHROOT/etc/inittab.new $CHROOT/etc/inittab
+}
+addchroot $CHROOT sed util-linux gzip network-scripts shadow ncurses
+mkdir $CHROOT/root $CHROOT/proc
+[ $INSTALL_DAEMONTOOLS = no ] || addchroot $CHROOT daemontools
+
+[ $STRIP_QMAIL_USERS_GROUPS != yes ] ||
+{
+ mount -tproc proc $CHROOT/proc
+
+ for i in alias qmail{d,l,p,q,r,s}
+ do
+ grep -q ^$i: $CHROOT/etc/passwd && chroot $CHROOT userdel $i
+ done
+ for i in nofiles qmail
+ do
+ grep -q ^$i: $CHROOT/etc/group && chroot $CHROOT groupdel $i
+ done
+ umount $CHROOT/proc
+}
+
+# inst_check needs these
+addchroot $CHROOT procps-ng gawk net-tools
diff --git a/network/netqmail/useradd_functions b/network/netqmail/useradd_functions
new file mode 100644
index 0000000000000..b7711224d170b
--- /dev/null
+++ b/network/netqmail/useradd_functions
@@ -0,0 +1,10 @@
+useradd()
+{
+ ADDED_USERS=$ADDED_USERS' '$(echo "$@"|rev|cut -f1 -d' '|rev)
+ /usr/sbin/useradd "$@"
+}
+groupadd()
+{
+ ADDED_GROUPS=$ADDED_GROUPS' '$(echo "$@"|rev|cut -f1 -d' '|rev)
+ /usr/sbin/groupadd "$@"
+}