blob: a9a0f4c03c1e6b5d49e45bd19e690f1637040d42 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
# Copyright 1999-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-firewall/iptables/iptables-1.4.2-r2.ebuild,v 1.9 2009/02/16 16:57:34 ranger Exp $
inherit eutils toolchain-funcs linux-info
L7_PV=2.21
L7_P=netfilter-layer7-v${L7_PV}
DESCRIPTION="Linux kernel (2.4+) firewall, NAT and packet mangling tools"
HOMEPAGE="http://www.iptables.org/"
SRC_URI="http://iptables.org/projects/iptables/files/${P}.tar.bz2
l7filter? ( mirror://sourceforge/l7-filter/${L7_P}.tar.gz )"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="alpha amd64 arm hppa ia64 m68k ~mips ppc ppc64 s390 sh sparc x86"
IUSE="l7filter"
DEPEND="virtual/os-headers"
RDEPEND=""
pkg_setup() {
if use l7filter ; then
ewarn "WARNING: 3rd party extensions has been enabled."
ewarn "This means that iptables will use your currently installed"
ewarn "kernel in ${KERNEL_DIR} as headers for iptables."
linux-info_pkg_setup
if kernel_is lt 2 6 20 ; then
eerror "Currently there is no l7-filter patch available for iptables-1.4.x"
eerror "and kernel version before 2.6.20."
eerror "If you need to compile iptables 1.4.x against Linux 2.6.19.x"
eerror "or earlier, with l7-filter patch, please, report upstream."
die "No patch available."
fi
[[ ! -f ${KERNEL_DIR}/include/linux/netfilter/xt_layer7.h ]] && \
die "For layer 7 support emerge net-misc/l7-filter-${L7_PV} before this."
fi
}
src_unpack() {
unpack ${P}.tar.bz2
use l7filter && unpack ${L7_P}.tar.gz
cd "${S}"
epatch "${FILESDIR}"/${P}-glibc.patch
epatch "${FILESDIR}"/${P}-no-ldconfig.patch
epatch "${FILESDIR}"/${P}-as-needed.patch #244431
epatch "${FILESDIR}"/${P}-owner-restore.patch #255113
epatch "${FILESDIR}"/${P}-libxt_TOS-compilation.patch
epatch "${FILESDIR}"/${P}-libxt_iprange.c-build.patch
epatch "${FILESDIR}"/${P}-hashlimit.patch #254496
local check base=${PORTAGE_CONFIGROOT}/etc/portage/patches
for check in {${CATEGORY}/${PF},${CATEGORY}/${P},${CATEGORY}/${PN}}; do
EPATCH_SOURCE=${base}/${CTARGET}/${check}
[[ -r ${EPATCH_SOURCE} ]] || EPATCH_SOURCE=${base}/${CHOST}/${check}
[[ -r ${EPATCH_SOURCE} ]] || EPATCH_SOURCE=${base}/${check}
if [[ -d ${EPATCH_SOURCE} ]] ; then
EPATCH_SUFFIX="patch"
EPATCH_FORCE="yes" \
EPATCH_MULTI_MSG="Applying user patches from ${EPATCH_SOURCE} ..." \
epatch
break
fi
done
if use l7filter ; then
cp "${WORKDIR}/${L7_P}/iptables-1.4.1.1-for-kernel-2.6.20forward"/* extensions \
|| die "Failed to copy l7filter sources"
fi
}
src_compile() {
econf \
--sbindir=/sbin \
--libexecdir=/$(get_libdir) \
--enable-devel \
--enable-libipq \
--enable-shared \
--enable-static \
$(use_with l7filter kernel ${KERNEL_DIR})
emake V=1 || die
}
src_install() {
emake install DESTDIR="${D}" || die
insinto /usr/include
doins include/iptables.h include/ip6tables.h || die
dolib.a libiptc/libiptc.a || die
insinto /usr/include/libiptc
doins include/libiptc/*.h || die
keepdir /var/lib/iptables
newinitd "${FILESDIR}"/${PN}-1.3.2.init iptables
newconfd "${FILESDIR}"/${PN}-1.3.2.confd iptables
keepdir /var/lib/ip6tables
newinitd "${FILESDIR}"/iptables-1.3.2.init ip6tables
newconfd "${FILESDIR}"/ip6tables-1.3.2.confd ip6tables
}
|