MISP/app/Controller/Component/AdminCrudComponent.php

99 lines
3.3 KiB
PHP

<?php
/**
* create, read, update and delete (CRUD)
*/
class AdminCrudComponent extends AuthComponent {
/**
* add method
*
* @return void
*/
public function adminAdd() {
if ($this->controller->request->is('post')) {
$this->controller->{$this->controller->defaultModel}->create();
if ($this->controller->{$this->controller->defaultModel}->save($this->controller->request->data)) {
$this->controller->Session->setFlash(__(sprintf('The %s has been saved.', strtolower($this->controller->defaultModel))));
$this->controller->redirect(array('action' => 'index'));
} else {
if (!($this->Session->check('Message.flash'))) {
$this->controller->Session->setFlash(__(sprintf('The %s could not be saved. Please, try again.', strtolower($this->controller->defaultModel))));
}
}
}
}
/**
* index method
*
* @return void
*/
public function adminIndex() {
$this->controller->recursive = 0;
$this->controller->set('list', $this->controller->paginate());
}
/**
* edit method
*
* @param string $id
* @return void
* @throws NotFoundException
*/
public function adminEdit($id = null) {
$this->controller->{$this->controller->defaultModel}->id = $id;
if (!$this->controller->{$this->controller->defaultModel}->exists()) {
throw new NotFoundException(__(sprintf('Invalid %s', strtolower($this->controller->defaultModel))));
}
if ($this->controller->request->is('post') || $this->controller->request->is('put')) {
$this->controller->request->data[$this->controller->defaultModel]['id'] = $id;
if ($this->controller->{$this->controller->defaultModel}->save($this->controller->request->data)) {
$this->controller->Session->setFlash(__(sprintf('The %s has been saved', strtolower($this->controller->defaultModel))));
$this->controller->redirect(array('action' => 'index'));
} else {
if (!($this->Session->check('Message.flash'))) {
$this->controller->Session->setFlash(__(sprintf('The %s could not be saved. Please, try again.', strtolower($this->controller->defaultModel))));
}
}
} else {
$this->controller->request->data[$this->controller->defaultModel]['id'] = $id;
$this->controller->request->data = $this->controller->{$this->controller->defaultModel}->read(null, $id);
}
}
/**
* delete method
*
* @param string $id
* @return void
* @throws MethodNotAllowedException
* @throws NotFoundException
*/
public function adminDelete($id = null) {
if (!$this->controller->request->is('post')) {
throw new MethodNotAllowedException();
}
$this->controller->{$this->controller->defaultModel}->id = $id;
if (!$this->controller->{$this->controller->defaultModel}->exists()) {
throw new NotFoundException(__(sprintf('Invalid %s', strtolower($this->controller->defaultModel))));
}
if ($this->controller->{$this->controller->defaultModel}->delete()) {
$this->controller->Session->setFlash(__(sprintf('%s deleted', $this->controller->defaultModel)));
$this->controller->redirect(array('action' => 'index'));
}
$this->controller->Session->setFlash(__(sprintf('%s was not deleted', $this->controller->defaultModel)));
$this->controller->redirect(array('action' => 'index'));
}
public $controller;
public function initialize(Controller $controller) {
$this->controller = $controller;
}
public function startup(Controller $controller) {
$this->controller = $controller;
}
}