| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * output.php | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * runs the requested query and outputs as a file or text | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package    LibreNMS | 
					
						
							|  |  |  |  * @link       http://librenms.org | 
					
						
							|  |  |  |  * @copyright  2016 Neil Lathwood | 
					
						
							|  |  |  |  * @author     Neil Lathwood <neil@lathwood.co.uk> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!is_admin()) { | 
					
						
							|  |  |  |     echo("Insufficient Privileges"); | 
					
						
							|  |  |  |     exit(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $hostname = escapeshellcmd($_REQUEST['hostname']); | 
					
						
							|  |  |  | $type = $_REQUEST['type']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | switch ($type) { | 
					
						
							|  |  |  |     case 'alerts': | 
					
						
							|  |  |  |         $filename = "alerts-$hostname.txt"; | 
					
						
							|  |  |  |         $device_id = getidbyname($hostname); | 
					
						
							|  |  |  |         $device = device_by_id_cache($device_id); | 
					
						
							|  |  |  |         $rules = GetRules($device_id); | 
					
						
							|  |  |  |         $output = ''; | 
					
						
							| 
									
										
										
										
											2017-03-08 04:14:51 +00:00
										 |  |  |         $results = array(); | 
					
						
							| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  |         foreach ($rules as $rule) { | 
					
						
							| 
									
										
										
										
											2016-10-15 00:29:55 +01:00
										 |  |  |             if (empty($rule['query'])) { | 
					
						
							|  |  |  |                 $rule['query'] = GenSQL($rule['rule']); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $sql = $rule['query']; | 
					
						
							| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  |             $qry = dbFetchRow($sql, array($device_id)); | 
					
						
							|  |  |  |             if (is_array($qry)) { | 
					
						
							| 
									
										
										
										
											2017-03-08 04:14:51 +00:00
										 |  |  |                 $results[] = $qry; | 
					
						
							| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  |                 $response = 'matches'; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 $response = 'no match'; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $output .= 'Rule name: ' . $rule['name'] . PHP_EOL; | 
					
						
							|  |  |  |             $output .= 'Alert rule: ' . $rule['rule'] . PHP_EOL; | 
					
						
							| 
									
										
										
										
											2016-10-15 00:29:55 +01:00
										 |  |  |             $output .= 'Alert query: ' . $rule['query'] . PHP_EOL; | 
					
						
							| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  |             $output .= 'Rule match: ' . $response . PHP_EOL . PHP_EOL; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-10-14 02:14:02 +01:00
										 |  |  |         if ($config['alert']['transports']['mail'] === true) { | 
					
						
							| 
									
										
										
										
											2017-03-08 04:14:51 +00:00
										 |  |  |             $contacts = GetContacts($results); | 
					
						
							| 
									
										
										
										
											2016-10-14 02:14:02 +01:00
										 |  |  |             if (count($contacts) > 0) { | 
					
						
							| 
									
										
										
										
											2016-11-19 14:02:51 +00:00
										 |  |  |                 $output .= 'Found ' . count($contacts) . ' contacts to send alerts to.' . PHP_EOL; | 
					
						
							| 
									
										
										
										
											2016-10-14 02:14:02 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |             foreach ($contacts as $email => $name) { | 
					
						
							|  |  |  |                 $output .= $name . '<' . $email . '>' . PHP_EOL; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $output .= PHP_EOL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $transports = ''; | 
					
						
							|  |  |  |         $x = 0; | 
					
						
							|  |  |  |         foreach ($config['alert']['transports'] as $name => $v) { | 
					
						
							|  |  |  |             if ($config['alert']['transports'][$name] === true) { | 
					
						
							|  |  |  |                 $transports .= 'Transport: ' . $name . PHP_EOL; | 
					
						
							|  |  |  |                 $x++; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!empty($transports)) { | 
					
						
							|  |  |  |             $output .= 'Found ' . $x . ' transports to send alerts to.' . PHP_EOL; | 
					
						
							|  |  |  |             $output .= $transports; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-09-26 22:27:27 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         echo 'You must specify a valid type'; | 
					
						
							|  |  |  |         exit(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // ---- Output ----
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ($_GET['format'] == 'text') { | 
					
						
							|  |  |  |     header("Content-type: text/plain"); | 
					
						
							|  |  |  |     header('X-Accel-Buffering: no'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     echo $output; | 
					
						
							|  |  |  | } elseif ($_GET['format'] == 'download') { | 
					
						
							|  |  |  |     file_download($filename, $output); | 
					
						
							|  |  |  | } |