| 
									
										
										
										
											2016-03-22 07:35:39 +10:00
										 |  |  | #!/usr/bin/env php
 | 
					
						
							| 
									
										
										
										
											2016-03-21 16:47:11 +10:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * LibreNMS module to poll Nagios Services | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2016 Aaron Daniels <aaron@daniels.id.au> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify it | 
					
						
							|  |  |  |  * under the terms of the GNU General Public License as published by the | 
					
						
							|  |  |  |  * Free Software Foundation, either version 3 of the License, or (at your | 
					
						
							|  |  |  |  * option) any later version.  Please see LICENSE.txt at the top level of | 
					
						
							|  |  |  |  * the source code distribution for details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-16 09:17:58 -05:00
										 |  |  | use LibreNMS\Data\Store\Datastore; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-21 14:12:59 -06:00
										 |  |  | $init_modules = array(); | 
					
						
							|  |  |  | require __DIR__ . '/includes/init.php'; | 
					
						
							| 
									
										
										
										
											2016-03-21 16:47:11 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-16 09:17:58 -05:00
										 |  |  | $options = getopt('drfpgh:'); | 
					
						
							| 
									
										
										
										
											2018-07-13 17:08:00 -05:00
										 |  |  | if (set_debug(isset($options['d']))) { | 
					
						
							| 
									
										
										
										
											2016-03-21 16:47:11 +10:00
										 |  |  |     echo "DEBUG!\n"; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  | $poller_start = microtime(true); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-16 09:17:58 -05:00
										 |  |  | $datastore = Datastore::init($options); | 
					
						
							| 
									
										
										
										
											2016-03-22 07:35:39 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  | echo "Starting service polling run:\n\n"; | 
					
						
							|  |  |  | $polled_services = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-12 08:29:29 +00:00
										 |  |  | $where = ''; | 
					
						
							|  |  |  | if ($options['h']) { | 
					
						
							|  |  |  |     if (is_numeric($options['h'])) { | 
					
						
							|  |  |  |         $where = "AND `S`.`device_id` = ".$options['h']; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         if (preg_match('/\*/', $options['h'])) { | 
					
						
							|  |  |  |             $where = "AND `hostname` LIKE '".str_replace('*', '%', mres($options['h']))."'"; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $where = "AND `hostname` = '".mres($options['h'])."'"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-04 22:35:23 +02:00
										 |  |  | $sql = 'SELECT D.*,S.*,attrib_value  FROM `devices` AS D' | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |        .' INNER JOIN `services` AS S ON S.device_id = D.device_id AND D.disabled = 0 '.$where | 
					
						
							|  |  |  |        .' LEFT JOIN `devices_attribs` as A ON D.device_id = A.device_id AND A.attrib_type = "override_icmp_disable"' | 
					
						
							|  |  |  |        .' ORDER by D.device_id DESC;'; | 
					
						
							| 
									
										
										
										
											2017-01-12 08:29:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | foreach (dbFetchRows($sql) as $service) { | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  |     // Run the polling function if service is enabled and the associated device is up, "Disable ICMP Test" option is not enabled,
 | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |     // or service hostname/ip is different from associated device
 | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  |     if (!$service['service_disabled'] && ($service['status'] == 1 || ($service['status'] == 0 && $service['status_reason'] === 'snmp') || | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |         $service['attrib_value'] === 'true' || ($service['service_ip'] !== $service['hostname'] && | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  |         $service['service_ip'] !== inet6_ntop($service['ip']) ))) { | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |         poll_service($service); | 
					
						
							|  |  |  |         $polled_services++; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2018-08-06 20:29:06 -05:00
										 |  |  |         if (!$service['service_disabled']) { | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  |             d_echo("\nService check - ".$service['service_id']."\nSkipping service check because device " | 
					
						
							|  |  |  |                 .$service['hostname']." is down due to icmp.\n"); | 
					
						
							|  |  |  |             Log::event( | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |                 "Service check - {$service['service_desc']} ({$service['service_id']}) - 
 | 
					
						
							|  |  |  |                 Skipping service check because device {$service['hostname']} is down due to icmp",
 | 
					
						
							| 
									
										
										
										
											2018-08-04 22:35:23 +02:00
										 |  |  |                 $service['device_id'], | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |                 'service', | 
					
						
							|  |  |  |                 4, | 
					
						
							|  |  |  |                 $service['service_id'] | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             d_echo("\nService check - ".$service['service_id']."\nSkipping service check because device " | 
					
						
							|  |  |  |                 .$service['service_type']." is disabled.\n"); | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-07-06 10:58:06 -05:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | $poller_end  = microtime(true); | 
					
						
							|  |  |  | $poller_run  = ($poller_end - $poller_start); | 
					
						
							|  |  |  | $poller_time = substr($poller_run, 0, 5); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-23 00:29:12 -05:00
										 |  |  | $string = $argv[0] . " " . date(\LibreNMS\Config::get('dateformat.compact')) | 
					
						
							| 
									
										
										
										
											2018-07-25 09:38:52 +02:00
										 |  |  |     ." - $polled_services services polled in $poller_time secs"; | 
					
						
							|  |  |  | d_echo("$string\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-16 09:17:58 -05:00
										 |  |  | Datastore::terminate(); |