commit:     b327d5d84978188cc287fd509c93bce7e411def6
Author:     Peter Leese <inbox <AT> peterleese <DOT> org>
AuthorDate: Sun Nov  2 19:46:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov  4 11:21:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b327d5d8

net-misc/kea: add 3.0.2

Bug: https://bugs.gentoo.org/965298
Signed-off-by: Peter Leese <inbox <AT> peterleese.org>
Part-of: https://github.com/gentoo/gentoo/pull/44438
Closes: https://github.com/gentoo/gentoo/pull/44438
Signed-off-by: Sam James <sam <AT> gentoo.org>

 net-misc/kea/Manifest         |   2 +
 net-misc/kea/kea-3.0.2.ebuild | 305 ++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 307 insertions(+)

diff --git a/net-misc/kea/Manifest b/net-misc/kea/Manifest
index d67c0053e44a..dcb876b3f278 100644
--- a/net-misc/kea/Manifest
+++ b/net-misc/kea/Manifest
@@ -1,4 +1,6 @@
 DIST kea-2.6.3.tar.gz 10498882 BLAKE2B 
7a8549ceb86dccaa2ca8d541cbfd27618ccf8aeedfb8ff26f9d0e10cfd8a103efd70320a55dc318a84094a7764c560c100cf6e10421ae6d40e6c62891570c604
 SHA512 
d7781c0b95529bfe89c19615c1dd5952fd4c4b60274e187a641992dad81ef5af921dfb15050ec43169a0c2ad267639642b2e294c5d43405f85a5fb11bb1a939a
 DIST kea-2.6.4.tar.gz 10498705 BLAKE2B 
491a73dd0d4f7ffc068642d14a597158b70a5e6042967fd1f367f3269dd84bc4f1526b4158c7da8a474e385528b74985ac542c1591c458c6a0df42fc627b612d
 SHA512 
f4dce03a30ba5c0a1a0d97730d7cccc0876188fb7d165e8f67cf4df906cdf157049d651d0a38b3a01f33e5b0ac7b9e8b5b479543e06c89da197d6ef9d0937a18
 DIST kea-3.0.1.tar.xz 6632284 BLAKE2B 
7fc66680ddfd6805cb8eb7480d552c8fbd29416175cb2b81e0ef68436e1a2ed9c94c50e0a7037402e02620ef047a66c8dcafb3d89a6a0d7d552c5d5da04f5755
 SHA512 
84e2164aa91c95b2e6e65994a2327fa1233c82b06af69312f55464119d4edc6151a4662a54f4a3ae83e0487dac7b25c5e59e60bcbed653fd30fb32ae7cacddf3
+DIST kea-3.0.2.tar.xz 6634300 BLAKE2B 
8c7dccbb118f09e0c4dbd0fbb1889fba03bda633bedd6b05f91445d0979bbbedd8c7150ceaad73a280e58401eba4671398c65717f747b661fa0891e310dac1ea
 SHA512 
454081be248d6021aa99bfe027111f093795b123c827c6062e29a215856d29ec827f5757a1a6fc3351e74276563f101b52f26db2098cdd0b4e6f86e1b3449ba3
 DIST kea-manpages-3.0.1.tar.gz 6789 BLAKE2B 
37d79b0be3959cc0b12a4f0a782feb4065a7dffd741551f9ab1edfe1c4c3db0dc4fed24881a9e11fa2aeb214e8b094894f48741a5823e13d78fb41837adf0975
 SHA512 
4930173e93a8ae7ac0a933a8d82a1c90f79321365bf02f3995d8ef0496bddf4f611cf2d23c806ecee5017e7b98c2799d0d3ac00a66535be35898f89cd3f75f86
+DIST kea-manpages-3.0.2.tar.gz 6743 BLAKE2B 
30d254a0db2b635493a0f9fe5480cf731978532f860d9acf74f8d6114539f0f9e594aa68aeb1181ee05da51707fd35a900be72c79bc7abf31124c1c5ea439ef4
 SHA512 
