summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'net-analyzer/icinga')
-rw-r--r--net-analyzer/icinga/Manifest7
-rw-r--r--net-analyzer/icinga/files/icinga-apache.conf15
-rw-r--r--net-analyzer/icinga/files/icinga-conf.d10
-rw-r--r--net-analyzer/icinga/files/icinga-init.d57
-rw-r--r--net-analyzer/icinga/files/icinga-lighty.conf24
-rw-r--r--net-analyzer/icinga/icinga-9999.ebuild221
-rw-r--r--net-analyzer/icinga/metadata.xml25
7 files changed, 359 insertions, 0 deletions
diff --git a/net-analyzer/icinga/Manifest b/net-analyzer/icinga/Manifest
new file mode 100644
index 0000000..6985de0
--- /dev/null
+++ b/net-analyzer/icinga/Manifest
@@ -0,0 +1,7 @@
+AUX icinga-apache.conf 377 RMD160 bd009d51035802deb5efd3aaf0b726ca7ef34e2e SHA1 7ba572b8ed52695a8278cc5d57df3fd8cf59dca8 SHA256 e2a17742d8a74f31fd038cbf33533ccdeaed8604cfa026d0fdbb24d3a46e30f9
+AUX icinga-conf.d 409 RMD160 02133c6fc46e24cf99f517b15879ba0a002e36cf SHA1 91b5b200be4c6d6f8d6691e002c5456845f1cc52 SHA256 98485e5a3ec4e32ec800aee6fe695c4740287791e59d7b7426bb2378b21e8d46
+AUX icinga-init.d 1441 RMD160 7b2d9b472dde57c51e1e88c5b23078b3eb4bf05d SHA1 31583c8028c67fbd6e9a345bbc9977ab80b19508 SHA256 914c1c94f54913e7ebf26e64e82ef243a6b1669a2e475e50183b7b7425f41a64
+AUX icinga-lighty.conf 482 RMD160 8e95335db2126f3d95492e32b83eb275e9c30066 SHA1 c0eb082d8c3030059e0d63527ee1c8a3df535478 SHA256 18f865b1fe89c92594165bd065739c94c8c4738647f5d32d7baceb894d7f6b38
+EBUILD icinga-9999.ebuild 6453 RMD160 ddfdf7369845ff4a60b2458450b12879ec2e560a SHA1 1a71c634eca6f522b26f244fa987ac4202133097 SHA256 ad827aa352a08523c85ef232f9cf20501dbf8842debda5da23aa035a9f44e2b4
+MISC ChangeLog 206 RMD160 5e11cde7c9fb10d5ca15e0f8ba484eea47d9442b SHA1 e3c2bf5261a2aed9d2db9fbae95f981d865d18a4 SHA256 adde32eafe6d0078843cc6a7557f8c3c0c464f20f18d653ed2ddaeb536e91302
+MISC metadata.xml 1161 RMD160 2ef9d1f3a92dd1dd797faa20cdd8deddbe51d797 SHA1 202be33a6c045e373c628486567bc9c6190f51b1 SHA256 3e5c79c8abc997c8ab30566b516d5abcc428143cbd02c6b1714a2e987acf6a66
diff --git a/net-analyzer/icinga/files/icinga-apache.conf b/net-analyzer/icinga/files/icinga-apache.conf
new file mode 100644
index 0000000..e1a0199
--- /dev/null
+++ b/net-analyzer/icinga/files/icinga-apache.conf
@@ -0,0 +1,15 @@
+<IfDefine ICINGA>
+ ScriptAlias /icinga/cgi-bin/ /usr/lib/icinga/cgi-bin/
+ <Directory "/usr/lib/icinga/cgi-bin/">
+ AllowOverride AuthConfig
+ Options ExecCGI
+ Order allow,deny
+ Allow from all
+ </Directory>
+ Alias /icinga /usr/share/icinga/htdocs
+ <Directory "/usr/share/icinga/htdocs">
+ AllowOverride AuthConfig
+ Order allow,deny
+ Allow from all
+ </Directory>
+</IfDefine>
diff --git a/net-analyzer/icinga/files/icinga-conf.d b/net-analyzer/icinga/files/icinga-conf.d
new file mode 100644
index 0000000..84642cd
--- /dev/null
+++ b/net-analyzer/icinga/files/icinga-conf.d
@@ -0,0 +1,10 @@
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-analyzer/icinga-core/files/conf.d,v 1.1 2004/08/20 13:38:13 eldad Exp $
+
+# Distributed monitoring users will want to configure here the ip/hostname of the central server.
+# It will be used by submit_check_result_via_nsca.
+NAGIOS_NSCA_HOST="localhost"
+
+
+
diff --git a/net-analyzer/icinga/files/icinga-init.d b/net-analyzer/icinga/files/icinga-init.d
new file mode 100644
index 0000000..627cc50
--- /dev/null
+++ b/net-analyzer/icinga/files/icinga-init.d
@@ -0,0 +1,57 @@
+#!/sbin/runscript
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-analyzer/icinga-core/files/icinga3,v 1.1 2008/04/27 18:41:25 dertobi123 Exp $
+
+opts="${opts} reload checkconfig"
+
+depend() {
+ need net
+ use dns logger firewall
+ after mysql postgresql
+}
+
+reload()
+{
+ checkconfig || return 1
+ ebegin "Reloading configuration"
+ killall -HUP icinga &>/dev/null
+ eend $?
+}
+
+checkconfig() {
+ # Silent Check
+ /usr/sbin/icinga -v /etc/icinga/icinga.cfg &>/dev/null && return 0
+
+ # Now we know there's problem - run again and display errors
+ /usr/sbin/icinga -v /etc/icinga/icinga.cfg
+ eend $? "Configuration Error. Please fix your configfile"
+}
+
+start() {
+ checkconfig || return 1
+ ebegin "Starting icinga"
+ touch /var/icinga/icinga.log /var/icinga/status.sav
+ chown icinga:icinga /var/icinga/icinga.log /var/icinga/status.sav
+ rm -f /var/icinga/rw/icinga.cmd
+ start-stop-daemon --quiet --start --startas /usr/sbin/icinga \
+ -e HOME="/var/icinga/home" --pidfile /var/icinga/icinga.lock \
+ -- -d /etc/icinga/icinga.cfg
+ eend $?
+}
+
+stop() {
+ ebegin "Stopping icinga"
+ start-stop-daemon --quiet --stop --pidfile /var/icinga/icinga.lock
+ rm -f /var/icinga/status.log /var/icinga/icinga.tmp /var/icinga/icinga.lock /var/icinga/rw/icinga.cmd
+ eend $?
+}
+
+svc_restart() {
+ checkconfig || return 1
+ ebegin "Restarting icinga"
+ svc_stop
+ svc_start
+ eend $?
+}
+
diff --git a/net-analyzer/icinga/files/icinga-lighty.conf b/net-analyzer/icinga/files/icinga-lighty.conf
new file mode 100644
index 0000000..227189d
--- /dev/null
+++ b/net-analyzer/icinga/files/icinga-lighty.conf
@@ -0,0 +1,24 @@
+server.modules += ("mod_cgi")
+server.modules += ("mod_auth")
+server.modules += ("mod_alias")
+
+auth.require += ( "/icinga" =>
+ (
+ "method" => "digest",
+ "realm" => "icinga",
+ "require" => "valid-user"
+ )
+)
+
+$HTTP["url"] =~ "^/icinga/cgi-bin/" {
+ dir-listing.activate = "disable"
+ cgi.assign = (
+ ".pl" => "/usr/bin/perl",
+ ".cgi" => ""
+ )
+}
+
+alias.url += (
+ "/icinga/cgi-bin" => "/usr/lib/icinga/cgi-bin",
+ "/icinga" => "/usr/share/icinga/htdocs"
+)
diff --git a/net-analyzer/icinga/icinga-9999.ebuild b/net-analyzer/icinga/icinga-9999.ebuild
new file mode 100644
index 0000000..84915d2
--- /dev/null
+++ b/net-analyzer/icinga/icinga-9999.ebuild
@@ -0,0 +1,221 @@
+# Copyright 1999-2009 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-analyzer/icinga-core/icinga-core-3.1.0.ebuild,v 1.3 2009/02/24 17:07:42 dertobi123 Exp $
+
+EAPI="2"
+
+inherit eutils depend.apache toolchain-funcs git
+
+
+EGIT_REPO_URI="git://git.icinga.org/icinga-core.git"
+SRC_URI=""
+DESCRIPTION="Icinga - Check daemon, CGIs, docs, IDOutils"
+HOMEPAGE="http://www.icinga.org/"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="amd64 x86"
+IUSE="+apache2 debug +idoutils lighttpd perl +web +vim-syntax plugins"
+DEPEND="virtual/mailx
+ web? (
+ >=media-libs/gd-1.8.3-r5[jpeg,png]
+ lighttpd? ( www-servers/lighttpd dev-lang/php[cgi] )
+ apache2? ( || ( dev-lang/php[apache2] dev-lang/php[cgi] ) )
+ )
+ perl? ( >=dev-lang/perl-5.6.1-r7 )
+ idoutils? ( dev-db/libdbi-drivers[mysql] )
+ !net-analyzer/nagios-core"
+RDEPEND="${DEPEND}
+ vim-syntax? ( app-vim/nagios-syntax )
+ plugins? ( net-analyzer/nagios-plugins )"
+
+want_apache2
+
+pkg_setup() {
+ enewgroup icinga
+ enewuser icinga -1 /bin/bash /var/spool/icinga icinga
+}
+
+src_prepare() {
+ local strip="$(echo '$(MAKE) strip-post-install')"
+ sed -i -e "s:${strip}::" {cgi,base}/Makefile.in || die "sed failed in Makefile.in"
+}
+
+src_configure() {
+ local myconf
+
+ if use perl ; then
+ myconf="${myconf} --enable-embedded-perl --with-perlcache"
+ fi
+
+ myconf="${myconf} --disable-statuswrl $(use_enable idoutils)"
+
+ if use debug; then
+ myconf="${myconf} --enable-DEBUG0"
+ myconf="${myconf} --enable-DEBUG1"
+ myconf="${myconf} --enable-DEBUG2"
+ myconf="${myconf} --enable-DEBUG3"
+ myconf="${myconf} --enable-DEBUG4"
+ myconf="${myconf} --enable-DEBUG5"
+ fi
+
+ if use !apache2 && use !lighttpd ; then
+ myconf="${myconf} --with-command-group=icinga"
+ else
+ if use apache2 ; then
+ myconf="${myconf} --with-command-group=apache"
+ myconf="${myconf} --with-httpd-conf=/etc/apache2/conf.d"
+ elif use lighttpd ; then
+ myconf="${myconf} --with-command-group=lighttpd"
+ fi
+ fi
+
+ econf ${myconf} \
+ --prefix=/usr \
+ --bindir=/usr/sbin \
+ --sbindir=/usr/$(get_libdir)/icinga/cgi-bin \
+ --datarootdir=/usr/share/icinga/htdocs \
+ --localstatedir=/var/icinga \
+ --sysconfdir=/etc/icinga \
+ --libexecdir=/usr/$(get_libdir)/icinga/plugins \
+ || die "./configure failed"
+}
+
+src_compile() {
+ emake CC=$(tc-getCC) icinga || die "make failed"
+
+ if use web ; then
+ # Only compile the CGI's if "web" useflag is set.
+ emake CC=$(tc-getCC) DESTDIR="${D}" cgis || die
+ fi
+
+ if use idoutils ; then
+ # Only compile IDOUtils if "idoutils" useflag is set.
+ cd module/idoutils && emake CC=$(tc-getCC) DESTDIR="${D}" || die
+ fi
+}
+
+src_install() {
+ dodoc Changelog INSTALLING LEGAL README UPGRADING
+
+ if ! use web ; then
+ sed -i -e 's/cd $(SRC_CGI) && $(MAKE) $@/# line removed due missing web use flag/' \
+ -e 's/cd $(SRC_HTM) && $(MAKE) $@/# line removed due missing web use flag/' \
+ Makefile
+ fi
+
+ sed -i -e 's/^contactgroups$//g' Makefile
+
+ emake DESTDIR="${D}" install
+ emake DESTDIR="${D}" install-config
+ emake DESTDIR="${D}" install-commandmode
+
+ if use idoutils ; then
+ emake DESTDIR="${D}" install-idoutils
+ fi
+
+ newinitd "${FILESDIR}"/icinga-init.d icinga
+ newconfd "${FILESDIR}"/icinga-conf.d icinga
+
+ # Apache Module
+ if use web ; then
+ if use apache2 ; then
+ insinto "${APACHE_MODULES_CONFDIR}"
+ newins "${FILESDIR}"/icinga-apache.conf 99_icinga.conf
+ elif use lighttpd ; then
+ insinto /etc/lighttpd
+ newins "${FILESDIR}"/icinga-lighty.conf lighttpd_icinga.conf
+ else
+ ewarn "${CATEGORY}/${PF} only supports Apache-2.x or Lighttpd webserver"
+ ewarn "out-of-the-box. Since you are not using one of them, you"
+ ewarn "have to configure your webserver accordingly yourself."
+ fi
+
+ fi
+
+ for dir in etc/icinga var/icinga ; do
+ chown -R icinga:icinga "${D}/${dir}" || die "Failed chown of ${D}/${dir}"
+ done
+
+ chown -R root:root "${D}"/usr/$(get_libdir)/icinga
+ find "${D}"/usr/$(get_libdir)/icinga -type d -print0 | xargs -0 chmod 755
+ find "${D}"/usr/$(get_libdir)/icinga/cgi-bin -type f -print0 | xargs -0 chmod 755
+
+ keepdir /etc/icinga
+ keepdir /var/icinga
+ keepdir /var/icinga/archives
+ keepdir /var/icinga/rw
+ keepdir /var/icinga/spool/checkresults
+
+ if use !apache2 && use !lighttpd; then
+ chown -R icinga:icinga "${D}"/var/icinga/rw || die "Failed chown of ${D}/var/icinga/rw"
+ else
+ if use apache2 ; then
+ chown -R icinga:apache "${D}"/var/icinga/rw || die "Failed chown of ${D}/var/icinga/rw"
+ elif use lighttpd ; then
+ chown -R icinga:lighttpd "${D}"/var/icinga/rw || die "Failed chown of ${D}/var/icinga/rw"
+ fi
+ fi
+
+ chmod ug+s "${D}"/var/icinga/rw || die "Failed Chmod of ${D}/var/icinga/rw"
+ chmod 0750 "${D}"/etc/icinga || die "Failed chmod of ${D}/etc/icinga"
+}
+
+pkg_postinst() {
+ elog "If you want icinga to start at boot time"
+ elog "remember to execute:"
+ elog " rc-update add icinga default"
+ elog
+
+ if use web ; then
+ elog "This does not include cgis that are perl-dependent"
+ elog "Currently traceroute.cgi is perl-dependent"
+ elog "To have ministatus.cgi requires copying of ministatus.c"
+ elog "to cgi directory for compiling."
+
+ elog "Note that the user your webserver is running at needs"
+ elog "read-access to /etc/icinga."
+ elog
+
+ if use apache2 || use lighttpd ; then
+ elog "There are several possible solutions to accomplish this,"
+ elog "choose the one you are most comfortable with:"
+ elog
+ if use apache2 ; then
+ elog " usermod -G icinga apache"
+ elog "or"
+ elog " chown icinga:apache /etc/icinga"
+ elog
+ elog "Also edit /etc/conf.d/apache2 and add \"-D ICINGA\""
+ elif use lighttpd ; then
+ elog " usermod -G icinga lighttpd "
+ elog "or"
+ elog " chown icinga:lighttpd /etc/icinga"
+ fi
+ elog
+ elog "That will make icinga's web front end visable via"
+ elog "http://localhost/icinga/"
+ elog
+ else
+ elog "IMPORTANT: Do not forget to add the user your webserver"
+ elog "is running as to the icinga group!"
+ fi
+
+ else
+ elog "Please note that you have installed Icinga without web interface."
+ elog "Please don't file any bugs about having no web interface when you do this."
+ elog "Thank you!"
+ fi
+
+ elog
+ elog "If your kernel has /proc protection, icinga"
+ elog "will not be happy as it relies on accessing the proc"
+ elog "filesystem. You can fix this by adding icinga into"
+ elog "the group wheel, but this is not recomended."
+ elog
+}
+
+pkg_postinst() {
+ einfo "Fixing permissions"
+ chown icinga:icinga "${ROOT}"var/icinga
+}
diff --git a/net-analyzer/icinga/metadata.xml b/net-analyzer/icinga/metadata.xml
new file mode 100644
index 0000000..d539647
--- /dev/null
+++ b/net-analyzer/icinga/metadata.xml
@@ -0,0 +1,25 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <herd>netmon</herd>
+ <maintainer>
+ <email>dertobi123@gentoo.org</email>
+ <name>Tobias Scherbaum</name>
+ </maintainer>
+ <longdescription>Icinga is a host and service monitor designed to inform you
+ of network problems before your clients, end-users or managers do. It
+ has been designed to run under the Linux operating system, but works
+ fine under most *NIX variants as well. The monitoring daemon runs
+ intermittent checks on hosts and services you specify using external
+ "plugins" which return status information to Icinga. When problems are
+ encountered, the daemon can send notifications out to administrative
+ contacts in a variety of different ways (email, instant message, SMS,
+ etc.). Current status information, historical logs, and reports can all
+ be accessed via a web browser.
+ </longdescription>
+ <use>
+ <flag name='lighttpd'>install <pkg>www-servers/lighttpd</pkg> config</flag>
+ <flag name='web'>enable web interface</flag>
+ <flag name='idoutils'>enable icinga data objects</flag>
+ </use>
+</pkgmetadata>