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, null, RelationType::ALL, 1); $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((string) $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((string) ($request->getData('title') ?? '')); $task->setDescription(Markdown::parse((string) ($request->getData('description') ?? ''))); $task->setDescriptionRaw((string) ($request->getData('description') ?? '')); $task->setCreatedBy($request->getHeader()->getAccount()); $task->setDue(new \DateTime((string) ($request->getData('due') ?? 'now'))); $task->setStatus(TaskStatus::OPEN); $task->setType(TaskType::SINGLE); $element = new TaskElement(); $element->setForwarded((int) ($request->getData('forward') ?? $request->getHeader()->getAccount())); $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((string) $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((int) ($request->getData('forward') ?? $request->getHeader()->getAccount())); $element->setCreatedBy($request->getHeader()->getAccount()); $element->setDue(new \DateTime((string) ($request->getData('due') ?? 'now'))); $element->setStatus((int) ($request->getData('status'))); $element->setTask((int) ($request->getData('task'))); $element->setDescription(Markdown::parse((string) ($request->getData('description')))); $element->setDescriptionRaw((string) ($request->getData('description'))); return $element; } }