From 70e54fcfb70bf712b70c20841d90c17c5d0b8b8f Mon Sep 17 00:00:00 2001 From: Tobias Scherbaum Date: Fri, 15 May 2009 12:10:21 +0000 Subject: Initial import svn path=/; revision=47 --- net-analyzer/icinga/Manifest | 7 + net-analyzer/icinga/files/icinga-apache.conf | 15 ++ net-analyzer/icinga/files/icinga-conf.d | 10 ++ net-analyzer/icinga/files/icinga-init.d | 57 +++++++ net-analyzer/icinga/files/icinga-lighty.conf | 24 +++ net-analyzer/icinga/icinga-9999.ebuild | 221 +++++++++++++++++++++++++++ net-analyzer/icinga/metadata.xml | 25 +++ 7 files changed, 359 insertions(+) create mode 100644 net-analyzer/icinga/Manifest create mode 100644 net-analyzer/icinga/files/icinga-apache.conf create mode 100644 net-analyzer/icinga/files/icinga-conf.d create mode 100644 net-analyzer/icinga/files/icinga-init.d create mode 100644 net-analyzer/icinga/files/icinga-lighty.conf create mode 100644 net-analyzer/icinga/icinga-9999.ebuild create mode 100644 net-analyzer/icinga/metadata.xml 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 @@ + + ScriptAlias /icinga/cgi-bin/ /usr/lib/icinga/cgi-bin/ + + AllowOverride AuthConfig + Options ExecCGI + Order allow,deny + Allow from all + + Alias /icinga /usr/share/icinga/htdocs + + AllowOverride AuthConfig + Order allow,deny + Allow from all + + 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 @@ + + + + netmon + + dertobi123@gentoo.org + Tobias Scherbaum + + 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. + + + install www-servers/lighttpd config + enable web interface + enable icinga data objects + + -- cgit v1.2.3-65-gdbad