113 lines
3.1 KiB
Bash
113 lines
3.1 KiB
Bash
#!/bin/bash
|
|
#
|
|
# Slackware build script for openfire
|
|
# Written by Mário Antunes (mariolpantunes@gmail.com)
|
|
|
|
cd $(dirname $0) ; CWD=$(pwd)
|
|
|
|
PRGNAM=openfire
|
|
VERSION=${VERSION:-4.1.4}
|
|
BUILD=${BUILD:-1}
|
|
TAG=${TAG:-_SBo}
|
|
PKGTYPE=${PKGTYPE:-tgz}
|
|
|
|
SRCVER=$(echo $VERSION | tr . _)
|
|
|
|
ARCH=noarch
|
|
|
|
# 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}
|
|
|
|
# select openfire default user/group
|
|
OPENFIRE_USER=${OPENFIRE_USER:-openfire}
|
|
OPENFIRE_UID=${OPENFIRE_UID:-265}
|
|
OPENFIRE_GROUP=${OPENFIRE_GROUP:-openfire}
|
|
OPENFIRE_GID=${OPENFIRE_GID:-265}
|
|
|
|
bailout() {
|
|
echo " You must have a $OPENFIRE_USER user and $OPENFIRE_GROUP group to run this script. "
|
|
echo " Something like this should suffice for most systems: "
|
|
echo " # groupadd -g $OPENFIRE_GID $OPENFIRE_GROUP "
|
|
echo " # useradd -u $OPENFIRE_UID -g $OPENFIRE_GID -c \"Openfire Server\" -m $OPENFIRE_USER "
|
|
exit 1
|
|
}
|
|
|
|
# Bail if user and/or group isn't valid on your system
|
|
# uid=265 is suggested to avoid conflicts with other SBo packages,
|
|
# but it's your call: http://slackbuilds.org/uid_gid.txt
|
|
if ! getent passwd $OPENFIRE_USER 2>/dev/null; then
|
|
bailout
|
|
elif ! getent group $OPENFIRE_GROUP 2>/dev/null; then
|
|
bailout
|
|
fi
|
|
|
|
set -e
|
|
|
|
rm -rf $PKG
|
|
mkdir -p $TMP $PKG $OUTPUT
|
|
cd $TMP
|
|
rm -rf $PRGNAM
|
|
tar xvf $CWD/$PRGNAM\_$SRCVER.tar.gz
|
|
cd $PRGNAM
|
|
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 {} \;
|
|
|
|
# Installation path
|
|
PREFIX=/opt/$PRGNAM
|
|
|
|
mkdir -p $PKG$PREFIX/
|
|
cp -a bin/ $PKG$PREFIX/
|
|
cp -a .install4j/ $PKG$PREFIX/
|
|
cp -a conf/ $PKG$PREFIX/
|
|
cp -a lib/ $PKG$PREFIX/
|
|
mkdir -p $PKG$PREFIX/logs
|
|
cp -a plugins/ $PKG$PREFIX/
|
|
cp -a resources/ $PKG$PREFIX/
|
|
|
|
mkdir -p $PKG/var/log/$PRGNAM
|
|
chown -R $OPENFIRE_USER:$OPENFIRE_GROUP $PKG$PREFIX $PKG/var/log/$PRGNAM
|
|
|
|
mkdir -p $PKG/etc/profile.d
|
|
cat << EOF > $PKG/etc/profile.d/$PRGNAM.sh
|
|
#!/bin/sh
|
|
export openfireHome=/opt/openfire
|
|
EOF
|
|
cat << EOF > $PKG/etc/profile.d/$PRGNAM.csh
|
|
#!/bin/csh
|
|
setenv openfireHome /opt/openfire
|
|
EOF
|
|
chmod 755 $PKG/etc/profile.d/*
|
|
|
|
mkdir -p $PKG/etc/rc.d
|
|
sed \
|
|
-e "s|@OPENFIRE_USER@|$OPENFIRE_USER|" \
|
|
-e "s|@PREFIX@|$PREFIX|" \
|
|
$CWD/rc.$PRGNAM > $PKG/etc/rc.d/rc.$PRGNAM
|
|
chmod 755 $PKG/etc/rc.d/rc.$PRGNAM
|
|
|
|
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
|
|
|
|
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
|
|
cp -a *.html documentation/ $PKG/usr/doc/$PRGNAM-$VERSION
|
|
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
|
|
|
|
mkdir -p $PKG/install
|
|
cat $CWD/slack-desc > $PKG/install/slack-desc
|
|
|
|
cd $PKG
|
|
/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE
|