cfcf91abfd34e44319d4ea58de15bc068e5c7be7c94f211e85890009ef285ab84ca310dbe4ba8879a4797574715086861755cd528ea90a65e88980adeabc43a1

diff --git a/net-misc/kea/kea-3.0.2.ebuild b/net-misc/kea/kea-3.0.2.ebuild
new file mode 100644
index 000000000000..9d954aca8489
--- /dev/null
+++ b/net-misc/kea/kea-3.0.2.ebuild
@@ -0,0 +1,305 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{11..14} )
+inherit eapi9-ver flag-o-matic meson python-r1 systemd tmpfiles toolchain-funcs
+
+DESCRIPTION="High-performance production grade DHCPv4 & DHCPv6 server"
+HOMEPAGE="https://www.isc.org/kea/";
+
+if [[ ${PV} == 9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://gitlab.isc.org/isc-projects/kea.git";
+else
+       SRC_URI="
+               https://downloads.isc.org/isc/kea/${PV}/${P}.tar.xz
+               !doc? ( 
https://codeberg.org/peter1010/kea-manpages/archive/kea-manpages-${PV}.tar.gz )
+       "
+       KEYWORDS="~amd64 ~arm ~arm64 ~x86"
+fi
+
+LICENSE="MPL-2.0"
+SLOT="0"
+IUSE="debug doc kerberos mysql +openssl postgres shell test"
+
+REQUIRED_USE="shell? ( ${PYTHON_REQUIRED_USE} )"
+RESTRICT="!test? ( test )"
+
+COMMON_DEPEND="
+       >=dev-libs/boost-1.66:=
+       dev-libs/log4cplus:=
+       kerberos? ( virtual/krb5 )
+       mysql? (
+               app-arch/zstd:=
+               dev-db/mysql-connector-c:=
+               dev-libs/openssl:=
+               virtual/zlib:=
+       )
+       !openssl? ( dev-libs/botan:3=[boost] )
+       openssl? ( dev-libs/openssl:0= )
+       postgres? ( dev-db/postgresql:* )
+       shell? ( ${PYTHON_DEPS} )
+"
+DEPEND="${COMMON_DEPEND}
+       test? ( dev-cpp/gtest )
+"
+RDEPEND="${COMMON_DEPEND}
+       acct-group/dhcp
+       acct-user/dhcp
+"
+BDEPEND="
+       >=dev-build/meson-1.8
+       doc? (
+               $(python_gen_any_dep '
+                       dev-python/sphinx[${PYTHON_USEDEP}]
+                       dev-python/sphinx-rtd-theme[${PYTHON_USEDEP}]
+               ')
+       )
+       virtual/pkgconfig
+       ${PYTHON_DEPS}
+"
+
+PATCHES=(
+       "${FILESDIR}"/kea-3.0.1-boost-1.89.patch
+)
+
+python_check_deps() {
+       use doc || return 0;
+       python_has_version "dev-python/sphinx[${PYTHON_USEDEP}]" \
+               "dev-python/sphinx-rtd-theme[${PYTHON_USEDEP}]"
+}
+
+pkg_setup() {
+       python_setup
+}
+
+src_prepare() {
+       default
+
+       # Fix up all doc paths, whether or not we are installing full set of 
docs
+       sed -e "s:'doc/kea':'doc/${PF}':" \
+               -i meson.build || die
+       sed -e "s:'share/doc/kea':'share/doc/${PF}':" \
+               -i doc/meson.build || die
+       sed -e "s:'doc/kea':'doc/${PF}':" \
+               -i doc/sphinx/meson.build || die
+       sed -e "s:share/doc/kea/:share/doc/${PF}/:" \
+               -i doc/sphinx/arm/install.rst || die
+       sed -e "s:share/doc/kea/examples:share/doc/${PF}/examples:" \
+               -i doc/sphinx/arm/config.rst || die
+
+       # set shebang before meson whether or not we are installing the shell
+       sed -e 's:^#!@PYTHON@:#!/usr/bin/env python3:' \
+               -i src/bin/shell/kea-shell.in || die
+
+       # Don't allow meson to install shell, we shall do that if required
+       sed -e 's:install\: true:install\: false:' \
+               -i src/bin/shell/meson.build || die
+
+       # do not create /run
+       sed -e '/^install_emptydir(RUNSTATEDIR)$/d' \
+               -i meson.build || die
+}
+
+src_configure() {
+       # https://bugs.gentoo.org/861617
+       # https://gitlab.isc.org/isc-projects/kea/-/issues/3946
+       #
+       # Kea Devs say no to LTO
+       filter-lto
+
+       if use !openssl; then
+               append-cxxflags -std=c++20
+       fi
+
+       local emesonargs=(
+               --localstatedir="${EPREFIX}/var"
+               -Drunstatedir="${EPREFIX}/run"
+               $(meson_feature kerberos krb5)
+               -Dnetconf=disabled
+               -Dcrypto=$(usex openssl openssl botan)
+               $(meson_feature mysql)
+               $(meson_feature postgres postgresql)
+               $(meson_feature test tests)
+       )
+       if use debug; then
+               emesonargs+=(
+                       --debug
+               )
+       fi
+       meson_src_configure
+}
+
+src_compile() {
+       meson_src_compile
+
+       use doc && meson_src_compile doc
+}
+
+src_test() {
+       # Get list of all test suites into an associative array
+       # the meson test --list returns either "kea / test_suite", 
"kea:shell-tests / test_suite" or
+       # "kea:python-tests / test_suite"
+       # Discard the shell tests as we can't run shell tests in sandbox
+
+       pushd "${BUILD_DIR}" || die
+       local -A TEST_SUITES
+       while IFS=" / " read -r subsystem test_suite ; do
+               if [[ ${subsystem} != "kea:shell-tests" ]]; then
+                       TEST_SUITES["$test_suite"]=1
+               fi
+       done < <(meson test --list || die)
+       popd
+
+       # Some other tests will fail for interface access restrictions, we have 
to remove the test suites those tests
+       # belong to
+       local SKIP_TESTS=(
+               dhcp-radius-tests
+               kea-log-buffer_logger_test.sh
+               kea-log-console_test.sh
+               dhcp-lease-query-tests
+               kea-dhcp6-tests
+               kea-dhcp4-tests
+               kea-dhcp-tests
+       )
+
+       # skip shell tests that require a running instance of MySQL
+       if use mysql; then
+               SKIP_TESTS+=(
+                       kea-mysql-tests
+                       dhcp-mysql-lib-tests
+                       dhcp-forensic-log-libloadtests
+               )
+       fi
+
+       # skip shell tests that require a running instance of PgSQL
+       if use postgres; then
+               SKIP_TESTS+=(
+                       kea-pgsql-tests
+                       dhcp-pgsql-lib-tests
+                       dhcp-forensic-log-libloadtests
+               )
+       fi
+
+       if use kerberos; then
+               SKIP_TESTS+=(
+                       ddns-gss-tsig-tests
+               )
+       fi
+
+       if [[ $(tc-get-ptr-size) -eq 4 ]]; then
+               # see https://bugs.gentoo.org/958171 for reason for skipping 
these tests
+               SKIP_TESTS+=(
+                       kea-util-tests
+                       kea-dhcpsrv-tests
+                       dhcp-ha-lib-tests
+                       kea-d2-tests
+               )
+       fi
+
+       for SKIP in ${SKIP_TESTS[@]}; do
+               unset TEST_SUITES["${SKIP}"]
+       done
+
+       meson_src_test ${!TEST_SUITES[@]}
+}
+
+install_shell() {
+       python_domodule ${ORIG_BUILD_DIR}/src/bin/shell/*.py
+       python_doscript ${ORIG_BUILD_DIR}/src/bin/shell/kea-shell
+
+       # fix path to import kea modules
+       sed -e "/^sys.path.append/s|(.*)|('$(python_get_sitedir)/${PN}')|"      
\
+               -i "${ED}"/usr/lib/python-exec/${EPYTHON}/kea-shell || die
+}
+
+src_install() {
+       meson_install
+
+       # Tidy up
+       rm -r "${ED}"/usr/share/kea/meson-info || die
+       if use !mysql; then
+               rm -r "${ED}"/usr/share/kea/scripts/mysql || die
+       fi
+       if use !postgres; then
+               rm -r "${ED}"/usr/share/kea/scripts/pgsql || die
+       fi
+
+       # No easy way to control how meson_install sets permissions in meson < 
1.9
+       # So make sure permissions are same as in previous versions of kea
+       # To avoid any differences between an update vers first time install
+       fperms -R 0755 /usr/sbin
+       fperms -R 0755 /usr/bin
+       fperms -R 0755 /usr/$(get_libdir)
+
+       if use shell; then
+               python_moduleinto ${PN}
+               ORIG_BUILD_DIR=${BUILD_DIR} python_foreach_impl install_shell
+       fi
+
+       # We don't use keactrl.conf so move to reduce confusion
+       mv "${ED}"/etc/${PN}/keactrl.conf 
"${ED}"/usr/share/doc/${PF}/examples/keactrl.conf || die
+
+       fowners -R root:dhcp /etc/${PN}
+
+       # Install a conf per service and a linked init script per service
+       newinitd "${FILESDIR}"/${PN}-initd-r3 ${PN}
+       local svc
+       for svc in dhcp4 dhcp6 dhcp-ddns ctrl-agent; do
+               newconfd "${FILESDIR}"/${PN}-confd-r3 kea-${svc}
+               sed -e "s:@KEA_SVC@:${svc}:g" \
+                       -i "${ED}"/etc/conf.d/kea-${svc} || die
+               dosym kea "${EPREFIX}"/etc/init.d/kea-${svc}
+       done
+
+       if use !doc; then
+               doman "${WORKDIR}"/kea-manpages/man/*
+       fi
+
+       systemd_newunit "${FILESDIR}"/${PN}-ctrl-agent.service-r2 
${PN}-ctrl-agent.service
+       systemd_newunit "${FILESDIR}"/${PN}-dhcp-ddns.service-r2 
${PN}-dhcp-ddns.service
+       systemd_newunit "${FILESDIR}"/${PN}-dhcp4.service-r2 ${PN}-dhcp4.service
+       systemd_newunit "${FILESDIR}"/${PN}-dhcp6.service-r2 ${PN}-dhcp6.service
+
+       newtmpfiles "${FILESDIR}"/${PN}.tmpfiles.conf ${PN}.conf
+
+       keepdir /var/lib/${PN} /var/log/${PN}
+       fowners -R dhcp:dhcp /var/lib/${PN} /var/log/${PN}
+       fperms 750 /var/lib/${PN} /var/log/${PN}
+}
+
+pkg_postinst() {
+       tmpfiles_process ${PN}.conf
+
+       if ver_replacing -lt 2.6; then
+               ewarn "Several changes have been made for daemons:"
+               ewarn "  To comply with common practices for this package,"
+               ewarn "  config paths by default has been changed as below:"
+               ewarn "    /etc/kea/kea-dhcp4.conf"
+               ewarn "    /etc/kea/kea-dhcp6.conf"
+               ewarn "    /etc/kea/kea-dhcp-ddns.conf"
+               ewarn "    /etc/kea/kea-ctrl-agent.conf"
+               ewarn
+               ewarn "  Daemons are launched by default with the unprivileged 
user 'dhcp'"
+               ewarn
+               ewarn "Please check your configuration!"
+       fi
+
+       if ver_replacing -lt 3.0; then
+               ewarn "If using openrc;"
+               ewarn "  There are now separate conf.d scripts and associated 
init.d per daemon!"
+               ewarn "    Each Daemon needs to be launched separately, i.e. 
the daemons are"
+               ewarn "      kea-dhcp4"
+               ewarn "      kea-dhcp6"
+               ewarn "      kea-dhcp-ddns"
+               ewarn "      kea-ctrl"
+               ewarn "Please adjust your service startups appropriately"
+       fi
+
+       if ! has_version net-misc/kea; then
+               elog "See examples of config files in:"
+               elog "  ${EROOT}/usr/share/doc/${PF}/examples"
+       fi
+}

Reply via email to