commit:     974aa8ef144d931ef1a1743dd05fea79c924ffd4
Author:     Matthew Thode <prometheanfire <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  9 18:30:29 2026 +0000
Commit:     Matthew Thode <prometheanfire <AT> gentoo <DOT> org>
CommitDate: Fri Jan  9 18:31:17 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=974aa8ef

net-analyzer/icinga2: revbump adding support for boost 1.89

closes: https://bugs.gentoo.org/963409
Signed-off-by: Matthew Thode <prometheanfire <AT> gentoo.org>

 .../icinga2/files/icinga2-boost-1.89.patch         |  23 +++
 net-analyzer/icinga2/icinga2-2.15.0-r2.ebuild      | 159 +++++++++++++++++++++
 2 files changed, 182 insertions(+)

diff --git a/net-analyzer/icinga2/files/icinga2-boost-1.89.patch 
b/net-analyzer/icinga2/files/icinga2-boost-1.89.patch
new file mode 100644
index 000000000000..98d51bdf0f22
--- /dev/null
+++ b/net-analyzer/icinga2/files/icinga2-boost-1.89.patch
@@ -0,0 +1,23 @@
+From 76fa0d9e8054f405dc3d1e39a4b48f21e86afdf0 Mon Sep 17 00:00:00 2001
+From: "Alexander A. Klimov" <[email protected]>
+Date: Thu, 14 Aug 2025 11:05:37 +0200
+Subject: [PATCH] Boost: don't require "system" component
+
+It's vanished in v1.89.
+---
+ CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 86abc77d661..1a087b8ed2f 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -172,7 +172,7 @@ else()
+   set(LOGROTATE_CREATE "\n\tcreate 644 ${ICINGA2_USER} ${ICINGA2_GROUP}")
+ endif()
+ 
+-find_package(Boost ${BOOST_MIN_VERSION} COMPONENTS coroutine context 
date_time filesystem iostreams thread system program_options regex REQUIRED)
++find_package(Boost ${BOOST_MIN_VERSION} COMPONENTS coroutine context 
date_time filesystem iostreams thread program_options regex REQUIRED)
+ 
+ # Boost.Coroutine2 (the successor of Boost.Coroutine)
+ # (1) doesn't even exist in old Boost versions and

