342 lines
13 KiB
PHP
342 lines
13 KiB
PHP
<?php
|
|
//
|
|
// ZoneMinder web console file, $Date$, $Revision$
|
|
// Copyright (C) 2001-2008 Philip Coombes
|
|
//
|
|
// 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 2
|
|
// 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, write to the Free Software
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
//
|
|
|
|
$servers = Server::find_all();
|
|
$storage_areas = Storage::find_all();
|
|
$show_storage_areas = count($storage_areas) > 1 and canEdit( 'System' ) ? 1 : 0;
|
|
if ( $running == null )
|
|
$running = daemonCheck();
|
|
|
|
$eventCounts = array(
|
|
array(
|
|
'title' => translate('Events'),
|
|
'filter' => array(
|
|
'Query' => array (
|
|
'terms' => array()
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
array(
|
|
'title' => translate('Hour'),
|
|
'filter' => array(
|
|
'Query' => array(
|
|
'terms' => array(
|
|
array( 'attr' => 'DateTime', 'op' => '>=', 'val' => '-1 hour' ),
|
|
)
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
array(
|
|
'title' => translate('Day'),
|
|
'filter' => array(
|
|
'Query' => array(
|
|
'terms' => array(
|
|
array( 'attr' => 'DateTime', 'op' => '>=', 'val' => '-1 day' ),
|
|
)
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
array(
|
|
'title' => translate('Week'),
|
|
'filter' => array(
|
|
'Query' => array(
|
|
'terms' => array(
|
|
array( 'attr' => 'DateTime', 'op' => '>=', 'val' => '-7 day' ),
|
|
)
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
array(
|
|
'title' => translate('Month'),
|
|
'filter' => array(
|
|
'Query' => array(
|
|
'terms' => array(
|
|
array( 'attr' => 'DateTime', 'op' => '>=', 'val' => '-1 month' ),
|
|
)
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
array(
|
|
'title' => translate('Archived'),
|
|
'filter' => array(
|
|
'Query' => array(
|
|
'terms' => array(
|
|
array( 'attr' => 'Archived', 'op' => '=', 'val' => '1' ),
|
|
)
|
|
)
|
|
),
|
|
'total' => 0,
|
|
),
|
|
);
|
|
|
|
|
|
$navbar = getNavBarHTML();
|
|
|
|
noCacheHeaders();
|
|
|
|
$eventsView = ZM_WEB_EVENTS_VIEW;
|
|
$eventsWindow = 'zm'.ucfirst(ZM_WEB_EVENTS_VIEW);
|
|
$left_columns = 3;
|
|
if ( count($servers) ) $left_columns += 1;
|
|
if ( ZM_WEB_ID_ON_CONSOLE ) $left_columns += 1;
|
|
if ( $show_storage_areas ) $left_columns += 1;
|
|
|
|
xhtmlHeaders( __FILE__, translate('Console') );
|
|
?>
|
|
<body>
|
|
<form name="monitorForm" method="get" action="<?php echo $_SERVER['PHP_SELF'] ?>">
|
|
<input type="hidden" name="view" value="<?php echo $view ?>"/>
|
|
<input type="hidden" name="action" value=""/>
|
|
|
|
<?php echo $navbar ?>
|
|
<div class="controlHeader">
|
|
<span id="groupControl"><label><?php echo translate('Group') ?>:</label>
|
|
<?php
|
|
$group_id = 0;
|
|
if ( isset($_REQUEST['group']) ) {
|
|
$group_id = $_REQUEST['group'];
|
|
} else if ( isset($_COOKIE['zmGroup'] ) ) {
|
|
$group_id = $_COOKIE['zmGroup'];
|
|
}
|
|
$subgroup_id = 0;
|
|
if ( isset($_REQUEST['subgroup']) ) {
|
|
$subgroup_id = $_REQUEST['subgroup'];
|
|
} else if ( isset($_COOKIE['zmSubGroup'] ) ) {
|
|
$subgroup_id = $_COOKIE['zmSubGroup'];
|
|
}
|
|
|
|
$groups = array(0=>'All');
|
|
foreach ( Group::find_all( array('ParentId'=>null) ) as $Group ) {
|
|
$groups[$Group->Id()] = $Group->Name();
|
|
}
|
|
echo htmlSelect( 'group', $groups, $group_id, 'changeGroup(this);' );
|
|
$groups = array(0=>'All');
|
|
if ( $group_id ) {
|
|
foreach ( Group::find_all( array('ParentId'=>$group_id) ) as $Group ) {
|
|
$groups[$Group->Id()] = $Group->Name();
|
|
}
|
|
}
|
|
echo htmlSelect( 'subgroup', $groups, $subgroup_id, 'changeSubGroup(this);' );
|
|
|
|
$group = NULL;
|
|
if ( $group_id ) {
|
|
if ( $group = dbFetchOne( 'SELECT MonitorIds FROM Groups WHERE Id = ?', NULL, array($group_id) ) )
|
|
$groupIds = array_flip(explode( ',', $group['MonitorIds'] ));
|
|
if ( $subgroup_id ) {
|
|
if ( $group = dbFetchOne( 'SELECT MonitorIds FROM Groups WHERE Id = ?', NULL, array($subgroup_id) ) )
|
|
$groupIds = array_merge( $groupIds, array_flip(explode( ',', $group['MonitorIds'] ) ) );
|
|
} else {
|
|
foreach ( dbFetchAll( 'SELECT MonitorIds FROM Groups WHERE ParentId = ?', NULL, array($group_id) ) as $group )
|
|
$groupIds = array_merge( $groupIds, array_flip(explode( ',', $group['MonitorIds'] ) ) );
|
|
}
|
|
}
|
|
|
|
$maxWidth = 0;
|
|
$maxHeight = 0;
|
|
# Used to determine if the Cycle button should be made available
|
|
$monitors = dbFetchAll( 'SELECT * FROM Monitors ORDER BY Sequence ASC' );
|
|
$displayMonitors = array();
|
|
for ( $i = 0; $i < count($monitors); $i++ ) {
|
|
if ( !visibleMonitor( $monitors[$i]['Id'] ) ) {
|
|
continue;
|
|
}
|
|
if ( $group && !empty($groupIds) && !array_key_exists( $monitors[$i]['Id'], $groupIds ) ) {
|
|
continue;
|
|
}
|
|
if ( $monitors[$i]['Function'] != 'None' ) {
|
|
$scaleWidth = reScale( $monitors[$i]['Width'], $monitors[$i]['DefaultScale'], ZM_WEB_DEFAULT_SCALE );
|
|
$scaleHeight = reScale( $monitors[$i]['Height'], $monitors[$i]['DefaultScale'], ZM_WEB_DEFAULT_SCALE );
|
|
if ( $maxWidth < $scaleWidth ) $maxWidth = $scaleWidth;
|
|
if ( $maxHeight < $scaleHeight ) $maxHeight = $scaleHeight;
|
|
}
|
|
$displayMonitors[] = $monitors[$i];
|
|
}
|
|
|
|
$cycleWidth = $maxWidth;
|
|
$cycleHeight = $maxHeight;
|
|
$zoneCount = 0;
|
|
|
|
for( $i = 0; $i < count($displayMonitors); $i += 1 ) {
|
|
$monitor = $displayMonitors[$i];
|
|
$monitor['zmc'] = zmcStatus( $monitor );
|
|
$monitor['zma'] = zmaStatus( $monitor );
|
|
$monitor['ZoneCount'] = dbFetchOne( 'select count(Id) as ZoneCount from Zones where MonitorId = ?', 'ZoneCount', array($monitor['Id']) );
|
|
$counts = array();
|
|
for ( $j = 0; $j < count($eventCounts); $j += 1 ) {
|
|
$filter = addFilterTerm( $eventCounts[$j]['filter'], count($eventCounts[$j]['filter']['Query']['terms']), array( 'cnj' => 'and', 'attr' => 'MonitorId', 'op' => '=', 'val' => $monitor['Id'] ) );
|
|
parseFilter( $filter );
|
|
$counts[] = 'count(if(1'.$filter['sql'].",1,NULL)) as EventCount$j";
|
|
$monitor['eventCounts'][$j]['filter'] = $filter;
|
|
}
|
|
$sql = 'SELECt '.join($counts,', ').' from Events as E where MonitorId = ?';
|
|
$counts = dbFetchOne( $sql, NULL, array($monitor['Id']) );
|
|
if ( $counts )
|
|
$displayMonitors[$i] = $monitor = array_merge( $monitor, $counts );
|
|
for ( $j = 0; $j < count($eventCounts); $j += 1 ) {
|
|
$eventCounts[$j]['total'] += $monitor['EventCount'.$j];
|
|
}
|
|
$zoneCount += $monitor['ZoneCount'];
|
|
}
|
|
?>
|
|
</span>
|
|
</div>
|
|
|
|
<div class="container-fluid">
|
|
<table class="table table-striped table-hover table-condensed" id="consoleTable">
|
|
<thead>
|
|
<tr>
|
|
<?php if ( ZM_WEB_ID_ON_CONSOLE ) { ?>
|
|
<th class="colId"><?php echo translate('Id') ?></th>
|
|
<?php } ?>
|
|
<th class="colName"><?php echo translate('Name') ?></th>
|
|
<th class="colFunction"><?php echo translate('Function') ?></th>
|
|
<?php if ( count($servers) ) { ?>
|
|
<th class="colServer"><?php echo translate('Server') ?></th>
|
|
<?php } ?>
|
|
<th class="colSource"><?php echo translate('Source') ?></th>
|
|
<?php if ( $show_storage_areas ) { ?>
|
|
<th class="colStorage"><?php echo translate('Storage') ?></th>
|
|
<?php } ?>
|
|
<?php for ( $i = 0; $i < count($eventCounts); $i++ ) { ?>
|
|
<th class="colEvents"><?php echo $eventCounts[$i]['title'] ?></th>
|
|
<?php } ?>
|
|
<th class="colZones"><a href="<?php echo $_SERVER['PHP_SELF'] ?>?view=zones_overview"><?php echo translate('Zones') ?></a></th>
|
|
<?php if ( canEdit('Monitors') ) { ?>
|
|
<th class="colMark"><?php echo translate('Mark') ?></th>
|
|
<?php } ?>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="consoleTableBody">
|
|
<?php
|
|
for( $monitor_i = 0; $monitor_i < count($displayMonitors); $monitor_i += 1 ) {
|
|
$monitor = $displayMonitors[$monitor_i];
|
|
?>
|
|
<tr id="<?php echo 'monitor_id-'.$monitor['Id'] ?>" title="<?php echo $monitor['Id'] ?>">
|
|
<?php
|
|
if ( !$monitor['zmc'] ) {
|
|
$dclass = 'errorText';
|
|
} else {
|
|
// https://github.com/ZoneMinder/ZoneMinder/issues/1082
|
|
if ( !$monitor['zma'] && $monitor['Function']!='Monitor' )
|
|
$dclass = 'warnText';
|
|
else
|
|
$dclass = 'infoText';
|
|
}
|
|
if ( $monitor['Function'] == 'None' )
|
|
$fclass = 'errorText';
|
|
//elseif ( $monitor['Function'] == 'Monitor' )
|
|
// $fclass = 'warnText';
|
|
else
|
|
$fclass = 'infoText';
|
|
if ( !$monitor['Enabled'] )
|
|
$fclass .= ' disabledText';
|
|
$scale = max( reScale( SCALE_BASE, $monitor['DefaultScale'], ZM_WEB_DEFAULT_SCALE ), SCALE_BASE );
|
|
?>
|
|
<?php
|
|
if ( ZM_WEB_ID_ON_CONSOLE ) {
|
|
?>
|
|
<td class="colId"><?php echo makePopupLink( '?view=watch&mid='.$monitor['Id'], 'zmWatch'.$monitor['Id'], array( 'watch', reScale( $monitor['Width'], $scale ), reScale( $monitor['Height'], $scale ) ), $monitor['Id'], $running && ($monitor['Function'] != 'None') && canView('Stream') ) ?></td>
|
|
<?php
|
|
}
|
|
?>
|
|
<td class="colName"><?php echo makePopupLink( '?view=watch&mid='.$monitor['Id'], 'zmWatch'.$monitor['Id'], array( 'watch', reScale( $monitor['Width'], $scale ), reScale( $monitor['Height'], $scale ) ), $monitor['Name'], $running && ($monitor['Function'] != 'None') && canView('Stream') ) ?></td>
|
|
<td class="colFunction"><?php echo makePopupLink( '?view=function&mid='.$monitor['Id'], 'zmFunction', 'function', '<span class="'.$fclass.'">'.translate('Fn'.$monitor['Function']).( empty($monitor['Enabled']) ? ', disabled' : '' ) .'</span>', canEdit( 'Monitors' ) ) ?></td>
|
|
<?php
|
|
if ( count($servers) ) { ?>
|
|
<td class="colServer"><?php $Server = new Server( $monitor['ServerId'] ); echo $Server->Name(); ?></td>
|
|
<?php
|
|
}
|
|
$source = '';
|
|
if ( $monitor['Type'] == 'Local' ) {
|
|
$source = $monitor['Device'].' ('.$monitor['Channel'].')';
|
|
} elseif ( $monitor['Type'] == 'Remote' ) {
|
|
$source = preg_replace( '/^.*@/', '', $monitor['Host'] );
|
|
} elseif ( $monitor['Type'] == 'File' || $monitor['Type'] == 'cURL' ) {
|
|
$source = preg_replace( '/^.*\//', '', $monitor['Path'] );
|
|
} elseif ( $monitor['Type'] == 'Ffmpeg' || $monitor['Type'] == 'Libvlc' ) {
|
|
$domain = parse_url( $monitor['Path'], PHP_URL_HOST );
|
|
$source = $domain ? $domain : preg_replace( '/^.*\//', '', $monitor['Path'] );
|
|
}
|
|
if ( $source == '' ) {
|
|
$source = 'Monitor ' . $monitor['Id'];
|
|
}
|
|
echo '<td class="colSource">'. makePopupLink( '?view=monitor&mid='.$monitor['Id'], 'zmMonitor'.$monitor['Id'], 'monitor', '<span class="'.$dclass.'">'.$source.'</span>', canEdit( 'Monitors' ) ).'</td>';
|
|
if ( $show_storage_areas ) {
|
|
?>
|
|
<td class="colStorage"><?php $Storage = new Storage( $monitor['StorageId'] ); echo $Storage->Name(); ?></td>
|
|
<?php
|
|
}
|
|
|
|
for ( $i = 0; $i < count($eventCounts); $i++ ) {
|
|
?>
|
|
<td class="colEvents"><?php echo makePopupLink( '?view='.$eventsView.'&page=1'.$monitor['eventCounts'][$i]['filter']['query'], $eventsWindow, $eventsView, $monitor['EventCount'.$i], canView( 'Events' ) ) ?></td>
|
|
<?php
|
|
}
|
|
?>
|
|
<td class="colZones"><?php echo makePopupLink( '?view=zones&mid='.$monitor['Id'], 'zmZones', array( 'zones', $monitor['Width'], $monitor['Height'] ), $monitor['ZoneCount'], $running && canView( 'Monitors' ) ) ?></td>
|
|
<?php
|
|
if ( canEdit('Monitors') ) {
|
|
?>
|
|
<td class="colMark">
|
|
<input type="checkbox" name="markMids[]" value="<?php echo $monitor['Id'] ?>" onclick="setButtonStates( this )"<?php if ( !canEdit( 'Monitors' ) ) { ?> disabled="disabled"<?php } ?>/>
|
|
<span class="glyphicon glyphicon-sort"></span>
|
|
</td>
|
|
<?php
|
|
}
|
|
?>
|
|
</tr>
|
|
<?php
|
|
} # end for each monitor
|
|
?>
|
|
</tbody>
|
|
<tfoot>
|
|
<tr>
|
|
<td class="colLeftButtons" colspan="<?php echo $left_columns ?>">
|
|
<input type="button" value="<?php echo translate('Refresh') ?>" onclick="location.reload(true);"/>
|
|
<input type="button" name="addBtn" value="<?php echo translate('AddNewMonitor') ?>" onclick="addMonitor( this )"/>
|
|
<!-- <?php echo makePopupButton( '?view=monitor', 'zmMonitor0', 'monitor', translate('AddNewMonitor'), (canEdit( 'Monitors' ) && !$user['MonitorIds']) ) ?> -->
|
|
<?php echo makePopupButton( '?view=filter&filter[terms][0][attr]=DateTime&filter[terms][0][op]=%3c&filter[terms][0][val]=now', 'zmFilter', 'filter', translate('Filters'), canView( 'Events' ) ) ?>
|
|
<input type="button" name="editBtn" value="<?php echo translate('Edit') ?>" onclick="editMonitor( this )" disabled="disabled"/>
|
|
<input type="button" name="deleteBtn" value="<?php echo translate('Delete') ?>" onclick="deleteMonitor( this )" disabled="disabled"/>
|
|
</td>
|
|
<?php
|
|
for ( $i = 0; $i < count($eventCounts); $i++ ) {
|
|
parseFilter( $eventCounts[$i]['filter'] );
|
|
?>
|
|
<td class="colEvents"><?php echo makePopupLink( '?view='.$eventsView.'&page=1'.$eventCounts[$i]['filter']['query'], $eventsWindow, $eventsView, $eventCounts[$i]['total'], canView( 'Events' ) ) ?></td>
|
|
<?php
|
|
}
|
|
?>
|
|
<td class="colZones"><?php echo $zoneCount ?></td>
|
|
<?php if ( canEdit('Monitors') ) { ?>
|
|
<td class="colMark"></td>
|
|
<?php } ?>
|
|
</tr>
|
|
</tfoot>
|
|
</table>
|
|
</div>
|
|
</form>
|
|
<?php xhtmlFooter() ?>
|