From f4bd939b43f51aeb80772dd492661b8af98bcfa3 Mon Sep 17 00:00:00 2001 From: mario Date: Fri, 9 Sep 2011 16:21:53 -0400 Subject: network/ebtables: Added (Ethernet frame filtering on a Linux bridge) Signed-off-by: dsomero --- network/ebtables/README | 10 ++++ network/ebtables/ebtables.SlackBuild | 100 +++++++++++++++++++++++++++++++++++ network/ebtables/ebtables.info | 10 ++++ network/ebtables/slack-desc | 19 +++++++ 4 files changed, 139 insertions(+) create mode 100644 network/ebtables/README create mode 100644 network/ebtables/ebtables.SlackBuild create mode 100644 network/ebtables/ebtables.info create mode 100644 network/ebtables/slack-desc diff --git a/network/ebtables/README b/network/ebtables/README new file mode 100644 index 000000000000..6dba3d209802 --- /dev/null +++ b/network/ebtables/README @@ -0,0 +1,10 @@ +The ebtables program is a filtering tool for a Linux-based bridging firewall. It +enables transparent filtering of network traffic passing through a Linux bridge. +The filtering possibilities are limited to link layer filtering and some basic +filtering on higher network layers. Advanced logging, MAC DNAT/SNAT and brouter +facilities are also included. + +The ebtables tool can be combined with the other Linux filtering tools (iptables, +ip6tables and arptables) to make a bridging firewall that is also capable of +filtering these higher network layers. This is enabled through the +bridge-netfilter architecture which is a part of the standard Linux kernel. diff --git a/network/ebtables/ebtables.SlackBuild b/network/ebtables/ebtables.SlackBuild new file mode 100644 index 000000000000..c0740128f550 --- /dev/null +++ b/network/ebtables/ebtables.SlackBuild @@ -0,0 +1,100 @@ +#!/bin/sh + +# Slackware build script for ebtables + +# Copyright 2011, mario +# All rights reserved. +# +# 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. + +PRGNAM=ebtables +VERSION=${VERSION:-2.0.10} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i486 ;; + arm*) ARCH=arm ;; + *) 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" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-v$VERSION-1 +tar xvf $CWD/$PRGNAM-v$VERSION-1.tar.gz +cd $PRGNAM-v$VERSION-1 +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 {} \; + +CFLAGS="$SLKCFLAGS" \ +make + +make install DESTDIR=$PKG \ +LIBDIR=/usr/lib${LIBDIRSUFFIX} \ +MANDIR=/usr/man \ +BINDIR=/usr/sbin \ +ETCDIR=/etc \ +INITDIR=/etc/rc.d/init.d \ +SYSCONFIGDIR=/etc/sysconfig + +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 + +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 + +# Remove Red Hat junk +rm -rf $PKG/etc/rc.d $PKG/etc/sysconfig + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -a COPYING ChangeLog INSTALL THANKS $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:-tgz} diff --git a/network/ebtables/ebtables.info b/network/ebtables/ebtables.info new file mode 100644 index 000000000000..2967221fb2c6 --- /dev/null +++ b/network/ebtables/ebtables.info @@ -0,0 +1,10 @@ +PRGNAM="ebtables" +VERSION="2.0.10" +HOMEPAGE="http://ebtables.sourceforge.net/" +DOWNLOAD="http://downloads.sourceforge.net/ebtables/ebtables-v2.0.10-1.tar.gz" +MD5SUM="33b9ff7c9b605605c705418f17812714" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +MAINTAINER="mario" +EMAIL="mario@slackverse.org" +APPROVED="dsomero" diff --git a/network/ebtables/slack-desc b/network/ebtables/slack-desc new file mode 100644 index 000000000000..eedf63c6990a --- /dev/null +++ b/network/ebtables/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. Line +# up the first '|' above the ':' following the base package name, and the '|' +# on the right side marks the last column you can put a character in. You must +# make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +ebtables: ebtables (Ethernet frame filtering on a Linux bridge) +ebtables: +ebtables: The ebtables utility enables basic Ethernet frame filtering on a +ebtables: Linux bridge, logging, MAC NAT and brouting. It only provides basic +ebtables: IP filtering, the full-fledged IP filtering on a Linux bridge is +ebtables: done with iptables. +ebtables: +ebtables: Homepage: http://ebtables.sourceforge.net/ +ebtables: +ebtables: +ebtables: -- cgit v1.2.3