#!/bin/sh #-- avahi for Slackware -- # Build script by Phantom X # Suggested usage: $ avahi.SlackBuild 2>&1 | tee build.log #-- # Copyright 2008, 2009, 2010, 2011 Phantom X, Goiania, Brazil. # Copyright 2006 Martijn Dekker, Groningen, Netherlands. # # 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. # http://avahi.org PACKAGER_ID=${PACKAGER_ID:-$USER} PACKAGER=${PACKAGER:-$USER@$HOSTNAME} # Set YES for native build with gcc >= 4.2 SB_NATIVE=${SB_NATIVE:-NO} # Set to YES to replicate slackbuild and patches SB_REP=${SB_REP:-YES} CWD=$(pwd) TMP=${TMP:-/tmp} if [ ! -d ${TMP} ]; then mkdir -p ${TMP} fi NAME=avahi PKG=${PKG:-${TMP}/package-${NAME}} VERSION=${VERSION:-0.6.28} if [ "${SB_NATIVE}" = "YES" ] ;then ARCH=${ARCH:-$(uname -m)} else ARCH=${ARCH:-x86_64} fi if [ "${ARCH}" = "x86_64" ] ;then SLKTARGET=${SLKTARGET:-x86_64} else SLKTARGET=${SLKTARGET:-i486} fi SLKDTARGET=${SLKDTARGET:-slackware} BUILD=${BUILD:-1} NJOBS=${NJOBS:-$(( $(getconf _NPROCESSORS_ONLN) + 1 ))} DOCDIR=${PKG}/usr/doc/${NAME}-${VERSION} SBDIR=${PKG}/usr/src/slackbuilds/${NAME} PKGDEST=${PKGDEST:-${CWD}} PKGFORMAT=${PKGFORMAT:-txz} PKGNAME=${NAME}-$(echo ${VERSION} | tr - . )-${ARCH}-${BUILD}${PACKAGER_ID} DATE=$(LC_ALL=C date +%d-%b-%Y) grep --quiet '^avahi:' /etc/group && SB_HGROUP=1 grep --quiet '^avahi:' /etc/passwd && SB_HUSER=1 SRCDIR=${NAME}-${VERSION} SRCARCHIVE=${SRCDIR}.tar.gz DL_PROG=${DL_PROG:-wget} DL_TO=${DL_TO:-5} DL_OPTS=${DL_OPTS:-"--timeout=${DL_TO}"} DL_URL="http://avahi.org/download/${SRCARCHIVE}" # if source is not present, download in source rootdir if possible test -r ${CWD}/${SRCARCHIVE} || ${DL_PROG} ${DL_OPTS} ${DL_URL} || exit 1 if [ "${SB_NATIVE}" = "YES" ] ;then SLKCFLAGS="-O2 -march=native -mtune=native ${SB_ECFLAGS} -pipe" else case "${ARCH}" in i[3-6]86) SLKCFLAGS="-O2 -march=${ARCH} -mtune=i686" ;; x86_64) SLKCFLAGS="-O2 -fPIC" ;; s390|*) SLKCFLAGS="-O2" ;; esac fi if [ "${ARCH}" = "x86_64" ] ;then LIBDIRSUFFIX="64" SLKCFLAGS="${SLKCFLAGS} -fPIC" else LIBDIRSUFFIX="" fi if [ -d ${PKG} ]; then # Clean up a previous build rm -rf ${PKG} fi mkdir -p ${PKG} cd ${TMP} rm -rf ${SRCDIR} tar -xvf ${CWD}/${SRCARCHIVE} || exit 1 cd ${SRCDIR} || exit 1 chmod -R u+w,go+r-w,a-s . if [ -r ${CWD}/apply-patches.sh ]; then . ${CWD}/apply-patches.sh || exit 1 fi PKG_CONFIG_PATH="/opt/kde3/lib64/pkgconfig/" CFLAGS="${SLKCFLAGS}" \ CXXFLAGS="${SLKCFLAGS}" \ ./configure \ --prefix=/usr \ --libdir=/usr/lib${LIBDIRSUFFIX} \ --sysconfdir=/etc \ --localstatedir=/var \ --infodir=/usr/info \ --mandir=/usr/man \ --docdir=/usr/doc/${NAME}-${VERSION} \ --disable-silent-rules \ --disable-static \ --with-distro=slackware \ --with-avahi-user=avahi \ --with-avahi-group=avahi \ --with-avahi-priv-access-group=avahi \ --with-autoipd-user=avahi_autoipd \ --with-autoipd-group=avahi_autoipd \ --enable-compat-howl \ --enable-compat-libdns_sd \ --enable-introspection=no \ --disable-mono \ --disable-monodoc \ --build=${SLKTARGET}-${SLKDTARGET}-linux || exit 1 make -j${NJOBS} || make || exit 1 make install DESTDIR=${PKG} || exit 1 rm -f ${PKG}/usr/lib*/*.la rm -f ${PKG}/usr/lib*/*.a rmdir ${PKG}/usr/man/man{5,8} # remove example rm -f ${PKG}/etc/avahi/services/sftp-ssh.service mkdir -p ${PKG}/var/run/avahi-daemon mkdir -p ${PKG}/var/lib/avahi-autoipd # remove avahi-bookmarks - unusable without python-twisted rm -f ${PKG}/usr/bin/avahi-bookmarks \ ${PKG}/usr/man/man1/avahi-bookmarks* # Make /etc/avahi/etc/localtime owned by avahi: mkdir -p ${PKG}/etc/avahi/etc || exit 1 touch ${PKG}/etc/avahi/etc/localtime || exit 1 ln -s avahi-compat-howl.pc ${PKG}/usr/lib${LIBDIRSUFFIX}/pkgconfig/howl.pc || exit 1 ln -s avahi-compat-libdns_sd.pc ${PKG}/usr/lib${LIBDIRSUFFIX}/pkgconfig/libdns_sd.pc || exit 1 ln -s avahi-compat-libdns_sd/dns_sd.h ${PKG}/usr/include/ || exit 1 ( cd ${PKG}/etc/avahi || exit 1 for f in *.{conf,action} ;do mv ${f} ${f}.new || exit 1 done ) || exit 1 mv ${PKG}/etc/dbus-1/system.d/avahi-dbus.conf \ ${PKG}/etc/dbus-1/system.d/avahi-dbus.conf.new || exit 1 mkdir -p ${PKG}/var/log/setup zcat ${CWD}/setup.onlyonce.rc${NAME}daemon.gz \ > ${PKG}/var/log/setup/setup.onlyonce.rc${NAME}daemon || exit 1 chmod 0755 ${PKG}/var/log/setup/setup.onlyonce.rc${NAME}daemon || exit 1 find ${PKG} | xargs file | grep -e "executable" -e "shared object" | grep ELF \ | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null desktop-file-install --delete-original --vendor="" \ --dir ${PKG}/usr/share/applications \ --remove-key="Encoding" \ --remove-key="GenericName" \ --remove-category="Application" \ --add-category="GTK" \ ${PKG}/usr/share/applications/*.desktop || exit 1 # Add a documentation directory: # remove the documentation directory - let \%doc handle it: rm -rf ${PKG}/usr/share/doc mkdir -p ${DOCDIR} cp -a \ avahi-daemon/{example.service,sftp-ssh.service} docs/* ${CWD}/ChangeLog.SB \ ${DOCDIR}/ find ${DOCDIR}/ -type d -print0 | xargs -0 chmod 0755 find ${DOCDIR}/ -type f -print0 | xargs -0 chmod 0644 # Compress and link manpages, if any: if [ -d ${PKG}/usr/share/man ]; then mv ${PKG}/usr/share/man ${PKG}/usr/man rmdir ${PKG}/usr/share fi if [ -d ${PKG}/usr/man ]; then ( cd ${PKG}/usr/man for manpagedir in $(find . -type d -name "man*") ; do ( cd ${manpagedir} for eachpage in $( find . -type l -maxdepth 1) ; do ln -s $( readlink ${eachpage} ).gz ${eachpage}.gz rm ${eachpage} done gzip -9 *.? # Prevent errors rm -f *.gz.gz ) done ) fi mkdir -p ${PKG}/install cat ${CWD}/slack-desc > ${PKG}/install/slack-desc cat ${CWD}/slack-required > ${PKG}/install/slack-required cat > ${PKG}/install/doinst.sh <<'EOF' function free_user_id { # Find a free user-ID >= 100 (should be < 1000 so it's not a normal user) local FREE_USER_ID=100 while grep --quiet "^.*:.*:${FREE_USER_ID}:.*:.*:.*:" etc/passwd; do let FREE_USER_ID++ done echo ${FREE_USER_ID} } function free_group_id { # Find a free group-ID >= 120 (should be < 1000 so it's not a normal group) local FREE_GROUP_ID=120 while grep --quiet "^.*:.*:${FREE_GROUP_ID}:" etc/group; do let FREE_GROUP_ID++ done echo ${FREE_GROUP_ID} } # Figure out our root directory ROOTDIR=$(pwd) unset CHROOT if test "${ROOTDIR}" != "/"; then CHROOT="chroot ${ROOTDIR} " ROOTDIR="${ROOTDIR}/" fi # Set up groups. if ! grep --quiet '^avahi:' etc/group ;then ${CHROOT} /usr/sbin/groupadd \ -g $(free_group_id) \ avahi 2> /dev/null fi if ! grep --quiet '^avahi_autoipd:' etc/group ;then ${CHROOT} /usr/sbin/groupadd \ -g $(free_group_id) \ avahi-autoipd 2> /dev/null fi # Set up user: add it if it doesn't exist, update it if it already does. if OLD_ENTRY=$(grep --max-count=1 '^avahi:' etc/passwd) \ || OLD_ENTRY=$(grep --max-count=1 \ ':/etc/avahi:[a-z/]*$' etc/passwd) then # Modify existing user OLD_USER=$(echo ${OLD_ENTRY} | cut --fields=1 --delimiter=':') USER_ID=$(echo ${OLD_ENTRY} | cut --fields=3 --delimiter=':') test ${USER_ID} -ge 1000 && USER_ID=$(free_user_id) if test "${OLD_USER}" = "avahi"; then echo -n "Updating unprivileged user" 1>&2 else echo -ne "Changing unprivileged user \e[1m${OLD_USER}\e[0m to" 1>&2 fi ${CHROOT} /usr/sbin/usermod \ -d '/etc/avahi' \ -u ${USER_ID} \ -s /bin/false \ -g avahi \ ${OLD_USER} else # Add new user echo -n "Creating unprivileged user" 1>&2 ${CHROOT} /usr/sbin/useradd \ -c 'Avahi daemon' \ -u $(free_user_id) \ -g avahi \ -s /bin/false \ -d '/etc/avahi' \ avahi 2> /dev/null fi # Set up user: add it if it doesn't exist, update it if it already does. if OLD_ENTRY=$(grep --max-count=1 '^avahi_autoipd:' etc/passwd) \ || OLD_ENTRY=$(grep --max-count=1 \ ':/var/lib/avahi_autoipd:[a-z/]*$' etc/passwd) then # Modify existing user OLD_USER=$(echo ${OLD_ENTRY} | cut --fields=1 --delimiter=':') USER_ID=$(echo ${OLD_ENTRY} | cut --fields=3 --delimiter=':') test ${USER_ID} -ge 1000 && USER_ID=$(free_user_id) if test "${OLD_USER}" = "avahi_autoipd"; then echo -n "Updating unprivileged user" 1>&2 else echo -ne "Changing unprivileged user \e[1m${OLD_USER}\e[0m to" 1>&2 fi ${CHROOT} /usr/sbin/usermod \ -d '/var/lib/avahi_autoipd' \ -u ${USER_ID} \ -s /bin/false \ -g avahi_autoipd \ ${OLD_USER} else # Add new user echo -n "Creating unprivileged user" 1>&2 ${CHROOT} /usr/sbin/useradd \ -c 'avahi_autoipd' \ -u $(free_user_id) \ -g avahi_autoipd \ -s /bin/false \ -d '/var/lib/avahi_autoipd' \ avahi_autoipd 2> /dev/null fi EOF cat >> ${PKG}/install/doinst.sh <> ${PKG}/install/doinst.sh echo >> ${PKG}/install/doinst.sh echo '# Fix permissions' >> ${PKG}/install/doinst.sh echo '${CHROOT} /bin/chown avahi.avahi /var/run/avahi-daemon' >> ${PKG}/install/doinst.sh ) sed -i "s|_PACKAGER|${PACKAGER}|g; s|_BUILD_DATE|${DATE}|g" \ ${PKG}/install/slack-desc if [ "${SB_REP}" = "YES" ] ;then # Replicate slackbuild and patches mkdir -p ${SBDIR}/patches install -m0644 ${CWD}/slack-desc ${CWD}/slack-required ${CWD}/ChangeLog.SB \ ${CWD}/apply-patches.sh ${CWD}/setup.onlyonce.rc${NAME}*.gz \ ${SBDIR}/ install -m0755 ${CWD}/${NAME}.SlackBuild \ ${SBDIR}/${NAME}.SlackBuild install -m0644 ${CWD}/patches/*.* \ ${SBDIR}/patches/ fi # Build package: set +o xtrace # no longer print commands upon execution ROOTCOMMANDS="set -o errexit -o xtrace ; cd ${PKG} ; /bin/chown --recursive root:root . ; [ \"${SB_HGROUP}\" = 1 ] && [ \"${SB_HUSER}\" = 1 ] && /bin/chown avahi.avahi ./var/run/avahi-daemon ; " ROOTCOMMANDS="${ROOTCOMMANDS} /sbin/makepkg --prepend --linkadd y --chown n ${PKGDEST}/${PKGNAME}.${PKGFORMAT} " if test ${UID} = 0; then eval ${ROOTCOMMANDS} set +o xtrace elif test "$(type -t fakeroot)" = 'file'; then echo -e "\e[1mEntering fakeroot environment.\e[0m" echo ${ROOTCOMMANDS} | fakeroot else echo -e "\e[1mPlease enter your root password.\e[0m (Consider installing fakeroot.)" /bin/su -c "${ROOTCOMMANDS}" fi # Clean up the extra stuff: if [ "$1" = "--cleanup" ]; then echo "Cleaning..." if [ -d ${TMP}/${SRCDIR} ]; then rm -rf ${TMP}/${SRCDIR} && echo "${TMP}/${SRCDIR} cleanup completed" fi if [ -d ${PKG} ]; then rm -rf ${PKG} && echo "${PKG} cleanup completed" fi rmdir ${TMP} && echo "${TMP} cleanup completed" fi exit 0