2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< ? php  
						 
					
						
							
								
									
										
										
										
											2017-12-24 21:56:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/*  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  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 . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ package     LibreNMS 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ subpackage  webui 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ link        http :// librenms . org 
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  @ copyright   2018  LibreNMS 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-24 21:56:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  @ author      LibreNMS  Contributors 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*/  
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-09-11 07:51:35 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								use  LibreNMS\Authentication\LegacyAuth ;  
						 
					
						
							
								
									
										
										
										
											2018-04-07 15:55:28 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$where  =  '1' ;  
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( is_numeric ( $vars [ 'device' ]))  {  
						 
					
						
							
								
									
										
										
										
											2019-01-10 00:52:00 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $where  .=  ' AND E.device_id = ?' ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    $param []  =  ( int ) $vars [ 'device' ]; 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( ! empty ( $vars [ 'eventtype' ]))  {  
						 
					
						
							
								
									
										
										
										
											2015-08-05 20:05:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $where  .=  ' AND `E`.`type` = ?' ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $param []  =  $vars [ 'eventtype' ]; 
							 
						 
					
						
							
								
									
										
										
										
											2015-08-05 20:05:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( $vars [ 'string' ])  {  
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $where  .=  ' AND E.message LIKE ?' ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-03-25 22:50:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $param []  =  '%'  .  $vars [ 'string' ]  .  '%' ; 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-09-11 07:51:35 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( LegacyAuth :: user () -> hasGlobalRead ())  {  
						 
					
						
							
								
									
										
										
										
											2019-01-10 00:52:00 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $sql  =  "  FROM `eventlog` AS E LEFT JOIN `devices` AS `D` ON `E`.`device_id`=`D`.`device_id` WHERE  $where " ; 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-18 20:28:22 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  else  {  
						 
					
						
							
								
									
										
										
										
											2019-01-10 00:52:00 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $sql  =  "  FROM `eventlog` AS E, devices_perms AS P WHERE  $where  AND E.device_id = P.device_id AND P.user_id = ? " ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-09-11 07:51:35 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $param []  =  LegacyAuth :: id (); 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  ( isset ( $searchPhrase )  &&  ! empty ( $searchPhrase ))  {  
						 
					
						
							
								
									
										
										
										
											2018-08-04 22:45:14 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $sql  .=  "  AND (`D`.`hostname` LIKE '% $searchPhrase %' OR `D`.`sysName` LIKE '% $searchPhrase %' OR `E`.`datetime` LIKE '% $searchPhrase %' OR `E`.`message` LIKE '% $searchPhrase %' OR `E`.`type` LIKE '% $searchPhrase %' OR `E`.`username` LIKE '% $searchPhrase %') " ; 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-11-16 21:42:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$count_sql  =  " SELECT COUNT(event_id)  $sql " ;  
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$total  =  dbFetchCell ( $count_sql ,  $param );  
						 
					
						
							
								
									
										
										
										
											2015-04-12 11:47:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( empty ( $total ))  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    $total  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:47:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								if  ( ! isset ( $sort )  ||  empty ( $sort ))  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    $sort  =  'datetime DESC' ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$sql  .=  "  ORDER BY  $sort " ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  ( isset ( $current ))  {  
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $limit_low  =  (( $current  *  $rowCount )  -  ( $rowCount )); 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    $limit_high  =  $rowCount ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  ( $rowCount  !=  - 1 )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    $sql  .=  "  LIMIT  $limit_low , $limit_high " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$sql  =  " SELECT `E`.*,DATE_FORMAT(datetime, ' "  .  $config [ 'dateformat' ][ 'mysql' ][ 'compact' ]  .  " ') as humandate,severity  $sql " ;  
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								foreach  ( dbFetchRows ( $sql ,  $param )  as  $eventlog )  {  
						 
					
						
							
								
									
										
										
										
											2019-01-10 00:52:00 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $dev  =  device_by_id_cache ( $eventlog [ 'device_id' ]); 
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( $eventlog [ 'type' ]  ==  'interface' )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-04-04 08:08:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $this_if  =  cleanPort ( getifbyid ( $eventlog [ 'reference' ])); 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $type  =  '<b>'  .  generate_port_link ( $this_if ,  makeshortif ( strtolower ( $this_if [ 'label' ])))  .  '</b>' ; 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-18 20:28:22 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $type  =  $eventlog [ 'type' ]; 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2017-02-13 00:41:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $severity_colour  =  $eventlog [ 'severity' ]; 
							 
						 
					
						
							
								
									
										
										
										
											2017-03-16 14:20:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-24 21:56:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( $eventlog [ 'username' ]  ==  '' )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $eventlog [ 'username' ]  =  'System' ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-24 21:56:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $response []  =  array ( 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        'datetime'  =>  " <span class='alert-status  "  .  eventlog_severity ( $severity_colour )  .  "  eventlog-status'></span><span style='display:inline;'> "  .  $eventlog [ 'humandate' ]  .  " </span> " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        'hostname'  =>  generate_device_link ( $dev ,  shorthost ( $dev [ 'hostname' ])), 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        'type'  =>  $type , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        'message'  =>  htmlspecialchars ( $eventlog [ 'message' ]), 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        'username'  =>  $eventlog [ 'username' ], 
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ); 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$output  =  array (  
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    'current'  =>  $current , 
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    'rowCount'  =>  $rowCount , 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-09 22:36:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    'rows'  =>  $response , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'total'  =>  $total , 
							 
						 
					
						
							
								
									
										
										
										
											2015-07-13 20:10:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								);  
						 
					
						
							
								
									
										
										
										
											2015-03-27 16:28:09 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								echo  _json_encode ( $output );