commit:     8e88a75c402954c9c81d2a471be272cfd1523583
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  4 15:54:16 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct  4 15:54:16 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8e88a75c

net-misc/stunnel: add 5.71

Closes: https://bugs.gentoo.org/892992
Signed-off-by: Sam James <sam <AT> gentoo.org>

 net-misc/stunnel/Manifest                          |   1 +
 .../stunnel-5.71-dont-clobber-fortify-source.patch |  15 +++
 .../stunnel-5.71-respect-EPYTHON-for-tests.patch   |  12 ++
 net-misc/stunnel/stunnel-5.71.ebuild               | 123 +++++++++++++++++++++
 4 files changed, 151 insertions(+)

diff --git a/net-misc/stunnel/Manifest b/net-misc/stunnel/Manifest
index 1f9de1099a83..de88c8164e0d 100644
--- a/net-misc/stunnel/Manifest
+++ b/net-misc/stunnel/Manifest
@@ -1,3 +1,4 @@
 DIST stunnel-5.64.tar.gz 869088 BLAKE2B 
c6be054b825e57c1ac44adf28d4546ab78250cf9d7b17bc9e039d2715ca2316fef674a3ed2c4419a5a7ad6fa85b56809f736d0dca0bc672521347d5f51d2ed23
 SHA512 
85ed22664420db3c97b871f1afeb6483e547f421f0419fed1ccb4f3563ea154b6aeb6ae7221f001557c786a3406ada4c7b0d44b208dcf98f16209229aee4e0aa
 DIST stunnel-5.65.tar.gz 872293 BLAKE2B 
45cc4dd0ec91cb9a99c10d26910b05325af29ec2609c0b86d5aceb07fbd495ff6fe39b0fe2c5895358596ee34ed822870c6eb1a538e30557f4485d042f5ae781
 SHA512 
96ca0535a07d5ea050a5d985c0ab6299bb92e551715120f536869a7b408b795fdc251782aaa7a4a282749d3146726d71c8b3c25430969aa55745a863abe5728a
 DIST stunnel-5.68.tar.gz 884989 BLAKE2B 
e2551b2052db0719203b24dcf16a2ef74c078dccd1200d25502defcef1301456e755a71a1a2b6ab7b43fc9ddc04cd031fca83ffb760528133a0e22ae22e64d40
 SHA512 
cdc3b8ab4cd35ba722b5248c005ae58a39d79a80600447417b1d0d01fd3aa9e8b22f8568c3177423be99d7395bb15a8754e975fb953556cd80a9cc11e185e9fb
+DIST stunnel-5.71.tar.gz 895646 BLAKE2B 
d323363c7bfdd6c0b7931b84a6069cf9a8337e967c31e14d15976d7932f0c0d6f40f7a1cbf5abbdff0e9edc52176cdcead4f848653088193b2debf4e77443b42
 SHA512 
c7004f48b93b3415305eec1193d51b7bf51a3bdd2cdc9f6ae588f563b32408b1ecde83b9f3f5b658f945ab5bcc5124390c38235394aad4471bf5b666081af2a2

diff --git 
a/net-misc/stunnel/files/stunnel-5.71-dont-clobber-fortify-source.patch 
b/net-misc/stunnel/files/stunnel-5.71-dont-clobber-fortify-source.patch
new file mode 100644
index 000000000000..723b9c5e43f2
--- /dev/null
+++ b/net-misc/stunnel/files/stunnel-5.71-dont-clobber-fortify-source.patch
@@ -0,0 +1,15 @@
+Don't clobber toolchain defaults.
+
+https://bugs.gentoo.org/892992
+--- a/configure.ac
++++ b/configure.ac
+@@ -109,7 +109,8 @@ if test "${GCC}" = yes; then
+     AX_APPEND_LINK_FLAGS([-Wl,-z,now])
+     AX_APPEND_LINK_FLAGS([-Wl,-z,noexecstack])
+ fi
+-AX_APPEND_COMPILE_FLAGS([-D_FORTIFY_SOURCE=2])
++
++AX_ADD_FORTIFY_SOURCE
+ 
+ AC_MSG_NOTICE([**************************************** libtool])
+ LT_INIT([disable-static])

diff --git 
a/net-misc/stunnel/files/stunnel-5.71-respect-EPYTHON-for-tests.patch 
b/net-misc/stunnel/files/stunnel-5.71-respect-EPYTHON-for-tests.patch
new file mode 100644
index 000000000000..3c421da91484
--- /dev/null
+++ b/net-misc/stunnel/files/stunnel-5.71-respect-EPYTHON-for-tests.patch
@@ -0,0 +1,12 @@
+--- a/tests/Makefile.am
++++ b/tests/Makefile.am
+@@ -7,8 +7,7 @@ EXTRA_DIST = maketest.py plugin_collection.py reader.py 
error.py plugins
+ 
+ # try to find a supported python version (>= 3.7) that works
+ check-local:
+-      for v in $$(seq 20 -1 7); do command -v python3.$$v && break; done || ( 
echo "Python 3.7 or later not found" && false )
+-      for v in $$(seq 20 -1 7); do command -v python3.$$v && python3.$$v 
$(srcdir)/maketest.py --debug=10 --libs=$(SSLDIR)/lib64:$(SSLDIR)/lib && break; 
done
++      ${EPYTHON} $(srcdir)/maketest.py --debug=10 
--libs=$(SSLDIR)/lib64:$(SSLDIR)/lib
+ 
+ dist-hook:
+       rm -rf $(distdir)/__pycache__ $(distdir)/plugins/__pycache__

