92 lines
2.3 KiB
PHP
92 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
* @package Octoleo CMS
|
|
*
|
|
* @created 9th April 2022
|
|
* @author Llewellyn van der Merwe <https://git.vdm.dev/Llewellyn>
|
|
* @git WEBD-325-45 <https://git.vdm.dev/Llewellyn/WEBD-325-45>
|
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
|
*/
|
|
|
|
namespace Octoleo\CMS\Controller;
|
|
|
|
use Joomla\Application\AbstractApplication;
|
|
use Joomla\Controller\AbstractController;
|
|
use Joomla\Input\Input;
|
|
use Joomla\Uri\Uri;
|
|
use Octoleo\CMS\Controller\Util\AccessInterface;
|
|
use Octoleo\CMS\Controller\Util\AccessTrait;
|
|
use Octoleo\CMS\Controller\Util\CheckTokenInterface;
|
|
use Octoleo\CMS\Controller\Util\CheckTokenTrait;
|
|
use Octoleo\CMS\View\Admin\DashboardHtmlView;
|
|
use Laminas\Diactoros\Response\HtmlResponse;
|
|
|
|
/**
|
|
* Controller handling the requests
|
|
*
|
|
* @method \Octoleo\CMS\Application\AdminApplication getApplication() Get the application object.
|
|
* @property-read \Octoleo\CMS\Application\AdminApplication $app Application object
|
|
*/
|
|
class DashboardController extends AbstractController implements AccessInterface, CheckTokenInterface
|
|
{
|
|
use AccessTrait, CheckTokenTrait;
|
|
|
|
/**
|
|
* The view object.
|
|
*
|
|
* @var DashboardHtmlView
|
|
*/
|
|
private $view;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param DashboardHtmlView $view The view object.
|
|
* @param Input|null $input The input object.
|
|
* @param AbstractApplication|null $app The application object.
|
|
*/
|
|
public function __construct(DashboardHtmlView $view, Input $input = null, AbstractApplication $app = null)
|
|
{
|
|
parent::__construct($input, $app);
|
|
|
|
$this->view = $view;
|
|
}
|
|
|
|
/**
|
|
* Execute the controller.
|
|
*
|
|
* @return boolean
|
|
* @throws \Exception
|
|
*/
|
|
public function execute(): bool
|
|
{
|
|
// Do not Enable browser caching
|
|
$this->getApplication()->allowCache(false);
|
|
|
|
$task = $this->getInput()->getString('task', '');
|
|
$id = $this->getInput()->getInt('id', 0);
|
|
|
|
$this->view->setActiveDashboard($task);
|
|
$this->view->setActiveId($id);
|
|
|
|
// validate form token
|
|
if ('access' === $task || 'signup' === $task)
|
|
{
|
|
$this->checkToken();
|
|
}
|
|
|
|
// check if user is allowed to access
|
|
if ($this->allow($task))
|
|
{
|
|
$this->getApplication()->setResponse(new HtmlResponse($this->view->render()));
|
|
}
|
|
else
|
|
{
|
|
// go to set page
|
|
$this->_redirect();
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|