net-firewall/fwknop: Version bump to 2.6.10.
authorHank Leininger <hlein@korelogic.com>
Sat, 26 Oct 2019 22:46:45 +0000 (16:46 -0600)
committerJoonas Niilola <juippis@gentoo.org>
Mon, 4 Nov 2019 05:42:51 +0000 (07:42 +0200)
Also changed SRC_URI to the main upstream site because github
mangles the .tar.gz to break upstream's PGP signature.

Signed-off-by: Hank Leininger <hlein@korelogic.com>
Bug: https://bugs.gentoo.org/698604
Package-Manager: Portage-2.3.78, Repoman-2.3.17
Signed-off-by: Joonas Niilola <juippis@gentoo.org>
net-firewall/fwknop/Manifest
net-firewall/fwknop/fwknop-2.6.10.ebuild [new file with mode: 0644]

index 27210436a6a2d5afbff7535b170b7ed2438b70a8..d49b6b5fc1a30597738d9ed3cfbc8392eae7fa74 100644 (file)
@@ -1 +1,2 @@
+DIST fwknop-2.6.10.tar.gz 1988197 BLAKE2B d4c2010c64ab160f0edc02e2b1530749ee47ff6ed16d6b556d366daef7ce5e22ef38fbbbf6e8cfaa14e0d9706ba2b65937b03c70b54b3429ff1732ae33c1852c SHA512 3b3e35eda574abd1759431c88677eea7078c54cb3252c0ee0e1019b5b8224ed8844d30760da70a952e1cd92b04715a547f6effabda54678f791fff9afa32cd80
 DIST fwknop-2.6.9.tar.gz 3043542 BLAKE2B 11440fa0fe5e990a269587fa9ee1da0242f3dc939d6dc185d6adff9e9c995a8ffe902a6351a057c619cb6ff056519caea38f7b865978fe5ac810a39281bb3fc3 SHA512 4706560d44c911c8604059d88dded9c1b8c333399d90ec7dc366c0fba96c79680bdbf1b8b5e76cc34aaf3a1e58fff80db8f5f20c96d57481bdb476a9b99f4d1b
diff --git a/net-firewall/fwknop/fwknop-2.6.10.ebuild b/net-firewall/fwknop/fwknop-2.6.10.ebuild
new file mode 100644 (file)
index 0000000..41a07f7
--- /dev/null
@@ -0,0 +1,130 @@
+# Copyright 1999-2019 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+# Python extension supports only Python 2.
+# See https://github.com/mrash/fwknop/issues/167
+PYTHON_COMPAT=( python2_7 )
+DISTUTILS_OPTIONAL=1
+
+inherit autotools distutils-r1 eutils linux-info readme.gentoo-r1 systemd
+
+DESCRIPTION="Single Packet Authorization and Port Knocking application"
+HOMEPAGE="https://www.cipherdyne.org/fwknop/"
+SRC_URI="https://www.cipherdyne.org/fwknop/download/${P}.tar.gz"
+
+LICENSE="GPL-2+"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+IUSE="+client extras firewalld gdbm gpg +iptables nfqueue python +server udp-server"
+
+DEPEND="
+       client? ( net-misc/wget[ssl] )
+       firewalld? ( net-firewall/firewalld[${PYTHON_USEDEP}] )
+       gdbm? ( sys-libs/gdbm )
+       gpg? (
+               app-crypt/gpgme
+               dev-libs/libassuan
+               dev-libs/libgpg-error
+       )
+       iptables? ( net-firewall/iptables )
+       nfqueue? ( net-libs/libnetfilter_queue )
+       python? ( ${PYTHON_DEPS} )
+       server? ( !nfqueue? ( !udp-server? ( net-libs/libpcap ) ) )
+"
+RDEPEND="${DEPEND}"
+
+REQUIRED_USE="
+       nfqueue? ( server )
+       python? ( ${PYTHON_REQUIRED_USE} )
+       server? ( ^^ ( firewalld iptables ) )
+       udp-server? ( server )
+"
+
+DOCS=( AUTHORS ChangeLog README )
+
+DISABLE_AUTOFORMATTING=1
+DOC_CONTENTS="
+Example configuration files were installed to '${EPREFIX}/etc/fwknopd/'.
+Please edit them to suit your needs and then remove the .example suffix.
+
+fwknopd supports several backends: firewalld, iptables, ipfw, pf, ipf.
+You can set the desired backend via FIREWALL_EXE option in fwknopd.conf
+instead of the default one chosen at compile time.
+"
+
+src_prepare() {
+       default_src_prepare
+
+       # Install example configs with .example suffix.
+       if use server; then
+               sed -i -e 's|conf;|conf.example;|g' Makefile.am || die
+       fi
+
+       eautoreconf
+}
+
+src_configure() {
+       local myeconfargs=(
+               --localstatedir="${EPREFIX}/run"
+               $(use_enable client)
+               $(use_enable !gdbm file-cache)
+               $(use_enable nfqueue nfq-capture)
+               $(use_enable server)
+               $(use_enable udp-server)
+               $(use_with gpg gpgme)
+       )
+       use firewalld && myeconfargs+=(--with-firewalld="${EPREFIX}/usr/sbin/firewalld")
+       use iptables && myeconfargs+=(--with-iptables="${EPREFIX}/sbin/iptables")
+
+       econf "${myeconfargs[@]}"
+}
+
+src_install() {
+       default_src_install
+
+       if use extras; then
+               dodoc extras/apparmor/usr.sbin.fwknopd
+               dodoc extras/console-qr/console-qr.sh
+               dodoc extras/fwknop-launcher/*
+       fi
+
+       if use server; then
+               newinitd "${FILESDIR}/fwknopd.init" fwknopd
+               newconfd "${FILESDIR}/fwknopd.confd" fwknopd
+               systemd_dounit "${FILESDIR}/fwknopd.service"
+               systemd_newtmpfilesd "${FILESDIR}/fwknopd.tmpfiles.conf" fwknopd.conf
+               readme.gentoo_create_doc
+       fi
+
+       if use python; then
+               # Redefine DOCS, otherwise distutils-r1 eclass interferes.
+               local DOCS=()
+               cd python || die
+               distutils-r1_src_install
+       fi
+
+       find "${ED}" -type f -name "*.la" -delete || die
+}
+
+pkg_postinst() {
+       if use server; then
+               readme.gentoo_print_elog
+
+               if ! linux_config_exists || ! linux_chkconfig_present NETFILTER_XT_MATCH_COMMENT; then
+                       echo
+                       ewarn "fwknopd daemon relies on the 'comment' match in order to expire"
+                       ewarn "created firewall rules, which is an important security feature."
+                       ewarn "Please enable NETFILTER_XT_MATCH_COMMENT support in your kernel."
+                       echo
+               fi
+               if use nfqueue && \
+                       ! linux_config_exists || ! linux_chkconfig_present NETFILTER_XT_TARGET_NFQUEUE; then
+                       echo
+                       ewarn "fwknopd daemon relies on the 'NFQUEUE' target for NFQUEUE mode."
+                       ewarn "Please enable NETFILTER_XT_TARGET_NFQUEUE support in your kernel."
+                       echo
+               fi
+       fi
+}