diff --git a/net-misc/stunnel/stunnel-5.71.ebuild 
b/net-misc/stunnel/stunnel-5.71.ebuild
new file mode 100644
index 000000000000..0a61d4a431b5
--- /dev/null
+++ b/net-misc/stunnel/stunnel-5.71.ebuild
@@ -0,0 +1,123 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+inherit autotools python-any-r1 ssl-cert systemd tmpfiles
+
+DESCRIPTION="TLS/SSL - Port Wrapper"
+HOMEPAGE="https://www.stunnel.org/index.html";
+SRC_URI="
+       https://www.stunnel.org/downloads/${P}.tar.gz
+       ftp://ftp.stunnel.org/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+       http://www.usenix.org.uk/mirrors/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+       
http://ftp.nluug.nl/pub/networking/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+       http://www.namesdir.com/mirrors/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+       http://stunnel.cybermirror.org/archive/${PV%%.*}.x/${P}.tar.gz
+       http://mirrors.zerg.biz/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+       ftp://mirrors.go-parts.com/stunnel/archive/${PV%%.*}.x/${P}.tar.gz
+"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sparc 
~x86 ~amd64-linux ~x86-linux ~ppc-macos"
+IUSE="selinux stunnel3 systemd tcpd test"
+RESTRICT="!test? ( test )"
+
+DEPEND="
+       dev-libs/openssl:=
+       tcpd? ( sys-apps/tcp-wrappers )
+       systemd? ( sys-apps/systemd:= )
+"
+RDEPEND="
+       ${DEPEND}
+       acct-user/stunnel
+       acct-group/stunnel
+       selinux? ( sec-policy/selinux-stunnel )
+       stunnel3? ( dev-lang/perl )
+"
+BDEPEND="
+       test? ( ${PYTHON_DEPS} )
+"
+
+PATCHES=(
+       "${FILESDIR}"/${PN}-5.71-dont-clobber-fortify-source.patch
+       "${FILESDIR}"/${PN}-5.71-respect-EPYTHON-for-tests.patch
+)
+
+pkg_setup() {
+       use test && python-any-r1_pkg_setup
+}
+
+src_prepare() {
+       default
+
+       # Hack away generation of certificate
+       sed -i -e "s/^install-data-local:/do-not-run-this:/" \
+               tools/Makefile.am || die "sed failed"
+
+       echo "CONFIG_PROTECT=\"/etc/stunnel/stunnel.conf\"" > "${T}"/20stunnel 
|| die
+
+       # We pass --disable-fips to configure, so avoid spurious test failures
+       rm tests/plugins/p10_fips.py tests/plugins/p11_fips_cipher.py || die
+
+       # Needed for FORTIFY_SOURCE patch
+       eautoreconf
+}
+
+src_configure() {
+       local myeconfargs=(
+               --libdir="${EPREFIX}/usr/$(get_libdir)"
+               --with-ssl="${EPREFIX}"/usr
+               --disable-fips
+               $(use_enable tcpd libwrap)
+               $(use_enable systemd)
+       )
+
+       econf "${myeconfargs[@]}"
+}
+
+src_install() {
+       emake DESTDIR="${D}" install
+
+       rm -rf "${ED}"/usr/share/doc/${PN} || die
+       rm -f "${ED}"/etc/stunnel/stunnel.conf-sample \
+               "${ED}"/usr/share/man/man8/stunnel.{fr,pl}.8 || die
+
+       if ! use stunnel3 ; then
+               rm -f "${ED}"/usr/bin/stunnel3 || die
+       fi
+
+       dodoc AUTHORS.md BUGS.md CREDITS.md PORTS.md README.md TODO.md
+       docinto html
+       dodoc doc/stunnel.html doc/en/VNC_StunnelHOWTO.html tools/ca.html \
+               tools/importCA.html
+
+       insinto /etc/stunnel
+       doins "${FILESDIR}"/stunnel.conf
+       newinitd "${FILESDIR}"/stunnel-r2 stunnel
+
+       doenvd "${T}"/20stunnel
+
+       systemd_dounit "${S}/tools/stunnel.service"
+       newtmpfiles "${FILESDIR}"/stunnel.tmpfiles.conf stunnel.conf
+
+       find "${ED}" -name '*.la' -delete || die
+}
+
+pkg_postinst() {
+       if [[ ! -f "${EROOT}"/etc/stunnel/stunnel.key ]]; then
+               install_cert /etc/stunnel/stunnel
+               chown stunnel:stunnel 
"${EROOT}"/etc/stunnel/stunnel.{crt,csr,key,pem}
+               chmod 0640 "${EROOT}"/etc/stunnel/stunnel.{crt,csr,key,pem}
+       fi
+
+       tmpfiles_process stunnel.conf
+
+       einfo "If you want to run multiple instances of stunnel, create a new 
config"
+       einfo "file ending with .conf in /etc/stunnel/. **Make sure** you 
change "
+       einfo "\'pid= \' with a unique filename.  For openrc make a symlink 
from the"
+       einfo "stunnel init script to \'stunnel.name\' and use that to 
start|stop"
+       einfo "your custom instance"
+}

Reply via email to