aboutsummaryrefslogtreecommitdiff
path: root/network/quagga
diff options
context:
space:
mode:
authorMarin Glibic <zhilla2@gmail.com>2010-12-29 19:19:03 -0200
committerRobby Workman <rworkman@slackbuilds.org>2010-12-31 18:59:53 -0600
commita5d362da5127036f0608e79a36b1411fcae5b9ac (patch)
treeb08a78a90966306f5a466d8ec0218b1663db2156 /network/quagga
parentae22224689c79cddd3702167b9e98784d7104704 (diff)
network/quagga: Added (IP routing daemons)
Signed-off-by: Niels Horn <niels.horn@slackbuilds.org>
Diffstat (limited to 'network/quagga')
-rw-r--r--network/quagga/Makefile.am.diff.gzbin0 -> 262 bytes
-rw-r--r--network/quagga/README6
-rw-r--r--network/quagga/doinst.sh34
-rw-r--r--network/quagga/ospf6_area.c.diff.gzbin0 -> 484 bytes
-rw-r--r--network/quagga/quagga.SlackBuild166
-rw-r--r--network/quagga/quagga.info10
-rw-r--r--network/quagga/quagga.logrotate17
-rw-r--r--network/quagga/quagga.pam3
-rw-r--r--network/quagga/rc.quagga43
-rw-r--r--network/quagga/rc.watchquagga40
-rw-r--r--network/quagga/slack-desc12
-rw-r--r--network/quagga/vtysh_user.c.diff.gzbin0 -> 264 bytes
12 files changed, 331 insertions, 0 deletions
diff --git a/network/quagga/Makefile.am.diff.gz b/network/quagga/Makefile.am.diff.gz
new file mode 100644
index 0000000000000..97349a1a6c501
--- /dev/null
+++ b/network/quagga/Makefile.am.diff.gz
Binary files differ
diff --git a/network/quagga/README b/network/quagga/README
new file mode 100644
index 0000000000000..1352f95b68f0f
--- /dev/null
+++ b/network/quagga/README
@@ -0,0 +1,6 @@
+Quagga is a routing software suite, providing implementations of OSPFv2,
+OSPFv3, RIP v1 and v2, RIPng and BGP-4 for Unix platforms, particularly
+FreeBSD, Linux, Solaris and NetBSD. Quagga is a fork of GNU Zebra which
+was developed by Kunihiro Ishiguro. The Quagga tree aims to build a more
+involved community around Quagga than the current centralised model of
+GNU Zebra. \ No newline at end of file
diff --git a/network/quagga/doinst.sh b/network/quagga/doinst.sh
new file mode 100644
index 0000000000000..f0f1596656c18
--- /dev/null
+++ b/network/quagga/doinst.sh
@@ -0,0 +1,34 @@
+config() {
+ NEW="$1"
+ OLD="$(dirname $NEW)/$(basename $NEW .new)"
+ # If there's no config file by that name, mv it over:
+ if [ ! -r $OLD ]; then
+ mv $NEW $OLD
+ elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then
+ # toss the redundant copy
+ rm $NEW
+ fi
+ # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+preserve_perms() {
+ NEW="$1"
+ OLD="$(dirname $NEW)/$(basename $NEW .new)"
+ if [ -e $OLD ]; then
+ cp -a $OLD ${NEW}.incoming
+ cat $NEW > ${NEW}.incoming
+ mv ${NEW}.incoming $NEW
+ fi
+ config $NEW
+}
+
+preserve_perms etc/rc.d/rc.quagga.new
+preserve_perms etc/rc.d/rc.watchquagga.new
+
+config etc/logrotate.d/quagga.new
+
+# Install the info files for this package
+if [ -x usr/bin/install-info ]; then
+ usr/bin/install-info --info-dir=/usr/info /usr/info/quagga.info.gz 2>/dev/null
+fi
+
diff --git a/network/quagga/ospf6_area.c.diff.gz b/network/quagga/ospf6_area.c.diff.gz
new file mode 100644
index 0000000000000..7b1448bd984d0
--- /dev/null
+++ b/network/quagga/ospf6_area.c.diff.gz
Binary files differ
diff --git a/network/quagga/quagga.SlackBuild b/network/quagga/quagga.SlackBuild
new file mode 100644
index 0000000000000..fdd853edd350c
--- /dev/null
+++ b/network/quagga/quagga.SlackBuild
@@ -0,0 +1,166 @@
+#!/bin/sh
+
+# Slackware build script for Quagga routing suite
+# Written by zhilla2_at_gm@il.kkom (spamprotected, figure domain out)
+# This script is in the public domain
+
+# Don't forget to set USE_PAM if you use it.
+
+PRGNAM=quagga
+VERSION=${VERSION:-0.99.17}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) export ARCH=i486 ;;
+ arm*) export ARCH=arm ;;
+ *) export ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "s390" ]; then
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIRSUFFIX="64"
+else
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+fi
+
+set -e
+
+# Bail if user or group isn't valid on your system
+if ! grep ^quagga: /etc/passwd 2>&1 > /dev/null; then
+
+cat << EOF
+
+ You must have a quagga user and group to run this script
+
+ # groupadd -g 245 quagga
+ # useradd -g quagga -u 245 -s /bin/false -c "Quagga routing suite" -d /var/run/quagga/ quagga
+
+EOF
+
+ exit
+elif ! grep ^quaggavt: /etc/group 2>&1 > /dev/null; then
+
+cat << EOF
+
+ You must have a quaggavt group to run this script
+
+ # groupadd -g 246 quaggavt
+
+EOF
+
+ exit
+fi
+
+rm -rf $PKG
+mkdir -p $TMP $PKG $OUTPUT
+cd $TMP
+
+rm -rf $PRGNAM-$VERSION
+tar zxvf $CWD/$PRGNAM-$VERSION.tar.gz
+cd $PRGNAM-$VERSION
+chown -R root:root .
+find . \
+ \( -perm 777 -o -perm 775 -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 {} \;
+
+# use libpam for PAM support in vtysh
+USE_PAM=${USE_PAM:-NO}
+
+if [ "$USE_PAM" == 'YES' ]; then
+ DO_PAM="--with-libpam"
+ zcat $CWD/vtysh_user.c.diff.gz | patch -p1
+ mkdir -p $PKG/etc/pam.d
+ cat $CWD/quagga.pam > $PKG/etc/pam.d/quagga
+else
+ DO_PAM="--without-libpam"
+fi
+
+zcat $CWD/Makefile.am.diff.gz | patch -p1
+zcat $CWD/ospf6_area.c.diff.gz | patch -p1
+
+#./bootstrap.sh
+
+CFLAGS="$SLKCFLAGS" \
+CXXFLAGS="$SLKCFLAGS" \
+./configure \
+ --prefix=/usr \
+ --sysconfdir=/etc/quagga \
+ --localstatedir=/var/run/quagga \
+ --libdir=/usr/lib${LIBDIRSUFFIX} \
+ --mandir=/usr/man \
+ --infodir=/usr/info \
+ --enable-vtysh \
+ --enable-opaque-lsa \
+ --enable-ospf-te \
+ --enable-dependency-tracking \
+ --enable-user=quagga \
+ --enable-group=quagga \
+ --enable-vty-group=quaggavt \
+ --enable-rtadv \
+ ${DO_PAM}
+# Some options useful for troubleshooting compiling
+# problems
+# --disable-capabilities \
+# --disable-ipv6 \
+
+sed -i -e "s#/lib#/lib${LIBDIRSUFFIX}#" Makefile
+
+make
+make install DESTDIR=$PKG
+
+find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \
+ | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null
+chown -R root.root $PKG/usr/sbin
+
+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
+
+rm -f $PKG/usr/info/dir
+gzip -9 $PKG/usr/info/*
+
+mv $TMP/$PRGNAM-$VERSION/*/*.sample $PKG/etc/quagga
+chown root.quagga $PKG/etc/quagga ; chmod 750 $PKG/etc/quagga
+chown -R root.quagga $PKG/etc/quagga/* ; chmod 640 $PKG/etc/quagga/*.sample
+
+mkdir -p $PKG/var/run/quagga $PKG/var/log/quagga
+chown quagga.quagga $PKG/var/run/quagga ; chmod 770 $PKG/var/run/quagga
+chown quagga.quagga $PKG/var/log/quagga ; chmod 770 $PKG/var/log/quagga
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a \
+ AUTHORS ChangeLog COPYING* README INSTALL REPORTING-BUGS TODO SERVICES \
+ $PKG/usr/doc/$PRGNAM-$VERSION
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+cat $CWD/doinst.sh > $PKG/install/doinst.sh
+
+mkdir -p $PKG/etc/rc.d
+cat $CWD/rc.quagga > $PKG/etc/rc.d/rc.quagga.new
+cat $CWD/rc.watchquagga > $PKG/etc/rc.d/rc.watchquagga.new
+
+mkdir -p $PKG/etc/logrotate.d
+cat $CWD/quagga.logrotate > $PKG/etc/logrotate.d/quagga.new
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}
diff --git a/network/quagga/quagga.info b/network/quagga/quagga.info
new file mode 100644
index 0000000000000..37f7943ab5ef5
--- /dev/null
+++ b/network/quagga/quagga.info
@@ -0,0 +1,10 @@
+PRGNAM="quagga"
+VERSION="0.99.17"
+HOMEPAGE="http://www.quagga.net/"
+DOWNLOAD="http://www.quagga.net/download/quagga-0.99.17.tar.gz"
+MD5SUM="37b9022adca04b03863d2d79787e643f"
+DOWNLOAD_x86_64=""
+MD5SUM_x86_64=""
+MAINTAINER="Marin Glibic"
+EMAIL="zhilla2@gmail.com"
+APPROVED="Niels Horn"
diff --git a/network/quagga/quagga.logrotate b/network/quagga/quagga.logrotate
new file mode 100644
index 0000000000000..9a213de3cadb9
--- /dev/null
+++ b/network/quagga/quagga.logrotate
@@ -0,0 +1,17 @@
+/var/log/quagga/*.log {
+ daily
+ sharedscripts
+ missingok
+ compress
+ rotate 14
+ create 640 quagga quagga
+
+ postrotate
+ for i in zebra bgpd ripd ospfd ripngd ospf6d isisd; do
+ if [ -e /var/run/quagga/$i.pid ] ; then
+ kill -USR1 $(cat /var/run/quagga/$i.pid)
+ fi
+
+ done
+ endscript
+}
diff --git a/network/quagga/quagga.pam b/network/quagga/quagga.pam
new file mode 100644
index 0000000000000..093e17294611f
--- /dev/null
+++ b/network/quagga/quagga.pam
@@ -0,0 +1,3 @@
+# Any user may call vtysh but only those belonging to the group quaggavty can
+# actually connect to the socket and use the program.
+auth sufficient pam_permit.so
diff --git a/network/quagga/rc.quagga b/network/quagga/rc.quagga
new file mode 100644
index 0000000000000..3033da277c06f
--- /dev/null
+++ b/network/quagga/rc.quagga
@@ -0,0 +1,43 @@
+#!/bin/sh
+
+# rc.quagga will try to start any service that has configured a config file in /etc/quagga
+
+start() {
+
+ for SERVICE in zebra bgpd ripd ospfd ripngd ospf6d isisd; do
+ if [ -r /etc/quagga/$SERVICE.conf ] ; then
+ echo -n "Starting ${SERVICE}: " && /usr/sbin/${SERVICE} -d && echo "done"
+ fi
+ done
+}
+
+stop() {
+
+ for SERVICE in zebra bgpd ripd ospfd ripngd ospf6d isisd; do
+ echo -n "Stopping ${SERVICE}: "
+ killall $SERVICE 2>/dev/null && echo -n "done" || echo -n "not started"
+ echo
+ done
+}
+
+restart() {
+
+ stop && sleep 2s && start
+ if [ -x /etc/rc.d/rc.watchquagga ] ; then
+ sh /etc/rc.d/rc.watchquagga restart
+ fi
+}
+
+case "$1" in
+ 'start')
+ start
+ ;;
+ 'stop')
+ stop
+ ;;
+ 'restart')
+ restart
+ ;;
+ *)
+ echo "usage $0 start|stop|restart"
+esac
diff --git a/network/quagga/rc.watchquagga b/network/quagga/rc.watchquagga
new file mode 100644
index 0000000000000..0f9736e2de6c1
--- /dev/null
+++ b/network/quagga/rc.watchquagga
@@ -0,0 +1,40 @@
+#!/bin/sh
+
+start() {
+ if [ -x /usr/sbin/watchquagga ]; then
+
+ for i in zebra bgpd ripd ospfd ripngd ospf6d isisd; do
+ if [ -e /var/run/quagga/$i.pid ] ; then
+ WATCHSERVICES="${WATCHSERVICES} ${i}"
+ fi
+ done
+
+ echo -n "Starting watchquagga: "
+ /usr/sbin/watchquagga -dz -R '/etc/rc.d/rc.quagga restart' $WATCHSERVICES || exit 1
+ echo "done"
+ fi
+}
+
+stop() {
+ echo -n "Stopping watchquagga: "
+ killall watchquagga 2>/dev/null && echo -n "done" || echo -n "not started"
+ echo
+}
+
+restart() {
+ stop && sleep 2s && start
+}
+
+case "$1" in
+ 'start')
+ start
+ ;;
+ 'stop')
+ stop
+ ;;
+ 'restart')
+ restart
+ ;;
+ *)
+ echo "usage $0 start|stop|restart"
+esac
diff --git a/network/quagga/slack-desc b/network/quagga/slack-desc
new file mode 100644
index 0000000000000..a3e1295aaf203
--- /dev/null
+++ b/network/quagga/slack-desc
@@ -0,0 +1,12 @@
+ |-----handy-ruler------------------------------------------------------|
+quagga: quagga (IP routing daemons)
+quagga:
+quagga: Quagga is a routing software suite, providing implementations of
+quagga: OSPFv2, OSPFv3, RIP v1 and v2, RIPv3 and BGPv4 for Unix platforms.
+quagga: Quagga is a fork of GNU Zebra.
+quagga:
+quagga:
+quagga:
+quagga:
+quagga:
+quagga:
diff --git a/network/quagga/vtysh_user.c.diff.gz b/network/quagga/vtysh_user.c.diff.gz
new file mode 100644
index 0000000000000..4bdc3d84552f4
--- /dev/null
+++ b/network/quagga/vtysh_user.c.diff.gz
Binary files differ