n/unbound: Added unbound-1.4.21.

slackware-14.2
Damien Goutte-Gattat 10 years ago
parent 19336f6add
commit 6255dfe34a

@ -0,0 +1,25 @@
#!/bin/sh
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
}
config etc/unbound.conf.new
if ! grep ^unbound /etc/group > /dev/null ; then
/usr/sbin/groupadd -g 281 unbound
fi
if ! grep ^unbound /etc/passwd > /dev/null ; then
/usr/sbin/useradd -u 281 -c Unbound -d /var/lib/unbound -g unbound unbound
fi
if [ ! -d var/lib/unbound ]; then
mkdir -p var/lib/unbound
chown unbound:unbound var/lib/unbound
fi

@ -0,0 +1,30 @@
#!/bin/sh
case "$1" in
start)
/usr/sbin/unbound-control start
;;
stop)
/usr/sbin/unbound-control stop
;;
restart)
/usr/sbin/unbound-control stop
sleep 1
/usr/sbin/unbound-control start
;;
reload)
/usr/sbin/unbound-control reload
;;
status)
/usr/sbin/unbound-control status
;;
*)
echo "Usage: `basename $0` {start|stop|restart|reload|status}" 1>&2
exit 1
;;
esac

@ -0,0 +1,12 @@
|-----handy-ruler------------------------------------------------------|
unbound: unbound (DNS validating resolver)
unbound:
unbound: Unbound is an implementation of a DNS resolver, that does caching
unbound: and DNSSEC validation.
unbound:
unbound:
unbound:
unbound:
unbound:
unbound:
unbound:

@ -0,0 +1 @@
3ef4ea626e5284368d48ab618fe2207d43f2cee1 unbound-1.4.21.tar.gz

@ -0,0 +1,141 @@
#!/bin/bash
# Build script for Slackware
# Copyright (C) 2013 Damien Goutte-Gattat
#
# Redistribution and use of this script, with or without modifications,
# 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.
#
# Contact: Damien Goutte-Gattat <dgouttegattat@incenp.org>
#
# Latest unbound sourcecode is available at: <http://unbound.net/>.
#
# Depends: l/ldns
# Source package infos
NAMESRC=${NAMESRC:-unbound}
VERSION=${VERSION:-1.4.21}
ARCHIVE=${ARCHIVE:-$NAMESRC-$VERSION.tar.gz}
WGET=${WGET:-http://unbound.net/downloads/$ARCHIVE}
# Build infos
NAMEPKG=${NAMEPKG:-unbound}
BUILD=${BUILD:-1GGD}
ARCH=${ARCH:-$(uname -m | sed 's/^i.86$/i486/;s/^arm.*/arm/')}
JOBS=${JOBS:-1}
EXT=${EXT:-txz}
# Directories
TMP=${TMP:-/tmp}
OUT=${OUT:-$TMP/build}
PKG=${PKG:-$OUT/$NAMEPKG}
CWD=$(pwd)
set -e # Quit if a command returns non-zero
# Sanity checks
if [ $UID -eq 0 ]; then
echo "You should NOT run this script as ROOT!"
exit 1
fi
if [ ! -d $TMP ]; then
echo "$TMP does not exists or is not a directory!"
exit 1
fi
# Compilation flags
LIBDIRSUFFIX=""
case "$ARCH" in
i?86)
CPUOPT="-O2 -march=$ARCH -mtune=i686"
;;
x86_64)
CPUOPT="-O2 -fPIC"
LIBDIRSUFFIX="64"
;;
*)
CPUOPT="-O2"
;;
esac
# Get and verify the source archive
if [ ! -r $ARCHIVE ]; then
wget -c -O $ARCHIVE.part "$WGET"
mv $ARCHIVE.part $ARCHIVE
fi
sha1sum -c $ARCHIVE.sha1
NAME=$(tar ft $ARCHIVE | head -n 1 | cut -d / -f 1)
# Compile
cd $TMP
echo "Building $ARCHIVE..."
tar xf $CWD/$ARCHIVE
cd $NAME
CFLAGS=$CPUOPT \
CXXFLAGS=$CPUOPT \
./configure \
--prefix=/usr \
--libdir=/usr/lib$LIBDIRSUFFIX \
--mandir=/usr/man \
--sysconfdir=/etc \
--localstatedir=/var \
--disable-static \
--with-conf-file=/etc/unbound.conf \
--with-run-dir=/var/lib/unbound \
--with-pidfile=/var/run/unbound.pid
make -j $JOBS
make install DESTDIR=$PKG
# Strip binaries
find $PKG | xargs file | grep "ELF \(32\|64\)-bit LSB" | cut -d : -f 1 | \
xargs strip --strip-unneeded 2> /dev/null
# Compress man pages
find $PKG/usr/man -type f -exec gzip -9 {} \;
# Install the documentation
mkdir -p $PKG/usr/doc/$NAME
(cd doc
install -m 644 CREDITS Changelog FEATURES LICENSE README README.svn \
README.tests TODO control_proto_spec.txt ietf67-design-02.pdf \
requirements.txt $PKG/usr/doc/$NAME
)
# Install control script
install -D -m 644 $CWD/rc.unbound $PKG/etc/rc.d/rc.unbound
# Protect configuration file
mv $PKG/etc/unbound.conf $PKG/etc/unbound.conf.new
# Copy slack-desc and doinst.sh files
install -D -m 644 $CWD/slack-desc $PKG/install/slack-desc
install -m 755 $CWD/doinst.sh $PKG/install/doinst.sh
# Package the tree
cd $PKG
mkdir -p $OUT
PACKAGING="
chown root:root . -R
/sbin/makepkg -l y -c n $OUT/$NAMEPKG-$VERSION-$ARCH-$BUILD.$EXT
rm -rf $PKG
rm -rf $TMP/$NAME
"
if type -p fakeroot ; then
echo "$PACKAGING" | fakeroot
else
su -c "$PACKAGING"
fi
Loading…
Cancel
Save