diff options
author | Frédéric Guillot <contact@fredericguillot.com> | 2014-01-25 14:56:02 -0500 |
---|---|---|
committer | Frédéric Guillot <contact@fredericguillot.com> | 2014-01-25 14:56:02 -0500 |
commit | 9383a15af699ede77142d040b65118e15754a2ca (patch) | |
tree | b550b5adf5bcf8f5a8793c188cc5630f26a27d49 /controllers/base.php |
First commit
Diffstat (limited to 'controllers/base.php')
-rw-r--r-- | controllers/base.php | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/controllers/base.php b/controllers/base.php new file mode 100644 index 00000000..f0ae5bd2 --- /dev/null +++ b/controllers/base.php @@ -0,0 +1,79 @@ +<?php + +namespace Controller; + +require __DIR__.'/../lib/request.php'; +require __DIR__.'/../lib/response.php'; +require __DIR__.'/../lib/session.php'; +require __DIR__.'/../lib/template.php'; +require __DIR__.'/../lib/helper.php'; +require __DIR__.'/../lib/translator.php'; +require __DIR__.'/../models/base.php'; +require __DIR__.'/../models/config.php'; +require __DIR__.'/../models/user.php'; +require __DIR__.'/../models/project.php'; +require __DIR__.'/../models/task.php'; +require __DIR__.'/../models/board.php'; + +abstract class Base +{ + protected $request; + protected $response; + protected $session; + protected $template; + protected $user; + protected $project; + protected $task; + protected $board; + protected $config; + + public function __construct() + { + $this->request = new \Request; + $this->response = new \Response; + $this->session = new \Session; + $this->template = new \Template; + $this->config = new \Model\Config; + $this->user = new \Model\User; + $this->project = new \Model\Project; + $this->task = new \Model\Task; + $this->board = new \Model\Board; + } + + public function beforeAction($controller, $action) + { + $this->session->open(); + + $public = array( + 'user' => array('login', 'check'), + 'task' => array('add'), + ); + + if (! isset($_SESSION['user']) && ! isset($public[$controller]) && ! in_array($action, $public[$controller])) { + $this->response->redirect('?controller=user&action=login'); + } + + // Load translations + $language = $this->config->get('language', 'en_US'); + if ($language !== 'en_US') \Translator\load($language); + + $this->response->csp(); + $this->response->nosniff(); + $this->response->xss(); + $this->response->hsts(); + $this->response->xframe(); + } + + public function checkPermissions() + { + if ($_SESSION['user']['is_admin'] == 0) { + $this->response->redirect('?controller=user&action=forbidden'); + } + } + + public function redirectNoProject() + { + $this->session->flash(t('There is no active project, the first step is to create a new project.')); + $this->response->redirect('?controller=project&action=create'); + } +} |