2008-07-14 21:54:50 +08:00
< ? php
2020-03-03 00:50:40 +08:00
if ( $_REQUEST [ 'entity' ] == 'navBar' ) {
2020-08-03 02:01:20 +08:00
global $bandwidth_options , $user ;
2020-03-03 00:50:40 +08:00
$data = array ();
if ( ZM_OPT_USE_AUTH && ( ZM_AUTH_RELAY == 'hashed' ) ) {
$auth_hash = generateAuthHash ( ZM_AUTH_HASH_IPS );
if ( isset ( $_REQUEST [ 'auth' ]) and ( $_REQUEST [ 'auth' ] != $auth_hash ) ) {
$data [ 'auth' ] = $auth_hash ;
}
2018-02-14 23:44:48 +08:00
}
2020-08-03 02:01:20 +08:00
// Each widget on the navbar has its own function
// Call the functions we want to dynamically update
$data [ 'getBandwidthHTML' ] = getBandwidthHTML ( $bandwidth_options , $user );
$data [ 'getSysLoadHTML' ] = getSysLoadHTML ();
$data [ 'getDbConHTML' ] = getDbConHTML ();
$data [ 'getStorageHTML' ] = getStorageHTML ();
$data [ 'getShmHTML' ] = getShmHTML ();
2018-02-14 23:44:48 +08:00
ajaxResponse ( $data );
return ;
2017-11-30 12:04:38 +08:00
}
2008-07-14 21:54:50 +08:00
$statusData = array (
2019-09-25 22:13:32 +08:00
'system' => array (
'permission' => 'System' ,
'table' => 'Monitors' ,
'limit' => 1 ,
'elements' => array (
'MonitorCount' => array ( 'sql' => 'count(*)' ),
2020-05-08 01:57:37 +08:00
'ActiveMonitorCount' => array ( 'sql' => 'count(if(`Function` != \'None\',1,NULL))' ),
2019-09-25 22:13:32 +08:00
'State' => array ( 'func' => 'daemonCheck()?' . translate ( 'Running' ) . ':' . translate ( 'Stopped' ) ),
'Load' => array ( 'func' => 'getLoad()' ),
'Disk' => array ( 'func' => 'getDiskPercent()' ),
),
),
'monitor' => array (
'permission' => 'Monitors' ,
'table' => 'Monitors' ,
'limit' => 1 ,
'selector' => 'Monitors.Id' ,
'elements' => array (
'Id' => array ( 'sql' => 'Monitors.Id' ),
'Name' => array ( 'sql' => 'Monitors.Name' ),
'Type' => true ,
'Function' => true ,
'Enabled' => true ,
'LinkedMonitors' => true ,
'Triggers' => true ,
'Device' => true ,
'Channel' => true ,
'Format' => true ,
'Host' => true ,
'Port' => true ,
'Path' => true ,
'Width' => array ( 'sql' => 'Monitors.Width' ),
'Height' => array ( 'sql' => 'Monitors.Height' ),
'Palette' => true ,
'Orientation' => true ,
'Brightness' => true ,
'Contrast' => true ,
'Hue' => true ,
'Colour' => true ,
'EventPrefix' => true ,
'LabelFormat' => true ,
'LabelX' => true ,
'LabelY' => true ,
'LabelSize' => true ,
'ImageBufferCount' => true ,
'WarmupCount' => true ,
'PreEventCount' => true ,
'PostEventCount' => true ,
'AlarmFrameCount' => true ,
'SectionLength' => true ,
'FrameSkip' => true ,
'MotionFrameSkip' => true ,
'MaxFPS' => true ,
'AlarmMaxFPS' => true ,
'FPSReportInterval' => true ,
'RefBlendPerc' => true ,
'Controllable' => true ,
'ControlId' => true ,
'ControlDevice' => true ,
'ControlAddress' => true ,
'AutoStopTimeout' => true ,
'TrackMotion' => true ,
'TrackDelay' => true ,
'ReturnLocation' => true ,
'ReturnDelay' => true ,
'DefaultView' => true ,
'DefaultRate' => true ,
'DefaultScale' => true ,
'WebColour' => true ,
'Sequence' => true ,
'MinEventId' => array ( 'sql' => '(SELECT min(Events.Id) FROM Events WHERE Events.MonitorId = Monitors.Id' ),
'MaxEventId' => array ( 'sql' => '(SELECT max(Events.Id) FROM Events WHERE Events.MonitorId = Monitors.Id' ),
'TotalEvents' => array ( 'sql' => '(SELECT count(Events.Id) FROM Events WHERE Events.MonitorId = Monitors.Id' ),
2019-12-07 03:31:06 +08:00
'Status' => ( isset ( $_REQUEST [ 'id' ]) ? array ( 'zmu' => '-m ' . escapeshellarg ( $_REQUEST [ 'id' ][ 0 ]) . ' -s' ) : null ),
'FrameRate' => ( isset ( $_REQUEST [ 'id' ]) ? array ( 'zmu' => '-m ' . escapeshellarg ( $_REQUEST [ 'id' ][ 0 ]) . ' -f' ) : null ),
2019-09-25 22:13:32 +08:00
),
),
'events' => array (
'permission' => 'Events' ,
'table' => 'Events' ,
'selector' => 'Events.MonitorId' ,
'elements' => array (
'Id' => true ,
2020-04-10 23:11:24 +08:00
'MonitorId' => true ,
2019-09-25 22:13:32 +08:00
'Name' => true ,
'Cause' => true ,
'Notes' => true ,
'StartTime' => true ,
2019-09-29 02:14:27 +08:00
'StartTimeShort' => array ( 'sql' => 'date_format( StartTime, \'' . MYSQL_FMT_DATETIME_SHORT . '\' )' ),
2019-09-25 22:13:32 +08:00
'EndTime' => true ,
'Width' => true ,
'Height' => true ,
'Length' => true ,
'Frames' => true ,
'AlarmFrames' => true ,
'TotScore' => true ,
'AvgScore' => true ,
'MaxScore' => true ,
),
),
'event' => array (
'permission' => 'Events' ,
'table' => 'Events' ,
'limit' => 1 ,
'selector' => 'Events.Id' ,
'elements' => array (
'Id' => array ( 'sql' => 'Events.Id' ),
'MonitorId' => true ,
'MonitorName' => array ( 'sql' => '(SELECT Monitors.Name FROM Monitors WHERE Monitors.Id = Events.MonitorId)' ),
'Name' => true ,
'Cause' => true ,
'StartTime' => true ,
2019-09-29 02:14:27 +08:00
'StartTimeShort' => array ( 'sql' => 'date_format( StartTime, \'' . MYSQL_FMT_DATETIME_SHORT . '\' )' ),
2019-09-25 22:13:32 +08:00
'EndTime' => true ,
'Width' => true ,
'Height' => true ,
'Length' => true ,
'Frames' => true ,
'DefaultVideo' => true ,
'AlarmFrames' => true ,
'TotScore' => true ,
'AvgScore' => true ,
'MaxScore' => true ,
'Archived' => true ,
'Videoed' => true ,
'Uploaded' => true ,
'Emailed' => true ,
'Messaged' => true ,
'Executed' => true ,
'Notes' => true ,
'MinFrameId' => array ( 'sql' => '(SELECT min(Frames.FrameId) FROM Frames WHERE EventId=Events.Id)' ),
'MaxFrameId' => array ( 'sql' => '(SELECT max(Frames.FrameId) FROM Frames WHERE Events.Id = Frames.EventId)' ),
'MinFrameDelta' => array ( 'sql' => '(SELECT min(Frames.Delta) FROM Frames WHERE Events.Id = Frames.EventId)' ),
'MaxFrameDelta' => array ( 'sql' => '(SELECT max(Frames.Delta) FROM Frames WHERE Events.Id = Frames.EventId)' ),
),
),
'frames' => array (
'permission' => 'Events' ,
'table' => 'Frames' ,
'selector' => 'EventId' ,
'elements' => array (
'EventId' => true ,
'FrameId' => true ,
'Type' => true ,
'Delta' => true ,
),
),
'frame' => array (
'permission' => 'Events' ,
'table' => 'Frames' ,
'limit' => 1 ,
'selector' => array ( array ( 'table' => 'Events' , 'join' => 'Events.Id = Frames.EventId' , 'selector' => 'Events.Id' ), 'Frames.FrameId' ),
'elements' => array (
//'Id' => array( 'sql' => 'Frames.FrameId' ),
'FrameId' => true ,
'EventId' => true ,
'Type' => true ,
'TimeStamp' => true ,
2019-09-29 02:14:27 +08:00
'TimeStampShort' => array ( 'sql' => 'date_format( StartTime, \'' . MYSQL_FMT_DATETIME_SHORT . '\' )' ),
2019-09-25 22:13:32 +08:00
'Delta' => true ,
'Score' => true ,
//'Image' => array( 'postFunc' => 'getFrameImage' ),
),
),
'frameimage' => array (
'permission' => 'Events' ,
'func' => 'getFrameImage()'
),
'nearframe' => array (
'permission' => 'Events' ,
'func' => 'getNearFrame()'
),
'nearevents' => array (
'permission' => 'Events' ,
'func' => 'getNearEvents()'
)
);
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
function collectData () {
global $statusData ;
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$entitySpec = & $statusData [ strtolower ( validJsStr ( $_REQUEST [ 'entity' ]))];
#print_r( $entitySpec );
2019-09-25 22:13:32 +08:00
if ( ! canView ( $entitySpec [ 'permission' ]) )
2019-05-24 22:00:15 +08:00
ajaxError ( 'Unrecognised action or insufficient permissions' );
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
if ( ! empty ( $entitySpec [ 'func' ]) ) {
2019-09-25 22:13:32 +08:00
$data = eval ( 'return(' . $entitySpec [ 'func' ] . ');' );
2016-06-27 22:26:37 +08:00
} else {
$data = array ();
$postFuncs = array ();
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$fieldSql = array ();
$joinSql = array ();
$groupSql = array ();
2019-12-07 03:31:06 +08:00
$values = array ();
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$elements = & $entitySpec [ 'elements' ];
2020-05-08 01:57:37 +08:00
$lc_elements = array_change_key_case ( $elements );
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$id = false ;
if ( isset ( $_REQUEST [ 'id' ]) )
if ( ! is_array ( $_REQUEST [ 'id' ]) )
$id = array ( validJsStr ( $_REQUEST [ 'id' ]) );
else
2020-05-08 01:57:37 +08:00
$id = array_values ( $_REQUEST [ 'id' ]);
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
if ( ! isset ( $_REQUEST [ 'element' ]) )
2020-05-08 01:57:37 +08:00
$_REQUEST [ 'element' ] = array_keys ( $elements );
2016-06-27 22:26:37 +08:00
else if ( ! is_array ( $_REQUEST [ 'element' ]) )
$_REQUEST [ 'element' ] = array ( validJsStr ( $_REQUEST [ 'element' ]) );
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
if ( isset ( $entitySpec [ 'selector' ]) ) {
if ( ! is_array ( $entitySpec [ 'selector' ]) )
$entitySpec [ 'selector' ] = array ( $entitySpec [ 'selector' ] );
foreach ( $entitySpec [ 'selector' ] as $selector )
if ( is_array ( $selector ) && isset ( $selector [ 'table' ]) && isset ( $selector [ 'join' ]) )
2017-12-07 23:31:25 +08:00
$joinSql [] = 'left join ' . $selector [ 'table' ] . ' on ' . $selector [ 'join' ];
2016-06-27 22:26:37 +08:00
}
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
foreach ( $_REQUEST [ 'element' ] as $element ) {
if ( ! ( $elementData = $lc_elements [ strtolower ( $element )]) )
2020-05-08 01:57:37 +08:00
ajaxError ( 'Bad ' . validJsStr ( $_REQUEST [ 'entity' ]) . ' element ' . $element );
2016-06-27 22:26:37 +08:00
if ( isset ( $elementData [ 'func' ]) )
2020-05-08 01:57:37 +08:00
$data [ $element ] = eval ( 'return( ' . $elementData [ 'func' ] . ' );' );
2016-06-27 22:26:37 +08:00
else if ( isset ( $elementData [ 'postFunc' ]) )
$postFuncs [ $element ] = $elementData [ 'postFunc' ];
else if ( isset ( $elementData [ 'zmu' ]) )
2020-05-08 01:57:37 +08:00
$data [ $element ] = exec ( escapeshellcmd ( getZmuCommand ( ' ' . $elementData [ 'zmu' ])));
2016-06-27 22:26:37 +08:00
else {
if ( isset ( $elementData [ 'sql' ]) )
2017-12-07 23:31:25 +08:00
$fieldSql [] = $elementData [ 'sql' ] . ' as ' . $element ;
2016-06-27 22:26:37 +08:00
else
2020-05-11 21:19:16 +08:00
$fieldSql [] = $element ;
2016-06-27 22:26:37 +08:00
if ( isset ( $elementData [ 'table' ]) && isset ( $elementData [ 'join' ]) ) {
2017-12-07 23:31:25 +08:00
$joinSql [] = 'left join ' . $elementData [ 'table' ] . ' on ' . $elementData [ 'join' ];
2016-06-27 22:26:37 +08:00
}
if ( isset ( $elementData [ 'group' ]) ) {
$groupSql [] = $elementData [ 'group' ];
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
}
2019-09-25 22:13:32 +08:00
} # end foreach element
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
if ( count ( $fieldSql ) ) {
2020-05-12 21:21:05 +08:00
$sql = 'SELECT ' . join ( ', ' , $fieldSql ) . ' FROM ' . $entitySpec [ 'table' ];
#$sql = 'SELECT '.join(', ', array_map($fieldSql, function($f){return '`'.$f.'`';})).' FROM '.$entitySpec['table'];
2016-06-27 22:26:37 +08:00
if ( $joinSql )
2019-09-25 22:13:32 +08:00
$sql .= ' ' . join ( ' ' , array_unique ( $joinSql ));
2016-06-27 22:26:37 +08:00
if ( $id && ! empty ( $entitySpec [ 'selector' ]) ) {
$index = 0 ;
$where = array ();
2020-05-11 21:19:16 +08:00
foreach ( $entitySpec [ 'selector' ] as $selIndex => $selector ) {
2019-01-19 22:46:08 +08:00
$selectorParamName = ':selector' . $selIndex ;
2020-05-11 21:19:16 +08:00
if ( is_array ( $selector ) ) {
2019-01-19 22:46:08 +08:00
$where [] = $selector [ 'selector' ] . ' = ' . $selectorParamName ;
$values [ $selectorParamName ] = validInt ( $id [ $index ]);
2016-06-27 22:26:37 +08:00
} else {
2019-01-19 22:46:08 +08:00
$where [] = $selector . ' = ' . $selectorParamName ;
$values [ $selectorParamName ] = validInt ( $id [ $index ]);
2016-06-27 22:26:37 +08:00
}
$index ++ ;
}
2019-09-25 22:13:32 +08:00
$sql .= ' WHERE ' . join ( ' AND ' , $where );
2016-06-27 22:26:37 +08:00
}
if ( $groupSql )
2019-09-25 22:13:32 +08:00
$sql .= ' GROUP BY ' . join ( ',' , array_unique ( $groupSql ));
2019-01-22 00:20:56 +08:00
if ( ! empty ( $_REQUEST [ 'sort' ]) ) {
2019-01-24 01:22:00 +08:00
$sql .= ' ORDER BY ' ;
2020-05-11 21:19:16 +08:00
$sort_fields = explode ( ',' , $_REQUEST [ 'sort' ]);
2019-01-24 01:22:00 +08:00
foreach ( $sort_fields as $sort_field ) {
2020-05-11 20:34:07 +08:00
preg_match ( '/^`?(\w+)`?\s*(ASC|DESC)?( NULLS FIRST)?$/i' , $sort_field , $matches );
2019-01-24 01:22:00 +08:00
if ( count ( $matches ) ) {
if ( in_array ( $matches [ 1 ], $fieldSql ) ) {
$sql .= $matches [ 1 ];
} else {
2020-05-12 21:16:37 +08:00
ZM\Error ( 'Sort field ' . $matches [ 1 ] . ' from ' . $sort_field . ' not in SQL Fields: ' . join ( ',' , $sort_field ));
2019-01-24 01:22:00 +08:00
}
if ( count ( $matches ) > 2 ) {
$sql .= ' ' . strtoupper ( $matches [ 2 ]);
if ( count ( $matches ) > 3 )
$sql .= ' ' . strtoupper ( $matches [ 3 ]);
}
} else {
2020-05-08 01:57:37 +08:00
ZM\Error ( 'Sort field didn\'t match regexp ' . $sort_field );
2019-01-24 01:22:00 +08:00
}
} # end foreach sort field
} # end if has sort
2016-06-27 22:26:37 +08:00
if ( ! empty ( $entitySpec [ 'limit' ]) )
$limit = $entitySpec [ 'limit' ];
elseif ( ! empty ( $_REQUEST [ 'count' ]) )
$limit = validInt ( $_REQUEST [ 'count' ]);
2017-12-07 23:31:25 +08:00
$limit_offset = '' ;
2016-06-27 22:26:37 +08:00
if ( ! empty ( $_REQUEST [ 'offset' ]) )
2017-12-07 23:31:25 +08:00
$limit_offset = validInt ( $_REQUEST [ 'offset' ]) . ', ' ;
2016-06-27 22:26:37 +08:00
if ( ! empty ( $limit ) )
2017-12-07 23:31:25 +08:00
$sql .= ' limit ' . $limit_offset . $limit ;
2016-06-27 22:26:37 +08:00
if ( isset ( $limit ) && $limit == 1 ) {
2020-05-08 01:57:37 +08:00
if ( $sqlData = dbFetchOne ( $sql , NULL , $values ) ) {
2016-06-27 22:26:37 +08:00
foreach ( $postFuncs as $element => $func )
$sqlData [ $element ] = eval ( 'return( ' . $func . '( $sqlData ) );' );
$data = array_merge ( $data , $sqlData );
}
} else {
$count = 0 ;
foreach ( dbFetchAll ( $sql , NULL , $values ) as $sqlData ) {
foreach ( $postFuncs as $element => $func )
$sqlData [ $element ] = eval ( 'return( ' . $func . '( $sqlData ) );' );
$data [] = $sqlData ;
if ( isset ( $limi ) && ++ $count >= $limit )
break ;
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
}
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
}
2019-02-22 22:19:07 +08:00
#ZM\Logger::Debug(print_r($data, true));
2018-04-21 02:21:41 +08:00
return $data ;
2008-07-14 21:54:50 +08:00
}
$data = collectData ();
2016-06-27 22:26:37 +08:00
if ( ! isset ( $_REQUEST [ 'layout' ]) ) {
2017-11-04 03:09:19 +08:00
$_REQUEST [ 'layout' ] = 'json' ;
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
switch ( $_REQUEST [ 'layout' ] ) {
case 'xml NOT CURRENTLY SUPPORTED' :
2019-09-25 22:13:32 +08:00
header ( 'Content-type: application/xml' );
2019-09-29 02:14:27 +08:00
echo ( ' < ? xml version = " 1.0 " encoding = " iso-8859-1 " ?>
' );
echo '<' . strtolower ( $_REQUEST [ 'entity' ]) . ' >
' ;
2016-06-27 22:26:37 +08:00
foreach ( $data as $key => $value ) {
2019-09-25 22:13:32 +08:00
$key = strtolower ( $key );
2016-06-27 22:26:37 +08:00
echo " < $key > " . htmlentities ( $value ) . " </ $key > \n " ;
}
2017-12-13 04:46:50 +08:00
echo '</' . strtolower ( $_REQUEST [ 'entity' ]) . " > \n " ;
2016-06-27 22:26:37 +08:00
break ;
case 'json' :
2008-07-14 21:54:50 +08:00
{
2016-06-27 22:26:37 +08:00
$response = array ( strtolower ( validJsStr ( $_REQUEST [ 'entity' ])) => $data );
if ( isset ( $_REQUEST [ 'loopback' ]) )
$response [ 'loopback' ] = validJsStr ( $_REQUEST [ 'loopback' ]);
2019-09-25 22:13:32 +08:00
ajaxResponse ( $response );
2016-06-27 22:26:37 +08:00
break ;
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
case 'text' :
2017-12-13 04:46:50 +08:00
header ( 'Content-type: text/plain' );
2017-12-07 23:31:25 +08:00
echo join ( ' ' , array_values ( $data ) );
2016-06-27 22:26:37 +08:00
break ;
2019-09-25 22:13:32 +08:00
default :
ZM\Error ( 'Unsupported layout: ' . $_REQUEST [ 'layout' ]);
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
function getFrameImage () {
$eventId = $_REQUEST [ 'id' ][ 0 ];
$frameId = $_REQUEST [ 'id' ][ 1 ];
2008-07-14 21:54:50 +08:00
2018-04-21 02:21:41 +08:00
$sql = 'SELECT * FROM Frames WHERE EventId = ? AND FrameId = ?' ;
if ( ! ( $frame = dbFetchOne ( $sql , NULL , array ( $eventId , $frameId ) )) ) {
2016-06-27 22:26:37 +08:00
$frame = array ();
$frame [ 'EventId' ] = $eventId ;
$frame [ 'FrameId' ] = $frameId ;
2017-11-04 03:09:19 +08:00
$frame [ 'Type' ] = 'Virtual' ;
2016-06-27 22:26:37 +08:00
}
$event = dbFetchOne ( 'select * from Events where Id = ?' , NULL , array ( $frame [ 'EventId' ] ) );
$frame [ 'Image' ] = getImageSrc ( $event , $frame , SCALE_BASE );
return ( $frame );
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
function getNearFrame () {
$eventId = $_REQUEST [ 'id' ][ 0 ];
$frameId = $_REQUEST [ 'id' ][ 1 ];
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$sql = 'select FrameId from Frames where EventId = ? and FrameId <= ? order by FrameId desc limit 1' ;
if ( ! $nearFrameId = dbFetchOne ( $sql , 'FrameId' , array ( $eventId , $frameId ) ) ) {
$sql = 'select * from Frames where EventId = ? and FrameId > ? order by FrameId asc limit 1' ;
if ( ! $nearFrameId = dbFetchOne ( $sql , 'FrameId' , array ( $eventId , $frameId ) ) ) {
return ( array () );
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
}
2017-11-04 03:09:19 +08:00
$_REQUEST [ 'entity' ] = 'frame' ;
2016-06-27 22:26:37 +08:00
$_REQUEST [ 'id' ][ 1 ] = $nearFrameId ;
return ( collectData () );
2008-07-14 21:54:50 +08:00
}
2016-06-27 22:26:37 +08:00
function getNearEvents () {
global $user , $sortColumn , $sortOrder ;
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$eventId = $_REQUEST [ 'id' ];
2019-05-24 22:00:15 +08:00
$event = dbFetchOne ( 'SELECT * FROM Events WHERE Id=?' , NULL , array ( $eventId ));
2008-07-14 21:54:50 +08:00
2019-05-24 22:00:15 +08:00
parseFilter ( $_REQUEST [ 'filter' ]);
2016-06-27 22:26:37 +08:00
parseSort ();
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
if ( $user [ 'MonitorIds' ] )
2018-09-29 01:24:50 +08:00
$midSql = ' AND MonitorId IN (' . join ( ',' , preg_split ( '/["\'\s]*,["\'\s]*/' , $user [ 'MonitorIds' ] ) ) . ')' ;
2016-06-27 22:26:37 +08:00
else
$midSql = '' ;
2008-07-14 21:54:50 +08:00
2018-01-29 06:30:49 +08:00
# When listing, it may make sense to list them in descending order. But when viewing Prev should timewise earlier and Next should be after.
if ( $sortColumn == 'E.Id' or $sortColumn == 'E.StartTime' ) {
$sortOrder = 'asc' ;
}
2018-09-30 22:15:04 +08:00
$sql = " SELECT E.Id AS Id, E.StartTime AS StartTime FROM Events AS E INNER JOIN Monitors AS M ON E.MonitorId = M.Id WHERE $sortColumn " . ( $sortOrder == 'asc' ? '<=' : '>=' ) . " ' " . $event [ $_REQUEST [ 'sort_field' ]] . " ' " . $_REQUEST [ 'filter' ][ 'sql' ] . $midSql . ' AND E.Id<' . $event [ 'Id' ] . " ORDER BY $sortColumn " . ( $sortOrder == 'asc' ? 'desc' : 'asc' );
2018-09-29 01:24:50 +08:00
if ( $sortColumn != 'E.Id' ) {
# When sorting by starttime, if we have two events with the same starttime (diffreent monitors) then we should sort secondly by Id
$sql .= ', E.Id DESC' ;
2016-06-27 22:26:37 +08:00
}
2018-09-29 01:24:50 +08:00
$sql .= ' LIMIT 1' ;
2019-05-24 22:00:15 +08:00
$result = dbQuery ( $sql );
$prevEvent = dbFetchNext ( $result );
2018-09-29 01:24:50 +08:00
2018-09-30 22:15:04 +08:00
$sql = " SELECT E.Id AS Id, E.StartTime AS StartTime FROM Events AS E INNER JOIN Monitors AS M ON E.MonitorId = M.Id WHERE $sortColumn " . ( $sortOrder == 'asc' ? '>=' : '<=' ) . " ' " . $event [ $_REQUEST [ 'sort_field' ]] . " ' " . $_REQUEST [ 'filter' ][ 'sql' ] . $midSql . ' AND E.Id>' . $event [ 'Id' ] . " ORDER BY $sortColumn $sortOrder " ;
2018-09-29 01:24:50 +08:00
if ( $sortColumn != 'E.Id' ) {
# When sorting by starttime, if we have two events with the same starttime (diffreent monitors) then we should sort secondly by Id
$sql .= ', E.Id ASC' ;
2016-06-27 22:26:37 +08:00
}
2018-09-29 01:24:50 +08:00
$sql .= ' LIMIT 1' ;
$result = dbQuery ( $sql );
$nextEvent = dbFetchNext ( $result );
2008-07-14 21:54:50 +08:00
2016-06-27 22:26:37 +08:00
$result = array ( 'EventId' => $eventId );
2018-09-29 01:24:50 +08:00
if ( $prevEvent ) {
$result [ 'PrevEventId' ] = $prevEvent [ 'Id' ];
$result [ 'PrevEventStartTime' ] = $prevEvent [ 'StartTime' ];
$result [ 'PrevEventDefVideoPath' ] = getEventDefaultVideoPath ( $prevEvent [ 'Id' ]);
} else {
$result [ 'PrevEventId' ] = $result [ 'PrevEventStartTime' ] = $result [ 'PrevEventDefVideoPath' ] = 0 ;
}
if ( $nextEvent ) {
$result [ 'NextEventId' ] = $nextEvent [ 'Id' ];
$result [ 'NextEventStartTime' ] = $nextEvent [ 'StartTime' ];
$result [ 'NextEventDefVideoPath' ] = getEventDefaultVideoPath ( $nextEvent [ 'Id' ]);
} else {
$result [ 'NextEventId' ] = $result [ 'NextEventStartTime' ] = $result [ 'NextEventDefVideoPath' ] = 0 ;
}
return $result ;
2008-07-14 21:54:50 +08:00
}
?>