| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | * LibreNMS | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | * Copyright (c) 2015 Søren Friis Rosiak <sorenrosiak@gmail.com> | 
					
						
							|  |  |  | * 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. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2015-07-23 22:55:37 +01:00
										 |  |  | require_once 'includes/object-cache.inc.php'; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-22 22:04:33 +01:00
										 |  |  | $sql = 'SELECT `D`.`hostname`,`D`.`device_id`,`D`.`status`,`D`.`uptime` FROM `devices` AS `D`'; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-23 17:48:22 +01:00
										 |  |  | if (is_normal_user() === true) { | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  |     $sql.= ' , `devices_perms` AS P WHERE D.`device_id` = P.`device_id` AND P.`user_id` = ? AND'; | 
					
						
							|  |  |  |     $param = array( | 
					
						
							|  |  |  |         $_SESSION['user_id'] | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | } | 
					
						
							|  |  |  | else { | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  |     $sql.= ' WHERE'; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  | $sql.= " `D`.`ignore` = '0' AND `D`.`disabled` = '0' ORDER BY `hostname`"; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | $temp_output = array(); | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  | $c = '0'; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  | foreach(dbFetchRows($sql, $param) as $device) { | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  |     if ($device['status'] == '1') { | 
					
						
							|  |  |  |         $btn_type = 'btn-success'; | 
					
						
							|  |  |  |         if ($device['uptime'] < $config['uptime_warning']) { | 
					
						
							|  |  |  |             $btn_type = 'btn-warning'; | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  |             $c++; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |         $btn_type = 'btn-danger'; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     $temp_output[] = '<a href="' . generate_url(array( | 
					
						
							|  |  |  |         'page' => 'device', | 
					
						
							|  |  |  |         'device' => $device['device_id'] | 
					
						
							|  |  |  |     )) . '" role="button" class="btn ' . $btn_type . ' btn-xs" title="' . $device['hostname'] . '" style="min-height:25px; min-width:25px; border-radius:0px; border:0px; margin:0; padding:0;"></a>'; | 
					
						
							| 
									
										
										
										
											2015-07-21 23:01:57 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $temp_rows = count($temp_output); | 
					
						
							| 
									
										
										
										
											2015-07-22 22:04:33 +01:00
										 |  |  | $temp_output[] = '</div>'; | 
					
						
							| 
									
										
										
										
											2015-07-24 08:55:13 +01:00
										 |  |  | $temp_header = array( | 
					
						
							|  |  |  |     '<div style="margin-left:auto; margin-right:auto;"><center><h5><i class="fa fa-check" style="color:green">' . $devices['up'] . ' </i> <i class="fa fa-exclamation-triangle" style="color:orange"> '. $c .'</i> <i class="fa fa-exclamation-circle" style="color:red"> ' . $devices['down'] . '</i></h5></center><br />' | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | $common_output = array_merge($temp_header, $temp_output); |