commit: 901358f7b67d6b7e98192dbcaa7e18f0fafef5a7 Author: Nicolas PARLANT <nicolas.parlant <AT> parhuet <DOT> fr> AuthorDate: Fri May 30 20:56:17 2025 +0000 Commit: Sam James <sam <AT> gentoo <DOT> org> CommitDate: Mon Jun 2 21:39:15 2025 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=901358f7
net-dns/knot-resolver: add 6.0.13 DoS - fix more rare crashes with `requirement` failing : https://gitlab.nic.cz/knot/knot-resolver/-/issues/930 include a patch from upstream to fix a regression Bug: https://bugs.gentoo.org/954555 Signed-off-by: Nicolas PARLANT <nicolas.parlant <AT> parhuet.fr> Part-of: https://github.com/gentoo/gentoo/pull/42367 Signed-off-by: Sam James <sam <AT> gentoo.org> net-dns/knot-resolver/Manifest | 2 + ...knot-resolver-6.0.13-fix_template_regress.patch | 52 ++++++ net-dns/knot-resolver/knot-resolver-6.0.13.ebuild | 184 +++++++++++++++++++++ 3 files changed, 238 insertions(+) diff --git a/net-dns/knot-resolver/Manifest b/net-dns/knot-resolver/Manifest index 5416174e8d70..4fcfa6eb0e62 100644 --- a/net-dns/knot-resolver/Manifest +++ b/net-dns/knot-resolver/Manifest @@ -2,3 +2,5 @@ DIST knot-resolver-5.7.5.tar.xz 1924960 BLAKE2B cad47756832b34399ea0437ef041ddbf DIST knot-resolver-5.7.5.tar.xz.asc 833 BLAKE2B 675b91253c5ae72db9e1ef6513a681538967f72b6b7a91f2159b42e7581b398a0a90df7e75da0e6818f1a20549a23677ab34722bbcf762cad019d4c211221f1e SHA512 df06eb244fa051a5f71385424b2da2479203019c6824344ec2226bc4851a3eb12eb3bb0f6f5a3e5ccce8c5875b6867924fa46b6939545cb35b24ef799f9ef6b0 DIST knot-resolver-6.0.12.tar.xz 2144940 BLAKE2B 72a8592591ba7ca8ee8b57eae105096125a71f7d4a7e1b096962683f66cc608f65ad5743ee2213b0b898983c52cf9b7d651088929b56db952871bb8b03607283 SHA512 2941de1d05258a627fa859de826487e940cd0c90befa5d2a678e0bf3111c048cb558cfe1258711417bec71a6f0d6e38aa40c1ba6743f3279862684109634d6dc DIST knot-resolver-6.0.12.tar.xz.asc 833 BLAKE2B ffb7758c151485fe65e8ad636767943b1280d4a02d5889fbc22247fcfe1d3d53969e369cff6d0d2a438ed241f96ec2c97d792fc7d07af3f51ec252eb20357c42 SHA512 1adafdb6ffcf8d2bcb0a6b6ed2a39eb8be237954280f8845fef62dc32dfa64f5101400db94d8ecad30c27c8ca21945414b8c4c4ec0db88ba8be679e99c60947e +DIST knot-resolver-6.0.13.tar.xz 2147116 BLAKE2B 0a5521fb0b33dd0122b4b7139f60b549517e3091beb3a196489fee8d7b9fbc5400166a900aa1cf2fbe9543862b21de9c02985ccbd71f04bb3950c27f5496ef9f SHA512 200219b6156e76bdb10a679dadd3de076df4d59ca2090b80fd59328ab343b403ae68a625e7f4e47ed92d041938176013bc142404571678bd44976b6a84c3ec95 +DIST knot-resolver-6.0.13.tar.xz.asc 833 BLAKE2B 2f91962a0c8f0bfc4b68b5a66212dfac45d3060a6132aeaa945b4badc1fb32a22552f5451f8ba35c61f2c3c8edf6444dc407633dc63f37b5b0f042bf256321ef SHA512 2d34ea2a67644082f9017166df855bcfc13b41ce09ec49e9317e4806c3ea7affa143571877dca0c7244763aeee64a3c5b8d34743616fb600d350a8a9c1465c88 diff --git a/net-dns/knot-resolver/files/knot-resolver-6.0.13-fix_template_regress.patch b/net-dns/knot-resolver/files/knot-resolver-6.0.13-fix_template_regress.patch new file mode 100644 index 000000000000..54171b1443c1 --- /dev/null +++ b/net-dns/knot-resolver/files/knot-resolver-6.0.13-fix_template_regress.patch @@ -0,0 +1,52 @@ +https://gitlab.nic.cz/knot/knot-resolver/-/merge_requests/1697/ +From 00929c0b0af776b4a5e344b6f3a0541fefe93db2 Mon Sep 17 00:00:00 2001 +From: Brad Cowie <[email protected]> +Date: Fri, 30 May 2025 13:57:25 +1200 +Subject: [PATCH 1/2] datamodel/templates: fix kr_rule_local_* macros + +commit a782e9c3 broke the jinja2 generation of the +kr_rule_local_* macro functions. C.KR_RULE_OPTS_DEFAULT +was provided as an argument to the assert() function call +instead of the call to the corresponding C.kr_rule_local_* function +--- + .../templates/macros/local_data_macros.lua.j2 | 10 +++++----- + 1 file changed, 5 insertions(+), 5 deletions(-) + +diff --git a/python/knot_resolver/datamodel/templates/macros/local_data_macros.lua.j2 b/python/knot_resolver/datamodel/templates/macros/local_data_macros.lua.j2 +index e91b82685..39029b3c7 100644 +--- a/python/knot_resolver/datamodel/templates/macros/local_data_macros.lua.j2 ++++ b/python/knot_resolver/datamodel/templates/macros/local_data_macros.lua.j2 +@@ -28,8 +28,8 @@ hints.root_file('{{ file }}') + + {% macro kr_rule_local_address(name, address, nodata, ttl, tags=none) -%} + assert(C.kr_rule_local_address('{{ name }}', '{{ address }}', +- {{ boolean(nodata) }}, {{ local_data_ttl(ttl)}}, {{ policy_get_tagset(tags) }}) == 0, +- C.KR_RULE_OPTS_DEFAULT) ++ {{ boolean(nodata) }}, {{ local_data_ttl(ttl)}}, {{ policy_get_tagset(tags) }}, ++ C.KR_RULE_OPTS_DEFAULT) == 0) + {%- endmacro -%} + + +@@ -44,7 +44,7 @@ assert(C.kr_rule_local_address('{{ name }}', '{{ address }}', + + {% macro kr_rule_local_hosts(file, nodata, ttl, tags=none) -%} + assert(C.kr_rule_local_hosts('{{ file }}', {{ boolean(nodata) }}, +- {{ local_data_ttl(ttl)}}, {{ policy_get_tagset(tags) }}) == 0, C.KR_RULE_OPTS_DEFAULT) ++ {{ local_data_ttl(ttl)}}, {{ policy_get_tagset(tags) }}, C.KR_RULE_OPTS_DEFAULT) == 0) + {%- endmacro %} + + +@@ -92,8 +92,8 @@ assert(C.kr_rule_zonefile({{ id }})==0) + + {% macro kr_rule_local_subtree(name, type, ttl, tags=none) -%} + assert(C.kr_rule_local_subtree(todname('{{ name }}'), +- C.KR_RULE_SUB_{{ type.upper() }}, {{ local_data_ttl(ttl) }}, {{ policy_get_tagset(tags) }}) == 0, +- C.KR_RULE_OPTS_DEFAULT) ++ C.KR_RULE_SUB_{{ type.upper() }}, {{ local_data_ttl(ttl) }}, {{ policy_get_tagset(tags) }}, ++ C.KR_RULE_OPTS_DEFAULT) == 0) + {%- endmacro %} + + +-- +GitLab + diff --git a/net-dns/knot-resolver/knot-resolver-6.0.13.ebuild b/net-dns/knot-resolver/knot-resolver-6.0.13.ebuild new file mode 100644 index 000000000000..7762c00dda49 --- /dev/null +++ b/net-dns/knot-resolver/knot-resolver-6.0.13.ebuild @@ -0,0 +1,184 @@ +# Copyright 2024-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +LUA_COMPAT=( luajit ) +DISTUTILS_EXT=1 +DISTUTILS_OPTIONAL=1 +DISTUTILS_SINGLE_IMPL=1 +DISTUTILS_USE_PEP517=poetry +PYTHON_COMPAT=( python3_{11..13} ) + +inherit distutils-r1 lua-single meson optfeature tmpfiles verify-sig + +DESCRIPTION="A scaleable caching DNS resolver" +HOMEPAGE="https://www.knot-resolver.cz https://gitlab.nic.cz/knot/knot-resolver" +SRC_URI=" + https://knot-resolver.nic.cz/release/${P}.tar.xz + verify-sig? ( https://knot-resolver.nic.cz/release/${P}.tar.xz.asc ) +" + +LICENSE="Apache-2.0 BSD CC0-1.0 GPL-3+ LGPL-2.1+ MIT" +SLOT="0" +KEYWORDS="~amd64 ~arm64" + +IUSE="caps dnstap jemalloc +manager nghttp2 selinux systemd test xdp" +RESTRICT="!test? ( test )" +REQUIRED_USE=" + ${LUA_REQUIRED_USE} + manager? ( ${PYTHON_REQUIRED_USE} ) +" + +RDEPEND=" + ${LUA_DEPS} + acct-group/knot-resolver + acct-user/knot-resolver + dev-db/lmdb:= + dev-libs/libuv:= + >=net-dns/knot-3.3:=[xdp?] + net-libs/gnutls:= + caps? ( sys-libs/libcap-ng ) + dnstap? ( + dev-libs/fstrm + dev-libs/protobuf-c:= + ) + jemalloc? ( dev-libs/jemalloc:= ) + manager? ( + ${PYTHON_DEPS} + $(python_gen_cond_dep ' + app-admin/supervisor[${PYTHON_USEDEP}] + dev-python/aiohttp[${PYTHON_USEDEP}] + dev-python/jinja2[${PYTHON_USEDEP}] + dev-python/pyyaml[${PYTHON_USEDEP}] + dev-python/typing-extensions[${PYTHON_USEDEP}] + ') + ) + nghttp2? ( net-libs/nghttp2:= ) + selinux? ( sec-policy/selinux-knot ) + systemd? ( sys-apps/systemd:= ) +" +DEPEND=" + ${RDEPEND} + test? ( + dev-util/cmocka + manager? ( + $(python_gen_cond_dep ' + dev-python/pyparsing[${PYTHON_USEDEP}] + dev-python/pytest-asyncio[${PYTHON_USEDEP}] + ') + ) + ) +" +BDEPEND=" + virtual/pkgconfig + manager? ( + ${DISTUTILS_DEPS} + ${PYTHON_DEPS} + ) + verify-sig? ( >=sec-keys/openpgp-keys-knot-resolver-20240304 ) +" + +VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/${PN}.gpg + +PATCHES=( + "${FILESDIR}"/${PN}-5.5.3-docdir.patch + "${FILESDIR}"/${PN}-5.5.3-nghttp-openssl.patch + "${FILESDIR}"/${PN}-6.0.9-libsystemd.patch + "${FILESDIR}"/${PN}-6.0.9-config-example.patch + "${FILESDIR}"/${PN}-6.0.12-pytest_tomllib.patch + # Regression fix merged, to be removed with release 6.0.14 + "${FILESDIR}"/${PN}-6.0.13-fix_template_regress.patch +) + +pkg_setup() { + lua-single_pkg_setup + use manager && python-single-r1_pkg_setup +} + +src_prepare() { + default + use manager && distutils-r1_src_prepare +} + +src_configure() { + local emesonargs=( + --localstatedir "${EPREFIX}"/var # double lib + # https://bugs.gentoo.org/870019 + -Dauto_features=disabled + # post-install tests + -Dconfig_tests=disabled + -Ddoc=disabled + -Ddocdir="${EPREFIX}"/usr/share/doc/${PF} + -Dinstall_kresd_conf=enabled + -Dopenssl=disabled + -Dmalloc=$(usex jemalloc jemalloc disabled) + -Dsystemd_files=enabled + $(meson_feature caps capng) + $(meson_feature dnstap) + $(meson_feature nghttp2) + $(meson_feature systemd) + $(meson_feature systemd systemd_legacy_units) + $(meson_feature test unit_tests) + ) + meson_src_configure +} + +src_compile() { + meson_src_compile + use manager && distutils-r1_src_compile +} + +src_test() { + meson_src_test + use manager && distutils-r1_src_test +} + +python_test() { + epytest tests/manager +} + +src_install() { + meson_src_install + if use manager; then + distutils-r1_src_install + newinitd "${FILESDIR}"/knot-resolver.initd knot-resolver + newconfd "${FILESDIR}"/knot-resolver.confd knot-resolver + else + rm "${ED}"/usr/lib/systemd/system/knot-resolver.service || die + fi + fowners -R ${PN}: /etc/${PN} + newinitd "${FILESDIR}"/kresd.initd-r2 kresd + newconfd "${FILESDIR}"/kresd.confd-r1 kresd + newinitd "${FILESDIR}"/kres-cache-gc.initd kres-cache-gc +} + +pkg_postinst() { + tmpfiles_process knot-resolver.conf + if use manager; then + elog "You choose the new way, called the manager, to start Knot Resolver:" + use systemd && elog " systemctl start knot-resolver.service" + use !systemd && elog " /etc/init.d/knot-resolver start" + elog "Configuration file: /etc/knot-resolver/config.yaml" + elog "" + elog "The older way, without the manager, is still available:" + else + elog "You choose the older way, without the manager, to start Knot Resolver:" + fi + use systemd && elog " systemctl start [email protected]" + use !systemd && elog " /etc/init.d/kresd start" + elog "Configuration file: /etc/knot-resolver/kresd.conf" + elog "Optional garbage collector: /etc/init.d/kres-cache-gc" + elog "" + use !manager && elog "The new way is available with the useflag manager." + elog "" + + optfeature_header "This package is recommended with Knot Resolver:" + optfeature "asynchronous execution, especially with policy module" dev-lua/cqueues + elog "" + optfeature_header "Other packages may also be useful:" + use manager && optfeature "Prometheus metrics (need manager)" dev-python/prometheus-client + use manager && optfeature "auto-reload TLS certificate files and RPZ files (need manager)" dev-python/watchdog + optfeature "legacy doh and webmgmt (metrics, tracking)" dev-lua/lua-http + optfeature "server map with geoIP database (webmgmt)" dev-lua/lua-mmdb +}