diff --git a/net-analyzer/icinga2/icinga2-2.15.0-r2.ebuild 
b/net-analyzer/icinga2/icinga2-2.15.0-r2.ebuild
new file mode 100644
index 000000000000..6ae680ff855a
--- /dev/null
+++ b/net-analyzer/icinga2/icinga2-2.15.0-r2.ebuild
@@ -0,0 +1,159 @@
+# Copyright 1999-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit cmake eapi9-ver
+
+# https://bugs.gentoo.org/960527#c9
+CMAKE_QA_COMPAT_SKIP=1
+
+if [[ ${PV} != 9999 ]]; then
+       SRC_URI="https://github.com/Icinga/icinga2/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
+       KEYWORDS="amd64 ~arm64 x86"
+else
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/Icinga/icinga2.git";
+fi
+
+DESCRIPTION="Distributed, general purpose, network monitoring engine"
+HOMEPAGE="https://icinga.com/";
+
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="console jumbo-build mail mariadb minimal +mysql +plugins postgres test 
systemd"
+RESTRICT="!test? ( test )"
+
+# Add accounts to DEPEND because of fowners in src_install
+DEPEND="
+       dev-libs/openssl:=
+       dev-libs/boost:=[context]
+       console? ( dev-libs/libedit )
+       mariadb? ( dev-db/mariadb-connector-c:= )
+       mysql? ( dev-db/mysql-connector-c:= )
+       postgres? ( dev-db/postgresql:= )
+       dev-libs/yajl:=
+       acct-user/icinga
+       acct-group/icinga
+       acct-group/icingacmd
+"
+BDEPEND="
+       app-alternatives/yacc
+       app-alternatives/lex
+"
+RDEPEND="
+       ${DEPEND}
+       acct-group/nagios
+       plugins? ( || (
+               net-analyzer/monitoring-plugins
+               net-analyzer/nagios-plugins
+       ) )
+       mail? ( virtual/mailx )
+"
+
+REQUIRED_USE="!minimal? ( || ( mariadb mysql postgres ) )"
+
+PATCHES=(
+       "${FILESDIR}/icinga2-boost-1.89.patch"
+)
+
+src_configure() {
+       local mycmakeargs=(
+               -DICINGA2_UNITY_BUILD=$(usex jumbo-build)
+               -DCMAKE_INSTALL_SYSCONFDIR=/etc
+               -DCMAKE_INSTALL_LOCALSTATEDIR=/var
+               -DICINGA2_SYSCONFIGFILE=/etc/conf.d/icinga2
+               -DICINGA2_PLUGINDIR="/usr/$(get_libdir)/nagios/plugins"
+               -DICINGA2_USER=icinga
+               -DICINGA2_GROUP=icingacmd
+               -DICINGA2_COMMAND_GROUP=icingacmd
+               -DICINGA2_RUNDIR=/run
+               -DINSTALL_SYSTEMD_SERVICE_AND_INITSCRIPT=ON
+               -DUSE_SYSTEMD=$(usex systemd)
+               -DICINGA2_WITH_TESTS=$(usex test)
+               -DLOGROTATE_HAS_SU=ON
+               # only appends -flto
+               -DICINGA2_LTO_BUILD=OFF
+       )
+
+       # default to off if minimal, allow the flags to be set otherwise
+       if use minimal; then
+               mycmakeargs+=(
+                       -DICINGA2_WITH_MYSQL=OFF
+                       -DICINGA2_WITH_PGSQL=OFF
+               )
+       else
+               mycmakeargs+=(
+                       -DICINGA2_WITH_PGSQL=$(usex postgres)
+                       -DICINGA2_WITH_MYSQL=$(usex mysql yes $(usex mariadb))
+               )
+       fi
+
+       cmake_src_configure
+}
+
+src_install() {
+       cmake_src_install
+
+       newinitd "${FILESDIR}"/icinga2.initd-3 icinga2
+
+       if use mysql || use mariadb; then
+               docinto schema
+               newdoc 
"${WORKDIR}"/icinga2-${PV}/lib/db_ido_mysql/schema/mysql.sql mysql.sql
+               docinto schema/upgrade
+               dodoc 
"${WORKDIR}"/icinga2-${PV}/lib/db_ido_mysql/schema/upgrade/*
+       fi
+       if use postgres; then
+               docinto schema
+               newdoc 
"${WORKDIR}"/icinga2-${PV}/lib/db_ido_pgsql/schema/pgsql.sql pgsql.sql
+               docinto schema/upgrade
+               dodoc 
"${WORKDIR}"/icinga2-${PV}/lib/db_ido_pgsql/schema/upgrade/*
+       fi
+
+       # See messiness in bug #638686
+       keepdir /etc/icinga2
+       keepdir /var/lib/icinga2/api/log
+       keepdir /var/lib/icinga2/api/repository
+       keepdir /var/lib/icinga2/api/zones
+       keepdir /var/lib/icinga2/api/zones-stage
+       keepdir /var/lib/icinga2/certificate-requests
+       keepdir /var/lib/icinga2/certs
+       keepdir /var/log/icinga2
+       keepdir /var/log/icinga2/compat
+       keepdir /var/log/icinga2/compat/archives
+       keepdir /var/log/icinga2/crash
+       keepdir /var/spool/icinga2/perfdata
+       keepdir /var/spool/icinga2/tmp
+
+       rm -r "${D}/run" || die "failed to remove /run"
+       rm -r "${D}/var/cache" || die "failed to remove /var/cache"
+
+       fowners -R icinga:icinga /etc/icinga2
+       fperms 0750 /etc/icinga2
+       fowners icinga:icinga /var/lib/icinga2
+       fowners -R icinga:icingacmd /var/lib/icinga2/api
+       fowners -R icinga:icingacmd /var/lib/icinga2/certificate-requests
+       fowners -R icinga:icingacmd /var/lib/icinga2/certs
+       fowners icinga:icinga /var/spool/icinga2
+       fowners icinga:icinga /var/spool/icinga2/perfdata
+       fowners icinga:icingacmd /var/log/icinga2
+
+       fperms ug+rwX,o-rwx /etc/icinga2
+       fperms ug+rwX,o-rwx /var/lib/icinga2
+       fperms ug+rwX,o-rwx /var/spool/icinga2
+       fperms ug+rwX,o-rwx /var/log/icinga2
+
+       insinto /usr/share/vim/vimfiles
+       doins -r "${WORKDIR}"/${P}/tools/syntax/vim/ftdetect
+       doins -r "${WORKDIR}"/${P}/tools/syntax/vim/syntax
+
+       insinto /usr/share/nano
+       doins "${WORKDIR}"/${P}/tools/syntax/nano/icinga2.nanorc
+}
+
+pkg_postinst() {
+       if [[ "${PV}" != 9999 ]] && ver_replacing -lt "${PV}"; then
+               elog "DB IDO schema upgrade may be required."
+               elog 
"https://www.icinga.com/docs/icinga2/latest/doc/16-upgrading-icinga-2/";
+       fi
+}

Reply via email to