From 5b628e8c66c39d9f89d054119d346d9b780def37 Mon Sep 17 00:00:00 2001 From: Peter Volkov Date: Thu, 29 Apr 2010 09:31:02 +0000 Subject: Initial import, ebuild by me. Fixes bug #250407, thank Nathan McSween for report and others who tested this package. (Portage version: 2.1.8.3/cvs/Linux x86_64) --- net-firewall/xtables-addons/ChangeLog | 11 ++ net-firewall/xtables-addons/metadata.xml | 18 +++ .../xtables-addons/xtables-addons-1.25.ebuild | 137 +++++++++++++++++++++ 3 files changed, 166 insertions(+) create mode 100644 net-firewall/xtables-addons/ChangeLog create mode 100644 net-firewall/xtables-addons/metadata.xml create mode 100644 net-firewall/xtables-addons/xtables-addons-1.25.ebuild (limited to 'net-firewall') diff --git a/net-firewall/xtables-addons/ChangeLog b/net-firewall/xtables-addons/ChangeLog new file mode 100644 index 000000000000..d58221b30d69 --- /dev/null +++ b/net-firewall/xtables-addons/ChangeLog @@ -0,0 +1,11 @@ +# ChangeLog for net-firewall/xtables-addons +# Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/net-firewall/xtables-addons/ChangeLog,v 1.1 2010/04/29 09:31:02 pva Exp $ + +*xtables-addons-1.25 (29 Apr 2010) + + 29 Apr 2010; Peter Volkov +xtables-addons-1.25.ebuild, + +metadata.xml: + Initial import, ebuild by me. Fixes bug #250407, thank Nathan McSween for + report and others who tested this package. + diff --git a/net-firewall/xtables-addons/metadata.xml b/net-firewall/xtables-addons/metadata.xml new file mode 100644 index 000000000000..1fe6ec70cbee --- /dev/null +++ b/net-firewall/xtables-addons/metadata.xml @@ -0,0 +1,18 @@ + + + +no-herd + + pva@gentoo.org + Peter Volkov + + +Xtables-addons is the successor to patch-o-matic(-ng). Likewise, it contains +extensions that were not, or are not yet, accepted in the main kernel/iptables +packages. + +Xtables-addons is different from patch-o-matic in that you do not have to patch +or recompile the kernel, sometimes recompiling iptables is also not needed. But +please see the INSTALL file for the minimum requirements of this package. + + diff --git a/net-firewall/xtables-addons/xtables-addons-1.25.ebuild b/net-firewall/xtables-addons/xtables-addons-1.25.ebuild new file mode 100644 index 000000000000..9e27e4dc16dd --- /dev/null +++ b/net-firewall/xtables-addons/xtables-addons-1.25.ebuild @@ -0,0 +1,137 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-firewall/xtables-addons/xtables-addons-1.25.ebuild,v 1.1 2010/04/29 09:31:02 pva Exp $ + +EAPI="2" + +inherit eutils linux-mod + +DESCRIPTION="extensions not yet accepted in the main kernel/iptables (patch-o-matic(-ng) successor)" +HOMEPAGE="http://xtables-addons.sourceforge.net/" +SRC_URI="mirror://sourceforge/xtables-addons/${P}.tar.bz2" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="modules" + +MODULES="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq steal rawnat logmark ipmark echo dhcpmac delude chaos account" + +for mod in ${MODULES}; do + IUSE="${IUSE} xtables_addons_${mod}" +done + +RDEPEND="virtual/modutils + >=net-firewall/iptables-1.4.3 + >virtual/linux-sources-2.6.22 + xtables_addons_ipset? ( !net-firewall/ipset )" + +DEPEND="${RDEPEND}" + +pkg_setup() { + if use modules; then + get_version + check_modules_supported + # CONFIG_IP_NF_CONNTRACK{,_MARK} doesn't exist in >virtual/linux-sources-2.6.22 + CONFIG_CHECK="NF_CONNTRACK NF_CONNTRACK_MARK" + linux-mod_pkg_setup + + if ! linux_chkconfig_present IPV6; then + SKIP_IPV6_MODULES="ip6table_rawpost" + fi + fi +} + +# Helper for maintainer: cheks if all possible MODULES are listed. +XA_qa_check() { + local all_modules + all_modules=$(sed -n '/^build_/{s/build_\(.*\)=.*/\L\1/;G;s/\n/ /;s/ $//;h}; ${x;p}' "${S}/mconfig") + if [[ ${all_modules} != ${MODULES} ]]; then + ewarn "QA: Modules in mconfig differ from \$MODULES in ebuild." + ewarn "Please, update MODULES in ebuild." + ewarn "'${all_modules}'" + fi +} + +# Is there any use flag set? +XA_has_something_to_build() { + local mod + for mod in ${MODULES}; do + use xtables_addons_${mod} && return + done + + eerror "All modules are disabled. What do you want me to build?" + eerror "Please, set XTABLES_ADDONS to any combination of" + eerror "${MODULES}" + die "All modules are disabled." +} + +# Parse Kbuid files and generates list of sources +XA_get_module_name() { + [[ $# != 1 ]] && die "XA_get_sources_for_mod: needs exactly one argument." + local mod objdir build_mod sources_list + mod=${1} + objdir=${S}/extensions + build_mod=$(sed -n "s/\(build_${mod}\)=.*/\1/Ip" "${S}/mconfig") + sources_list=$(sed -n "/^obj-[$][{]${build_mod}[}]/\ + {s:obj-[^+]\+ [+]=[[:space:]]*::;s:[.]o::g;p}" \ + "${objdir}/Kbuild") + + if [[ -d ${S}/extensions/${sources_list} ]]; then + objdir=${S}/extensions/${sources_list} + sources_list=$(sed -n "/^obj-m/\ + {s:obj-[^+]\+ [+]=[[:space:]]*::;s:[.]o::g;p}" \ + "${objdir}/Kbuild") + fi + for mod_src in ${sources_list}; do + has ${mod_src} ${SKIP_IPV6_MODULES} || \ + echo " ${mod_src}(xtables_addons:${S}/extensions:${objdir})" + done +} + +src_prepare() { + XA_qa_check + XA_has_something_to_build + + local mod module_name + if use modules; then + MODULE_NAMES="compat_xtables(xtables_addons:${S}/extensions:)" + fi + for mod in ${MODULES}; do + if use xtables_addons_${mod}; then + sed "s/\(build_${mod}=\).*/\1m/I" -i mconfig || die + if use modules; then + for module_name in $(XA_get_module_name ${mod}); do + MODULE_NAMES+=" ${module_name}" + done + fi + else + sed "s/\(build_${mod}=\).*/\1n/I" -i mconfig || die + fi + done + + sed -e 's/depmod -a/true/' -i Makefile.{in,am} || die + sed -e '/^all-local:/{s: modules::}' \ + -e '/^install-exec-local:/{s: modules_install::}' \ + -i extensions/Makefile.{in,am} || die +} + +src_configure() { + unset ARCH # .. or it'll look for /arch/amd64/Makefile in linux sources + export KBUILD_EXTMOD=${S} # Avoid build in /usr/src/linux #250407 + econf --prefix=/ \ + --libexecdir=/lib/ \ + --with-kbuild="${KV_DIR}" +} + +src_compile() { + emake CFLAGS="${CFLAGS}" CC="$(tc-getCC)" || die + use modules && BUILD_TARGETS="modules" linux-mod_src_compile +} + +src_install() { + emake DESTDIR="${D}" install || die + use modules && linux-mod_src_install + dodoc README doc/* || die + find "${D}" -type f -name '*.la' -exec rm -rf '{}' '+' +} -- cgit v1.2.3-65-gdbad