summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Black <dragonheart@gentoo.org>2007-07-03 22:04:30 +0000
committerDaniel Black <dragonheart@gentoo.org>2007-07-03 22:04:30 +0000
commit0546fecc24e82bd1237c53ac354555deaee6b48b (patch)
tree1e7f854094fcef3aa97d671ba14bf368771d4b01 /net-misc
parentRemove old security vulnerable versions (diff)
downloadgentoo-2-0546fecc24e82bd1237c53ac354555deaee6b48b.tar.gz
gentoo-2-0546fecc24e82bd1237c53ac354555deaee6b48b.tar.bz2
gentoo-2-0546fecc24e82bd1237c53ac354555deaee6b48b.zip
version bump as per bug #184081 thanks to Cilly
(Portage version: 2.1.2.7)
Diffstat (limited to 'net-misc')
-rw-r--r--net-misc/l7-filter/ChangeLog7
-rw-r--r--net-misc/l7-filter/files/digest-l7-filter-2.106
-rw-r--r--net-misc/l7-filter/l7-filter-2.10.ebuild176
3 files changed, 188 insertions, 1 deletions
diff --git a/net-misc/l7-filter/ChangeLog b/net-misc/l7-filter/ChangeLog
index 99e0c798489d..6fdc6ac192fa 100644
--- a/net-misc/l7-filter/ChangeLog
+++ b/net-misc/l7-filter/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for net-misc/l7-filter
# Copyright 1999-2007 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-misc/l7-filter/ChangeLog,v 1.45 2007/04/09 19:11:33 gustavoz Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-misc/l7-filter/ChangeLog,v 1.46 2007/07/03 22:04:30 dragonheart Exp $
+
+*l7-filter-2.10 (03 Jul 2007)
+
+ 03 Jul 2007; Daniel Black <dragonheart@gentoo.org> +l7-filter-2.10.ebuild:
+ version bump as per bug #184081 thanks to Cilly
09 Apr 2007; Gustavo Zacarias <gustavoz@gentoo.org> l7-filter-2.9.ebuild:
Stable on sparc for the latest mojo
diff --git a/net-misc/l7-filter/files/digest-l7-filter-2.10 b/net-misc/l7-filter/files/digest-l7-filter-2.10
new file mode 100644
index 000000000000..bb2a2d788f05
--- /dev/null
+++ b/net-misc/l7-filter/files/digest-l7-filter-2.10
@@ -0,0 +1,6 @@
+MD5 6e8ff4d1b7b0281a7596a74789b79f8d additional_patch_for_2.6.13.diff 4962
+RMD160 8faa60214d5695c797b24a11fe95858a785258a3 additional_patch_for_2.6.13.diff 4962
+SHA256 c0e2b7bb7024c8e35b554eb33263b5c34dd2356aaea739b07231f717eae8f58d additional_patch_for_2.6.13.diff 4962
+MD5 08c3dd251a88184ac1e185c29a1f845a netfilter-layer7-v2.10.tar.gz 139265
+RMD160 56cf6ac657f392636955f6c0cd6734427089950c netfilter-layer7-v2.10.tar.gz 139265
+SHA256 d0224c7b9ecf3db1a3da29026b07acc178ed129946e4e6394b2362e93e6970c7 netfilter-layer7-v2.10.tar.gz 139265
diff --git a/net-misc/l7-filter/l7-filter-2.10.ebuild b/net-misc/l7-filter/l7-filter-2.10.ebuild
new file mode 100644
index 000000000000..336e05e3d06e
--- /dev/null
+++ b/net-misc/l7-filter/l7-filter-2.10.ebuild
@@ -0,0 +1,176 @@
+# Copyright 1999-2007 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/l7-filter/l7-filter-2.10.ebuild,v 1.1 2007/07/03 22:04:30 dragonheart Exp $
+
+inherit linux-info eutils
+
+MY_P=netfilter-layer7-v${PV/_/-}
+DESCRIPTION="Kernel modules for layer 7 iptables filtering"
+HOMEPAGE="http://l7-filter.sourceforge.net"
+SRC_URI="mirror://sourceforge/l7-filter/${MY_P}.tar.gz
+ mirror://gentoo/additional_patch_for_2.6.13.diff"
+
+LICENSE="GPL-2"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~s390 ~sh sparc ~x86"
+IUSE=""
+#break repoman
+#SLOT="${KV}"
+SLOT="0"
+S=${WORKDIR}/${MY_P}
+RDEPEND="net-misc/l7-protocols"
+
+
+which_patch() {
+ if kernel_is ge 2 6 20
+ then
+ PATCH=kernel-2.6.20-2.6.22+-layer7-2.10.patch
+ elif kernel_is ge 2 6 18
+ then
+ PATCH=for_older_kernels/kernel-2.6.18-2.6.19-layer7-2.9.patch
+ elif kernel_is ge 2 6 17
+ then
+ PATCH=for_older_kernels/kernel-2.6.17-layer7-2.5.patch
+ elif kernel_is ge 2 6 13
+ then
+ PATCH=for_older_kernels/kernel-2.6.13-2.6.16-layer7-2.2.patch
+ elif kernel_is ge 2 6 11
+ then
+ PATCH=for_older_kernels/kernel-2.6.11-2.6.12-layer7-1.4.patch
+ elif kernel_is ge 2 6 9
+ then
+ PATCH=for_older_kernels/kernel-2.6.9-2.6.10-layer7-1.2.patch
+ elif kernel_is ge 2 6 0
+ then
+ PATCH=for_older_kernels/kernel-2.6.0-2.6.8.1-layer7-0.9.2.patch
+ elif kernel_is 2 4
+ then
+ PATCH=kernel-2.4-layer7-2.10.patch
+ else
+ die "No L7-filter patch for Kernel version ${KV_FULL} - sorry not supported"
+ fi
+}
+
+pkg_setup() {
+ linux-info_pkg_setup
+ pkg_preinstall
+ pkg_postinst
+}
+
+src_unpack() {
+
+ which_patch
+
+ if [ -f ${KV_DIR}/include/linux/netfilter_ipv4/ipt_layer7.h ] || \
+ [ -f ${KV_DIR}/include/linux/netfilter/ipt_layer7.h ]
+ then
+ ewarn "already installed ${PN} for kernel ${KV_FULL}"
+ ewarn "If this is an upgrade attempt, try unmerging first."
+ ewarn "If this failes remove your kernel source from /usr/src"
+ ewarn "and remerge your kernel sources"
+ die
+ fi
+
+ unpack ${MY_P}.tar.gz
+
+ [ ! -f "${S}/${PATCH}" ] && \
+ die "patch ${PATCH} not found. Please enter a bug at bugs.gentoo.org"
+
+
+ cd ${S}
+
+ mkdir kernel
+ mkdir kernel/Documentation
+
+
+ # create needed directories
+ if kernel_is ge 2 6 20
+ then
+ mkdir -p "${S}"/kernel/net/netfilter/regexp/
+ mkdir -p "${S}"/kernel/include/net/netfilter/
+ else
+ mkdir -p "${S}"/kernel/net/ipv4/netfilter/regexp/
+ mkdir -p "${S}"/kernel/include/linux/netfilter_ipv4/
+ fi
+
+ cd ${KV_DIR}
+
+ # start to copy needed files, if file not exists create an empty file
+ FILES=$(patch -t --dry-run -p1 < "${S}"/${PATCH} | grep "^patching file" | cut -f 3 -d ' ')
+ for F in ${FILES};
+ do
+ if [ -f "${F}" ];
+ then
+ cp -P "${F}" "${S}/kernel/${F}"
+ #else
+ # touch "${S}/kernel/${F}"
+ fi
+ done
+
+ #patch the copied kernel source
+ cd ${S}/kernel
+ EPATCH_OPTS="-F 3" epatch "${S}/${PATCH}"
+
+ # https://bugs.gentoo.org/show_bug.cgi?id=106009#c5
+ if kernel_is eq 2 6 12
+ then
+ epatch "${DISTDIR}"/additional_patch_for_2.6.13.diff
+ fi
+}
+
+src_compile() {
+ einfo "no compiling - just patching source"
+}
+
+src_install() {
+ insinto "$(/bin/readlink -f ${KV_DIR})"
+ doins -r kernel/*
+ dodoc CHANGELOG README
+}
+
+pkg_preinstall() {
+ if has collision-protect ${FEATURES}; then
+ ewarn
+ ewarn "Collisions are expected as this patches kernel code. Disable"
+ ewarn "FEATURES=collision-protect before use"
+ die 'incompatible FEATURES=collision-protect'
+ fi
+}
+
+pkg_postinst() {
+ ewarn "This may not work with all kernels. If it does not work please enter a bug at bugs.gentoo.org"
+ ewarn "This only patches the current kernel source code. (${KV_DIR})"
+ ewarn "Its up to you to recompile the kernel with the l7 options"
+ ewarn
+ ewarn 'You will also need to emerge iptables with the "extensions" or'
+ ewarn '"l7filter" USE flag (depend which version of iptables you emerge)'
+}
+
+#
+# Unpatching of patched files is required to avoid a broken kernel source tree
+
+pkg_prerm() {
+ # How to determine what version it was installed against? - measily
+ eval $(/bin/fgrep KV=2 ${ROOT}/var/db/pkg/net-misc/${PF}/environment |\
+ /bin/head -1)
+ KV_DIR=/usr/src/linux-"${KV}"
+ if [ -d ${KV_DIR} ]; then
+ ewarn "${KV_DIR} nolonger exists"
+ return 0;
+ fi
+ echo "KV_DIR=$KV_DIR"
+ if [ -f ${KV_DIR}/include/linux/netfilter_ipv4/ipt_layer7.h ]
+ then
+ einfo 'attempting to unpatch l7-patch from kernel ${KV_FULL}'
+ which_patch
+ if kernel_is eq 2 6 12
+ then
+
+ patch -F 3 -d "${KV_DIR}" -R -p1 \
+ < "${DISTDIR}"/additional_patch_for_2.6.13.diff
+ fi
+ cd "${T}"
+ unpack ${MY_P}.tar.gz
+ EPATCH_SINGLE_MSG="removing previous patch" \
+ EPATCH_OPTS="-F 3 -d "${KV_DIR}" -R" epatch "${T}/${MY_P}/${PATCH}"
+ fi
+}