mirror of
https://github.com/Ponce/slackbuilds
synced 2024-11-22 19:44:21 +01:00
604d4035c6
Signed-off-by: Dave Woodfall <dave@slackbuilds.org>
122 lines
3.3 KiB
Bash
122 lines
3.3 KiB
Bash
#!/bin/bash
|
|
|
|
# Slackware build script for HAVP
|
|
|
|
# Written by William Bowman <wilbowma@indiana.edu>
|
|
|
|
cd $(dirname $0) ; CWD=$(pwd)
|
|
|
|
PRGNAM=havp
|
|
VERSION=${VERSION:-0.93}
|
|
BUILD=${BUILD:-1}
|
|
TAG=${TAG:-_SBo}
|
|
PKGTYPE=${PKGTYPE:-tgz}
|
|
|
|
if [ -z "$ARCH" ]; then
|
|
case "$( uname -m )" in
|
|
i?86) ARCH=i586 ;;
|
|
arm*) ARCH=arm ;;
|
|
*) ARCH=$( uname -m ) ;;
|
|
esac
|
|
fi
|
|
|
|
# If the variable PRINT_PACKAGE_NAME is set, then this script will report what
|
|
# the name of the created package would be, and then exit. This information
|
|
# could be useful to other scripts.
|
|
if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then
|
|
echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE"
|
|
exit 0
|
|
fi
|
|
|
|
TMP=${TMP:-/tmp/SBo}
|
|
PKG=$TMP/package-$PRGNAM
|
|
OUTPUT=${OUTPUT:-/tmp}
|
|
|
|
if [ "$ARCH" = "i586" ]; then
|
|
SLKCFLAGS="-O2 -march=i586 -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
|
|
|
|
bailout() {
|
|
printf "\n You must have a \"havp\" user and \"clamav\" group in order
|
|
to run this script. Add them with something like this
|
|
(the uid and gid are only suggestions):
|
|
groupadd -g 210 clamav
|
|
useradd -u 256 -d /dev/null -s /bin/false -g clamav havp \n"
|
|
exit 1
|
|
}
|
|
|
|
if ! getent group clamav 2>&1 >/dev/null; then
|
|
bailout ;
|
|
elif ! getent passwd havp 2>&1 > /dev/null; then
|
|
bailout ;
|
|
fi
|
|
|
|
set -e
|
|
|
|
rm -rf $PKG
|
|
mkdir -p $TMP $PKG $OUTPUT
|
|
cd $TMP
|
|
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 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
|
|
-exec chmod 644 {} \;
|
|
|
|
# See the patch headers for details
|
|
patch -p1 < $CWD/patches/fixup_and_install_init_script.diff
|
|
patch -p1 < $CWD/patches/use_clamav_group_by_default.diff
|
|
patch -p1 < $CWD/patches/put_templates_in_usrshare.diff
|
|
|
|
CFLAGS="$SLKCFLAGS"
|
|
./configure \
|
|
--prefix=/usr \
|
|
--sysconfdir=/etc \
|
|
--datadir=/usr/share \
|
|
--localstatedir=/var \
|
|
--libdir=/usr/lib${LIBDIRSUFFIX} \
|
|
--enable-ssl-tunnel \
|
|
--build=$ARCH-slackware-linux
|
|
|
|
make CFLAGS="$SLKCFLAGS -Wall -g"
|
|
make install DESTDIR=$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
|
|
|
|
# Let's not clobber configs
|
|
for file in blacklist whitelist havp.config ; do
|
|
mv $PKG/etc/havp/$file $PKG/etc/havp/$file.new ;
|
|
done
|
|
|
|
# Note that /var/log/havp should probably not be operated on by logrotate,
|
|
# since it runs as root, and the directory is controlled by a non-root
|
|
# process. This is mitigated in logrotate-3.8.0+ with an "su" directive
|
|
# to logrotate, but it's not available in 13.37.
|
|
chown havp:clamav $PKG/var/{log,run,tmp}/havp
|
|
chmod 0775 $PKG/var/tmp/havp
|
|
|
|
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
|
|
cp -a INSTALL COPYING ChangeLog $PKG/usr/doc/$PRGNAM-$VERSION
|
|
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
|
|
cat $CWD/README.setup > $PKG/usr/doc/$PRGNAM-$VERSION/README.setup
|
|
|
|
mkdir -p $PKG/install
|
|
cat $CWD/slack-desc > $PKG/install/slack-desc
|
|
cat $CWD/doinst.sh > $PKG/install/doinst.sh
|
|
|
|
cd $PKG
|
|
/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE
|