app, $request, $response); if (!$this->app->accountManager->get($request->getHeader()->getAccount())->hasPermission( PermissionType::READ, $this->app->orgId, $this->app->appName, self::MODULE_ID, PermissionState::DASHBOARD) ) { $view->setTemplate('/Web/Backend/Error/403_inline'); $response->getHeader()->setStatusCode(RequestStatusCode::R_403); return $view; } $view->setTemplate('/Modules/Tasks/Theme/Backend/task-dashboard'); $view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1001101001, $request, $response)); $tasks = TaskMapper::getNewest(25); $view->addData('tasks', $tasks); return $view; } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 * @codeCoverageIgnore */ public function viewDashboard(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable { $view = new View($this->app, $request, $response); $view->setTemplate('/Modules/Tasks/Theme/Backend/dashboard-task'); $view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1001101001, $request, $response)); $taskListView = new \Modules\Tasks\Theme\Backend\Components\Tasks\BaseView($this->app, $request, $response); $taskListView->setTemplate('/Modules/Tasks/Theme/Backend/Components/Tasks/list'); $view->addData('tasklist', $taskListView); $tasks = TaskMapper::getNewest(5); $view->addData('tasks', $tasks); return $view; } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 * @codeCoverageIgnore */ public function viewTaskView(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable { $view = new View($this->app, $request, $response); $task = TaskMapper::get((int) $request->getData('id')); $accountId = $request->getHeader()->getAccount(); if (!($task->getCreatedBy()->getId() === $accountId || $task->isCc($accountId) || $task->isForwarded($accountId)) && !$this->app->accountManager->get($accountId)->hasPermission( PermissionType::READ, $this->app->orgId, $this->app->appName, self::MODULE_ID, PermissionState::TASK, $task->getId()) ) { $view->setTemplate('/Web/Backend/Error/403_inline'); $response->getHeader()->setStatusCode(RequestStatusCode::R_403); return $view; } $view->setTemplate('/Modules/Tasks/Theme/Backend/task-single'); $view->addData('task', $task); $view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1001101001, $request, $response)); return $view; } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 * @codeCoverageIgnore */ public function viewTaskCreate(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable { $view = new View($this->app, $request, $response); if (!$this->app->accountManager->get($request->getHeader()->getAccount())->hasPermission( PermissionType::CREATE, $this->app->orgId, $this->app->appName, self::MODULE_ID, PermissionState::TASK) ) { $view->setTemplate('/Web/Backend/Error/403_inline'); $response->getHeader()->setStatusCode(RequestStatusCode::R_403); return $view; } $view->setTemplate('/Modules/Tasks/Theme/Backend/task-create'); $view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1001101001, $request, $response)); $accGrpSelector = new \Modules\Profile\Theme\Backend\Components\AccountGroupSelector\BaseView($this->app, $request, $response); $view->addData('accGrpSelector', $accGrpSelector); $editor = new \Modules\Editor\Theme\Backend\Components\Editor\BaseView($this->app, $request, $response); $view->addData('editor', $editor); return $view; } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 * @codeCoverageIgnore */ public function viewTaskAnalysis(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable { $view = new View($this->app, $request, $response); $view->setTemplate('/Modules/Tasks/Theme/Backend/task-analysis'); $view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1001101001, $request, $response)); return $view; } private function validateTaskCreate(RequestAbstract $request) : array { $val = []; if ( ($val['title'] = empty($request->getData('title'))) || ($val['description'] = empty($request->getData('description'))) || ($val['due'] = !((bool) strtotime($request->getData('due')))) || ($val['forward'] = !(is_numeric($request->getData('forward') ?? 0))) ) { return $val; } return []; } public function openNav(int $account) : int { return TaskMapper::countUnread($account); } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 */ public function apiTaskCreate(RequestAbstract $request, ResponseAbstract $response, $data = null) { if (!$this->app->accountManager->get($request->getHeader()->getAccount())->hasPermission( PermissionType::CREATE, $this->app->orgId, $this->app->appName, self::MODULE_ID, PermissionState::TASK) ) { $response->set('task_create', null); $response->getHeader()->setStatusCode(RequestStatusCode::R_403); return; } if (!empty($val = $this->validateTaskCreate($request))) { $response->set('task_create', new FormValidation($val)); return; } $task = $this->createTaskFromRequest($request); TaskMapper::create($task); $response->set($request->__toString(), $task->jsonSerialize()); } private function createTaskFromRequest(RequestAbstract $request) : Task { $task = new Task(); $task->setTitle($request->getData('title') ?? ''); $task->setDescription($request->getData('description') ?? ''); $task->setCreatedBy($request->getHeader()->getAccount()); $task->setCreatedAt(new \DateTime('now')); $task->setDue(new \DateTime($request->getData('due') ?? 'now')); $task->setStatus(TaskStatus::OPEN); $task->setType(TaskType::SINGLE); $element = new TaskElement(); $element->setForwarded($request->getData('forward') ?? $request->getHeader()->getAccount()); $element->setCreatedAt($task->getCreatedAt()); $element->setCreatedBy($task->getCreatedBy()); $element->setDue($task->getDue()); $element->setStatus(TaskStatus::OPEN); $task->addElement($element); return $task; } private function validateTaskElementCreate(RequestAbstract $request) : array { $val = []; if ( ($val['status'] = !TaskStatus::isValidValue((int) $request->getData('status'))) || ($val['due'] = !((bool) strtotime($request->getData('due')))) || ($val['task'] = !(is_numeric($request->getData('task')))) || ($val['forward'] = !(is_numeric(empty($request->getData('forward')) ? $request->getHeader()->getAccount() : $request->getData('forward')))) ) { // todo: validate correct task return $val; } return []; } /** * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return \Serializable * * @since 1.0.0 */ public function apiTaskElementCreate(RequestAbstract $request, ResponseAbstract $response, $data = null) { if (!$this->app->accountManager->get($request->getHeader()->getAccount())->hasPermission( PermissionType::CREATE, $this->app->orgId, $this->app->appName, self::MODULE_ID, PermissionState::TASK) ) { $response->set('task_element_create', null); $response->getHeader()->setStatusCode(RequestStatusCode::R_403); return; } if (!empty($val = $this->validateTaskElementCreate($request))) { $response->set('task_element_create', new FormValidation($val)); return; } $element = $this->createTaskElementFromRequest($request); TaskElementMapper::create($element); $response->set($request->__toString(), $element->jsonSerialize()); } private function createTaskElementFromRequest(RequestAbstract $request) : TaskElement { $element = new TaskElement(); $element->setForwarded($request->getData('forward') ?? $request->getHeader()->getAccount()); $element->setCreatedAt(new \DateTime('now')); $element->setCreatedBy($request->getHeader()->getAccount()); $element->setDue(new \DateTime($request->getData('due') ?? 'now')); $element->setStatus($request->getData('status')); $element->setTask($request->getData('task')); $element->setDescription($request->getData('description')); return $element; } }