zoneminder/web/api/app/Controller/ZonesController.php

141 lines
3.7 KiB
PHP
Raw Normal View History

<?php
App::uses('AppController', 'Controller');
/**
* Zones Controller
*
* @property Zone $Zone
*/
class ZonesController extends AppController {
2018-07-25 04:41:09 +08:00
/**
* Components
*
* @var array
*/
public $components = array('RequestHandler');
public function beforeFilter() {
parent::beforeFilter();
global $user;
$canView = (!$user) || $user['Monitors'] != 'None';
if ( !$canView ) {
2018-07-25 04:41:09 +08:00
throw new UnauthorizedException(__('Insufficient Privileges'));
return;
}
}
2018-07-25 04:41:09 +08:00
// Find all zones which belong to a MonitorId
public function forMonitor($id = null) {
2016-09-04 03:02:32 +08:00
$this->loadModel('Monitor');
2018-07-25 04:41:09 +08:00
if ( !$this->Monitor->exists($id) ) {
throw new NotFoundException(__('Invalid monitor'));
2016-09-04 03:02:32 +08:00
}
$this->Zone->recursive = -1;
$zones = $this->Zone->find('all', array(
2018-07-25 04:41:09 +08:00
'conditions' => array('MonitorId' => $id)
2016-09-04 03:02:32 +08:00
));
$this->set(array(
2018-07-25 04:41:09 +08:00
'zones' => $zones,
'_serialize' => array('zones')
2016-09-04 03:02:32 +08:00
));
2018-07-25 04:41:09 +08:00
}
public function index() {
2016-09-04 03:02:32 +08:00
$this->Zone->recursive = -1;
2018-07-25 04:41:09 +08:00
global $user;
$allowedMonitors = $user ? preg_split('@,@', $user['MonitorIds'],NULL, PREG_SPLIT_NO_EMPTY) : null;
if ( $allowedMonitors ) {
2018-07-25 04:41:09 +08:00
$mon_options = array('Zones.MonitorId' => $allowedMonitors);
} else {
$mon_options = '';
2016-09-04 03:02:32 +08:00
}
$zones = $this->Zone->find('all',$mon_options);
$this->set(array(
2018-07-25 04:41:09 +08:00
'zones' => $zones,
'_serialize' => array('zones')
2016-09-04 03:02:32 +08:00
));
2018-07-25 04:41:09 +08:00
}
/**
* add method
*
* @return void
*/
public function add() {
if ( $this->request->is('post') ) {
global $user;
$canEdit = (!$user) || $user['Monitors'] == 'Edit';
if ( !$canEdit ) {
throw new UnauthorizedException(__('Insufficient Privileges'));
return;
}
2018-07-25 04:41:09 +08:00
$this->Zone->create();
if ( $this->Zone->save($this->request->data) ) {
return $this->flash(__('The zone has been saved.'), array('action' => 'index'));
}
2016-09-04 03:02:32 +08:00
}
2018-07-25 04:41:09 +08:00
$monitors = $this->Zone->Monitor->find('list');
$this->set(compact('monitors'));
}
/**
* edit method
*
* @throws NotFoundException
* @param string $id
* @return void
*/
public function edit($id = null) {
$this->Zone->id = $id;
if ( !$this->Zone->exists($id) ) {
throw new NotFoundException(__('Invalid zone'));
2016-09-04 03:02:32 +08:00
}
2018-07-25 04:41:09 +08:00
if ( $this->request->is(array('post', 'put')) ) {
global $user;
$canEdit = (!$user) || $user['Monitors'] == 'Edit';
if ( !$canEdit ) {
throw new UnauthorizedException(__('Insufficient Privileges'));
return;
}
2018-07-25 04:41:09 +08:00
if ( $this->Zone->save($this->request->data) ) {
return $this->flash(__('The zone has been saved.'), array('action' => 'index'));
}
} else {
$options = array('conditions' => array('Zone.' . $this->Zone->primaryKey => $id));
$this->request->data = $this->Zone->find('first', $options);
2016-09-04 03:02:32 +08:00
}
2018-07-25 04:41:09 +08:00
$monitors = $this->Zone->Monitor->find('list');
$this->set(compact('monitors'));
}
/**
* delete method
*
* @throws NotFoundException
* @param string $id
* @return void
*/
public function delete($id = null) {
$this->Zone->id = $id;
if ( !$this->Zone->exists() ) {
throw new NotFoundException(__('Invalid zone'));
}
$this->request->allowMethod('post', 'delete');
global $user;
$canEdit = (!$user) || $user['Monitors'] == 'Edit';
if ( !$canEdit ) {
throw new UnauthorizedException(__('Insufficient Privileges'));
return;
}
2018-07-25 04:41:09 +08:00
if ( $this->Zone->delete() ) {
return $this->flash(__('The zone has been deleted.'), array('action' => 'index'));
} else {
return $this->flash(__('The zone could not be deleted. Please, try again.'), array('action' => 'index'));
}
}
} // end class