summaryrefslogtreecommitdiff
path: root/net-analyzer/pnp4nagios
diff options
context:
space:
mode:
Diffstat (limited to 'net-analyzer/pnp4nagios')
-rw-r--r--net-analyzer/pnp4nagios/Manifest3
-rw-r--r--net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-magic-quotes.patch23
-rw-r--r--net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-sizeof.patch357
-rw-r--r--net-analyzer/pnp4nagios/pnp4nagios-0.6.26-r11.ebuild104
4 files changed, 487 insertions, 0 deletions
diff --git a/net-analyzer/pnp4nagios/Manifest b/net-analyzer/pnp4nagios/Manifest
index 2d3e7c1e57d8..f18071c9482a 100644
--- a/net-analyzer/pnp4nagios/Manifest
+++ b/net-analyzer/pnp4nagios/Manifest
@@ -1,6 +1,9 @@
AUX 98_pnp4nagios-2.4.conf 725 BLAKE2B ca04f13ad57a90d339980566008d7176aed8be5def8ddb1d4e55ed9ef846900f690ca9bcf37893d73c559c8dea625a027966407f9b87c9ea474447dad9d61314 SHA512 9698529decd9587b4c48dfd5a92069645d4a8fb0796f05fea104459bc4a58aab081f10fc110d75e97331ec960e5fef71a85745c3ea58c6b9f6c37bcec4143000
AUX npcd.initd 364 BLAKE2B b985e4951f95807f4d1d887cfe4f65780150ec827cbe6995e24a955290ce040c263c5848773f24c4ab8e05f5d78ab34693a3636bc8837aae8ef718e64f5c4e3c SHA512 efbf969865ce8f61a733ea0f0e3846854231b55d148dbf0121b4cf6022fedd94cb1ea8f717920f38aedddd6a8f33edf473f139599dc01cc2da14eedb80f7f4f2
AUX pnp4nagios-0.6.14-makefile.patch 1057 BLAKE2B 623115771d66839df357cf19ceb0eac9600cac220cb77b77638c76ac1a5a419b7dd83145192779cfeb845a122729728bccd7cc069de1a4da51180aabbff1b91c SHA512 a67e4b66b0f24db25f9b67d982d99a90c20ad229d404537c9963b2e9f1c5df39a46faa34ecdeb1a9e69b46efd96104d97a39a7e326a01d1c2d09dcc149171602
+AUX pnp4nagios-0.6.26-magic-quotes.patch 987 BLAKE2B 02bc9b3f3c8d3289593147530d8f7f41927e301e9af854c0c57840ea769b3db2fef1222ede7c125f22e1d0ea7e1c62e14bedc387b6e9f185d0bafcf6b1f2532b SHA512 80fdb4013740dabfc31cf990f4c1a517c0002b94aec7f48d408230045ca696147763fedb04cff5da4954962305fe026bf4bcbc575f04cb16e7d96f49536b0715
+AUX pnp4nagios-0.6.26-sizeof.patch 15528 BLAKE2B f6db44720ef2a68dc5d617427fd9d0813ce34e5fe922bd25153df482420a5b2d718ccd90a09a6073e803345a48e6545e39430522d45b6fea4f4924617ff4583e SHA512 02e671a31371662a1e0958dd704b7918360d20bd2fc4171d2d8c7d0332bc37356b24929834ae910858072812f7fa6d61ba4097ff1f93848e0d02b55aee515290
DIST pnp4nagios-0.6.26.tar.gz 3039265 BLAKE2B 1adb3c41222e6bc93671af955a1564387d77901ce118f5d309d101d88c691140e0feef1c2594bc5db44706ff01505a4fcf99b79b6a0c5b5cb923838dd00f1ff0 SHA512 caf6dcced74967174d9e6f09dd1a5bee17397c10a68d0f577c37dcc836f928d78c20d75a0189539e9ffa93715ab7b6e732e9f36b9698cf4dd9c09cfb65184427
EBUILD pnp4nagios-0.6.26-r10.ebuild 3074 BLAKE2B 4ba7815161da54bf4e9e66e0509d1c2cd1acc070d2c66ec619a560b13a496c72505a8f28183054c2b3d3efb354c608d866c86cc1ff177c868da18fddca04f912 SHA512 726614c8530d171320acc7909b1b3e735759983ed77e10361b6d9e3c61d8b51744d668110a887c723935e6351497518d4401d73c887d2978bb6e72b71f3cf4b9
+EBUILD pnp4nagios-0.6.26-r11.ebuild 3167 BLAKE2B 81d5d18234042e730d7430d9780a782c85091337d5e4011f04abe9ad4809c56f748bbf9b9453961a18e51c9660055b4c52baf03b9f4cac85b760477816355181 SHA512 935b3a92f92787ba4c74da329bed1fd363d0e5302c1a3796a0a30d8ca14ca5a49431b09812f7eb379d0669d604cca7e1c99cb5f31b95b5b3ede634c1616b035e
MISC metadata.xml 676 BLAKE2B 39cbab00f63f5b7e6cdd10826ef65eeb9ec85616c48c8c94939216e75615c1d0903285be99b53a99aaf0ed56a79845c63f42111b3fde6b1d6b1af9fb736d8596 SHA512 6efd39f07514cbdf85f95fdb0e7bb9f69bf7ba7ab78c1345bdde1eea645cd89415db5044fe2f1b458211c7b002c895e2e9e225c00172be416f1b30f47765f78e
diff --git a/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-magic-quotes.patch b/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-magic-quotes.patch
new file mode 100644
index 000000000000..7f1d8ae0cf51
--- /dev/null
+++ b/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-magic-quotes.patch
@@ -0,0 +1,23 @@
+# https://github.com/lingej/pnp4nagios/commit/08ce9e26171b888c8e3b036b6693fd8f751970a8
+diff --git a/lib/kohana/system/libraries/Input.php b/lib/kohana/system/libraries/Input.php
+index 0e23c80..b0b24f8 100644
+--- a/lib/kohana/system/libraries/Input.php
++++ b/lib/kohana/system/libraries/Input.php
+@@ -54,14 +54,14 @@ public function __construct()
+ if (Input::$instance === NULL)
+ {
+ // magic_quotes_runtime is enabled
+- if (get_magic_quotes_runtime())
++ if (function_exists('get_magic_quotes_runtime'))
+ {
+- set_magic_quotes_runtime(0);
++ ini_set('magic_quotes_runtime', 0);
+ Kohana::log('debug', 'Disable magic_quotes_runtime! It is evil and deprecated: http://php.net/magic_quotes');
+ }
+
+ // magic_quotes_gpc is enabled
+- if (get_magic_quotes_gpc())
++ if (function_exists('get_magic_quotes_gpc'))
+ {
+ $this->magic_quotes_gpc = TRUE;
+ Kohana::log('debug', 'Disable magic_quotes_gpc! It is evil and deprecated: http://php.net/magic_quotes');
diff --git a/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-sizeof.patch b/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-sizeof.patch
new file mode 100644
index 000000000000..360b4be4f76e
--- /dev/null
+++ b/net-analyzer/pnp4nagios/files/pnp4nagios-0.6.26-sizeof.patch
@@ -0,0 +1,357 @@
+# https://github.com/lingej/pnp4nagios/commit/d5e04540d52238dfcb877d7116316ba1be8c1963
+diff --git a/share/pnp/application/controllers/ajax.php b/share/pnp/application/controllers/ajax.php
+index 9e0428d..c5f89e2 100644
+--- a/share/pnp/application/controllers/ajax.php
++++ b/share/pnp/application/controllers/ajax.php
+@@ -59,7 +59,7 @@ public function basket($action=FALSE){
+
+ if($action == "list"){
+ $basket = $this->session->get("basket");
+- if(is_array($basket) && sizeof($basket) > 0){
++ if(is_array($basket) && (!empty($basket))){
+ foreach($basket as $item){
+ printf("<li class=\"ui-state-default %s\" id=\"%s\"><a title=\"%s\" id=\"%s\"><img width=12px height=12px src=\"%smedia/images/remove.png\"></a>%s</li>\n",
+ "basket_action_remove",
+@@ -135,7 +135,7 @@ public function basket($action=FALSE){
+ echo "Action $action not known";
+ }
+ $basket = $this->session->get("basket");
+- if(is_array($basket) && sizeof($basket) == 0){
++ if(is_array($basket) && empty($basket)){
+ echo Kohana::lang('common.basket-empty');
+ }else{
+ echo "<div align=\"center\" class=\"p2\">\n";
+diff --git a/share/pnp/application/controllers/image.php b/share/pnp/application/controllers/image.php
+index b41ca83..869435c 100644
+--- a/share/pnp/application/controllers/image.php
++++ b/share/pnp/application/controllers/image.php
+@@ -47,7 +47,7 @@ public function index()
+ $this->rrdtool->streamImage("ERROR: NOT_AUTHORIZED");
+
+ #print Kohana::debug($this->data->STRUCT);
+- if(sizeof($this->data->STRUCT) > 0){
++ if(!empty($this->data->STRUCT)){
+ $image = $this->rrdtool->doImage($this->data->STRUCT[0]['RRD_CALL']);
+ }else{
+ $image = FALSE;
+diff --git a/share/pnp/application/controllers/page.php b/share/pnp/application/controllers/page.php
+index 7bd877e..fcfffe8 100644
+--- a/share/pnp/application/controllers/page.php
++++ b/share/pnp/application/controllers/page.php
+@@ -58,7 +58,7 @@ public function index(){
+
+ public function basket(){
+ $basket = $this->session->get("basket");
+- if(is_array($basket) && sizeof($basket) > 0){
++ if(is_array($basket) && (!empty($basket))){
+ $this->data->buildBasketStruct($basket,$this->view);
+ $this->template->page->basket_box = $this->add_view('basket_box');
+ $this->template->page->header->title = Kohana::lang('common.page-basket');
+diff --git a/share/pnp/application/controllers/pdf.php b/share/pnp/application/controllers/pdf.php
+index 15f2ab4..d590859 100644
+--- a/share/pnp/application/controllers/pdf.php
++++ b/share/pnp/application/controllers/pdf.php
+@@ -202,7 +202,7 @@ public function basket(){
+ }
+ $this->data->getTimeRange($this->start,$this->end,$this->view);
+ $basket = $this->session->get("basket");
+- if(is_array($basket) && sizeof($basket) > 0){
++ if(is_array($basket) && (!empty($basket))){
+ $this->data->buildBasketStruct($basket,$this->view);
+ }
+ //echo Kohana::debug($this->data->STRUCT);
+diff --git a/share/pnp/application/helpers/rrd.php b/share/pnp/application/helpers/rrd.php
+index 81bb257..ea9f99b 100644
+--- a/share/pnp/application/helpers/rrd.php
++++ b/share/pnp/application/helpers/rrd.php
+@@ -207,7 +207,7 @@ public static function gprint($vname=FALSE, $cf="AVERAGE", $text="%6.2lf %s"){
+ if(is_array($cf)){
+ foreach($cf as $key => $val){
+ $line .= sprintf("GPRINT:%s:%s:",$vname,$val);
+- if($key == sizeof($cf)-1){
++ if($key == count($cf)-1){
+ $line .= '"'.$text.' '.ucfirst(strtolower($val)).'\\l" ';
+ }else{
+ $line .= '"'.$text.' '.ucfirst(strtolower($val)).'" ';
+@@ -234,7 +234,7 @@ public static function gprinta($vname=FALSE, $cf="AVERAGE", $text="%6.2lf %s", $
+ if(is_array($cf)){
+ foreach($cf as $key => $val){
+ $line .= sprintf("GPRINT:%s:%s:",$vname,$val);
+- if(($key == sizeof($cf)-1)and($align != "")){
++ if(($key == count($cf)-1)and($align != "")){
+ $line .= '"'.$text.' '.ucfirst(strtolower($val)).$align.'" ';
+ }else{
+ $line .= '"'.$text.' '.ucfirst(strtolower($val)).'" ';
+diff --git a/share/pnp/application/lib/json.php b/share/pnp/application/lib/json.php
+index 0cddbdd..d0e3171 100644
+--- a/share/pnp/application/lib/json.php
++++ b/share/pnp/application/lib/json.php
+@@ -375,7 +375,7 @@ function encode($var)
+ */
+
+ // treat as a JSON object
+- if (is_array($var) && count($var) && (array_keys($var) !== range(0, sizeof($var) - 1))) {
++ if (is_array($var) && count($var) && (array_keys($var) !== range(0, count($var) - 1))) {
+ $properties = array_map(array($this, 'name_value'),
+ array_keys($var),
+ array_values($var));
+diff --git a/share/pnp/application/models/auth.php b/share/pnp/application/models/auth.php
+index 77f28d2..11d785a 100644
+--- a/share/pnp/application/models/auth.php
++++ b/share/pnp/application/models/auth.php
+@@ -116,11 +116,7 @@ public function is_authorized($host = FALSE, $service = NULL){
+ $result = $this->queryLivestatus($query);
+ }
+
+- if(sizeof($result) > 0){
+- return TRUE;
+- }else{
+- return FALSE;
+- }
++ return (!empty($result));
+ }
+
+
+diff --git a/share/pnp/application/models/config.php b/share/pnp/application/models/config.php
+index 44e3d12..7a6b8e0 100644
+--- a/share/pnp/application/models/config.php
++++ b/share/pnp/application/models/config.php
+@@ -68,7 +68,7 @@ public function read_config(){
+ $views = array();
+ include ($config_file);
+ $array_b = $views;
+- if(sizeof($views) == 0 ){
++ if(empty($views)){
+ $views = $array_a;
+ }
+ }
+diff --git a/share/pnp/application/models/data.php b/share/pnp/application/models/data.php
+index 63b0e24..74e8821 100644
+--- a/share/pnp/application/models/data.php
++++ b/share/pnp/application/models/data.php
+@@ -45,11 +45,11 @@ public function getSpecialTemplates(){
+ }
+ }
+ }
+- if(sizeof($templates) > 0){
++ if(empty($templates)){
++ return FALSE;
++ }else{
+ sort($templates);
+ return $templates;
+- }else{
+- return FALSE;
+ }
+ }
+
+@@ -97,7 +97,9 @@ public function getHosts() {
+ throw new Kohana_User_Exception('Perfdata Dir', "Can not open $path");
+ }
+ }
+- if(sizeof($hosts)>0){
++ if(empty($hosts)){
++ throw new Kohana_Exception('error.perfdata-dir-empty', $conf['rrdbase'] );
++ }else{
+ # Obtain a list of columns
+ foreach ($hosts as $key => $row) {
+ $sort[$key] = $row['sort'];
+@@ -105,8 +107,6 @@ public function getHosts() {
+ # Sort the data with volume descending, edition ascending
+ # Add $data as the last parameter, to sort by the common key
+ array_multisort($sort, SORT_ASC, $hosts);
+- }else{
+- throw new Kohana_Exception('error.perfdata-dir-empty', $conf['rrdbase'] );
+ }
+ return $hosts;
+ }
+@@ -147,7 +147,7 @@ function getRawServices($hostname) {
+ }else{
+ throw new Kohana_Exception('error.perfdata-dir-for-host', $path, $hostname );
+ }
+- if( is_array($services) && sizeof($services) > 0){
++ if( is_array($services) && (!empty($services))){
+ # Obtain a list of columns
+ foreach ($services as $key => $row) {
+ $sort[$key] = $row['name'];
+@@ -205,7 +205,7 @@ function getServices($hostname) {
+ $i++;
+ }
+ #print Kohana::debug($services);
+- if( is_array($services) && sizeof($services) > 0){
++ if( is_array($services) && (!empty($services))){
+ # Obtain a list of columns
+ foreach ($services as $key => $row) {
+ $sort[$key] = $row['sort'];
+@@ -214,7 +214,7 @@ function getServices($hostname) {
+ # Add $data as the last parameter, to sort by the common key
+ array_multisort($sort, SORT_STRING, $services);
+ }
+- if(is_array($host) && sizeof($host) > 0 ){
++ if(is_array($host) && (!empty($host))){
+ array_unshift($services, $host[0]);
+ }
+ return $services;
+@@ -232,7 +232,7 @@ public function getFirstService($hostname) {
+ break;
+ }
+ }
+- if(sizeof($srv) == 0){
++ if(empty($srv)){
+ throw new Kohana_Exception('error.get-first-service', $hostname );
+ }
+ return $srv['name'];
+@@ -250,7 +250,7 @@ public function getFirstHost() {
+ break;
+ }
+ }
+- if(sizeof($host) == 0){
++ if(empty($host)){
+ throw new Kohana_Exception('error.get-first-host');
+ }
+ return $host['name'];
+@@ -693,7 +693,7 @@ public function getTimeRange($start=FALSE ,$end=FALSE ,$view="") {
+ }
+
+ $view=intval( pnp::clean($view) );
+- if($view >= sizeof($this->config->views)){
++ if($view >= count($this->config->views)){
+ $view = 1;
+ }
+
+@@ -735,7 +735,7 @@ public function getTimeRange($start=FALSE ,$end=FALSE ,$view="") {
+ $timerange['f_end'] = date($this->config->conf['date_fmt'],$end);
+ $timerange['cmd'] = " --start $start --end $end ";
+ $timerange['type'] = "views";
+- for ($i = 0; $i < sizeof($this->config->views); $i++) {
++ for ($i = 0; $i < count($this->config->views); $i++) {
+ $timerange[$i]['title'] = $this->config->views[$i]['title'];
+ $timerange[$i]['start'] = $end - $this->config->views[$i]['start'];
+ $timerange[$i]['f_start'] = date($this->config->conf['date_fmt'],$end - $this->config->views[$i]['start']);
+@@ -747,7 +747,7 @@ public function getTimeRange($start=FALSE ,$end=FALSE ,$view="") {
+ }
+
+ public function buildBasketStruct($basket,$view = NULL){
+- if(is_array($basket) && sizeof($basket) > 0){
++ if(is_array($basket) && (!empty($basket))){
+ if($view == ""){
+ $views = array_keys($this->config->views);
+ }else{
+@@ -757,9 +757,9 @@ public function buildBasketStruct($basket,$view = NULL){
+ foreach($basket as $item){
+ # explode host::service::source
+ $slices = explode("::",$item);
+- if(sizeof($slices) == 2)
++ if(count($slices) == 2)
+ $this->buildDataStruct($slices[0], $slices[1], $view);
+- if(sizeof($slices) == 3)
++ if(count($slices) == 3)
+ $this->buildDataStruct($slices[0], $slices[1], $view, $slices[2]);
+ }
+ # break on custom time ranges
+@@ -806,12 +806,12 @@ public function buildPageStruct($page,$view){
+ }
+ }
+ #print Kohana::debug($servicelist);
+- if(sizeof($servicelist) > 0 ){
++ if(empty($servicelist)){
++ $this->ERROR = "ERROR: ". Kohana::lang('error.no-data-for-page', $page.".cfg" );
++ }else{
+ foreach($servicelist as $s){
+ $this->buildDataStruct($s['host'],$s['service'],$view,$s['source']);
+ }
+- }else{
+- $this->ERROR = "ERROR: ". Kohana::lang('error.no-data-for-page', $page.".cfg" );
+ }
+ }
+
+@@ -962,11 +962,11 @@ public function getPages() {
+ die("Cannot open directory: $path");
+ }
+ }
+- if(sizeof($pages)>0){
++ if(empty($pages)){
++ return FALSE;
++ }else{
+
+ natsort($pages);
+- }else{
+- return FALSE;
+ }
+ return $pages;
+ }
+@@ -976,10 +976,10 @@ public function getPages() {
+ */
+ public function getFirstPage(){
+ $pages = $this->getPages();
+- if(sizeof($pages) > 0 ){
+- return urldecode($pages[0]);
+- }else{
++ if(empty($pages)){
+ return FALSE;
++ }else{
++ return urldecode($pages[0]);
+ }
+ }
+
+@@ -1093,7 +1093,7 @@ public function tplGetServices ($hostregex=FALSE, $serviceregex = ''){
+ }
+ }
+
+- if(sizeof($new_hosts) == 0){
++ if(empty($new_hosts)){
+ throw new Kohana_Exception('error.tpl-no-hosts-found', $hostregex);
+ }
+
+@@ -1101,7 +1101,7 @@ public function tplGetServices ($hostregex=FALSE, $serviceregex = ''){
+ $new_services = array();
+ foreach($new_hosts as $host){
+ $services = $this->getRawServices($host);
+- if(sizeof($services) == 0){
++ if(empty($services)){
+ throw new Kohana_Exception('error.tpl-no-services-found', $serviceregex);
+ }
+ foreach($services as $service){
+@@ -1115,7 +1115,7 @@ public function tplGetServices ($hostregex=FALSE, $serviceregex = ''){
+ }
+ }
+
+- if(sizeof($new_services) == 0){
++ if(empty($new_services)){
+ throw new Kohana_Exception('error.tpl-no-services-found', $serviceregex);
+ }
+
+diff --git a/share/pnp/application/views/basket_box.php b/share/pnp/application/views/basket_box.php
+index ea8a72c..2a4e0e6 100644
+--- a/share/pnp/application/views/basket_box.php
++++ b/share/pnp/application/views/basket_box.php
+@@ -6,7 +6,7 @@
+ echo Kohana::lang('common.basket-box-header')."</div>\n";
+ echo "<div class=\"p4 ui-widget-content ui-corner-bottom\">\n";
+ echo "<div id=\"basket_items\">\n";
+-if(is_array($basket) && sizeof($basket) > 0 ){
++if(is_array($basket) && !empty($basket)){
+ foreach($basket as $key=>$item){
+ echo "<li class=\"ui-state-default basket_action_remove\" id=\"".
+ $item."\"><a title=\"".Kohana::lang('common.basket-remove', $item)."\"".
+@@ -16,7 +16,7 @@
+ pnp::shorten($item)."</li>\n";
+ }
+ }
+-if(is_array($basket) && sizeof($basket) > 0 ){
++if(is_array($basket) && !empty($basket)){
+ echo "<div align=\"center\" class=\"p2\">\n";
+ echo "<button id=\"basket-show\">".Kohana::lang('common.basket-show')."</button>\n";
+ echo "<button id=\"basket-clear\">".Kohana::lang('common.basket-clear')."</button>\n";
+diff --git a/share/pnp/templates.dist/pnp-runtime.php b/share/pnp/templates.dist/pnp-runtime.php
+index 21c4ae3..a668fdc 100644
+--- a/share/pnp/templates.dist/pnp-runtime.php
++++ b/share/pnp/templates.dist/pnp-runtime.php
+@@ -34,7 +34,7 @@
+ #
+ $ds_name[2] = "Errors and updates";
+ $def[2] = '';
+-for($i=2; $i <= sizeof($DS); $i++) {
++for($i=2; $i <= count($DS); $i++) {
+ $def[2] .= rrd::def("var$i", $RRDFILE[$i], $DS[$i] , "AVERAGE") ;
+ $def[2] .= rrd::line1("var$i", rrd::color($i), rrd::cut(ucfirst($LABEL[$i]),12) );
+ $def[2] .= rrd::gprint("var$i", array('LAST', 'MAX', 'AVERAGE'), "%4.0lf$UNIT[$i]");
diff --git a/net-analyzer/pnp4nagios/pnp4nagios-0.6.26-r11.ebuild b/net-analyzer/pnp4nagios/pnp4nagios-0.6.26-r11.ebuild
new file mode 100644
index 000000000000..2d9d334da161
--- /dev/null
+++ b/net-analyzer/pnp4nagios/pnp4nagios-0.6.26-r11.ebuild
@@ -0,0 +1,104 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+DESCRIPTION="A performance data analyzer for nagios"
+HOMEPAGE="http://www.pnp4nagios.org/"
+SRC_URI="mirror://sourceforge/${PN}/PNP-0.6/${P}.tar.gz"
+
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="apache2 icinga +nagios"
+KEYWORDS="~amd64 ~ppc ~ppc64 ~sparc ~x86"
+
+REQUIRED_USE="^^ ( icinga nagios )"
+
+# Some things (sync mode, for one) are broken with nagios-4.x, but since
+# nagios-3.x has been end-of-life'd, we don't have much choice here but
+# to accept it.
+DEPEND="
+ dev-lang/php:*[filter,gd,json(+),simplexml,xml,zlib]
+ net-analyzer/rrdtool[graph,perl]
+ icinga? ( net-analyzer/icinga2 )
+ nagios? ( net-analyzer/nagios-core )"
+
+# A list of modules used in our Apache config file.
+APACHE_MODS="apache2_modules_alias," # "Alias" directive
+APACHE_MODS+="apache2_modules_authz_core," # "Require" directive
+APACHE_MODS+="apache2_modules_rewrite" # "RewriteEngine" and friends
+
+RDEPEND="${DEPEND}
+ virtual/perl-Getopt-Long
+ virtual/perl-Time-HiRes
+ media-fonts/dejavu
+ apache2? ( >=www-servers/apache-2.4[${APACHE_MODS}] )"
+
+PATCHES=(
+ "${FILESDIR}/${PN}-0.6.14-makefile.patch"
+ "${FILESDIR}/${PN}-0.6.26-magic-quotes.patch"
+ "${FILESDIR}/${PN}-0.6.26-sizeof.patch"
+)
+
+src_configure() {
+ local user_group=nagios
+ use icinga && user_group=icinga
+
+ econf \
+ --sysconfdir="${EPREFIX}"/etc/pnp \
+ --datarootdir="${EPREFIX}"/usr/share/pnp \
+ --localstatedir="${EPREFIX}"/var/lib/pnp \
+ --with-nagios-user="${user_group}" \
+ --with-nagios-group="${user_group}" \
+ --with-perfdata-logfile="${EPREFIX}"/var/log/pnp/process_perfdata.log
+}
+
+src_compile() {
+ # The default target just shows a help
+ emake all
+}
+
+src_install() {
+ # Don't use INSTALL_OPTS because they set insecure permissions on
+ # all of /etc/pnp (https://github.com/lingej/pnp4nagios/issues/140).
+ emake INSTALL_OPTS="" DESTDIR="${D}" install install-config
+ einstalldocs
+ newinitd "${FILESDIR}"/npcd.initd npcd
+ rm "${ED%/}/usr/share/pnp/install.php" || \
+ die "unable to remove ${ED%/}/usr/share/pnp/install.php"
+
+ # Fix CVE-2012-3457 (Gentoo bug 430358)
+ fperms o-rwx /etc/pnp/process_perfdata.cfg
+
+ if use apache2 ; then
+ insinto /etc/apache2/modules.d
+ newins "${FILESDIR}"/98_pnp4nagios-2.4.conf 98_pnp4nagios.conf
+ fi
+
+ # The nagios or icinga user needs to write performance data to the
+ # perfdata-dir...
+ local user_group=nagios
+ use icinga && user_group=icinga
+ fowners ":${user_group}" /var/lib/pnp/{,perfdata,spool}
+ fperms g+rwx /var/lib/pnp/{,perfdata,spool}
+
+ # and likewise for its logs...
+ dodir /var/log/pnp
+ fowners ":${user_group}" /var/log/pnp
+ fperms g+rwx /var/log/pnp
+
+ # and its statistics. This one is arguably the responsibility of the
+ # build system, since process_perfdata.cfg refers to this location.
+ dodir /var/lib/pnp/stats
+ fowners ":${user_group}" /var/lib/pnp/stats
+ fperms g+rwx /var/lib/pnp/stats
+}
+
+pkg_postinst() {
+ elog "To enable the pnp4nagios web front-end, please visit"
+ elog "${EROOT%/}/etc/conf.d/apache2 and add \"-D PNP -D PHP\""
+ elog "to APACHE2_OPTS. Then pnp4nagios will be available at,"
+ elog
+ elog " http://localhost/pnp4nagios"
+ elog
+}