loadModel('Monitor'); if ( !$this->Monitor->exists($id) ) { throw new NotFoundException(__('Invalid monitor')); } $this->Zone->recursive = -1; $zones = $this->Zone->find('all', array( 'conditions' => array('MonitorId' => $id) )); $this->set(array( 'zones' => $zones, '_serialize' => array('zones') )); } public function index() { $this->Zone->recursive = -1; global $user; $allowedMonitors = $user ? preg_split('@,@', $user['MonitorIds'],NULL, PREG_SPLIT_NO_EMPTY) : null; if ( $allowedMonitors ) { $mon_options = array('Zones.MonitorId' => $allowedMonitors); } else { $mon_options = ''; } $zones = $this->Zone->find('all',$mon_options); $this->set(array( 'zones' => $zones, '_serialize' => array('zones') )); } /** * 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; } $this->Zone->create(); if ( $this->Zone->save($this->request->data) ) { return $this->flash(__('The zone has been saved.'), array('action' => 'index')); } } $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')); } if ( $this->request->is(array('post', 'put')) ) { global $user; $canEdit = (!$user) || $user['Monitors'] == 'Edit'; if ( !$canEdit ) { throw new UnauthorizedException(__('Insufficient Privileges')); return; } 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); } $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; } 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