public function indexAction(Request $request, SessionInterface $session) { Util::checkUserIsLoggedInAndRedirect(); $emptyName = false; if ($request->request->has('add_permission_scheme')) { $name = Util::cleanRegularInputField($request->request->get('name')); $description = Util::cleanRegularInputField($request->request->get('description')); if (empty($name)) { $emptyName = true; } if (!$emptyName) { $permissionScheme = new PermissionScheme($session->get('client/id'), $name, $description); $currentDate = Util::getServerCurrentDateTime(); $permissionSchemeId = $permissionScheme->save($currentDate); $this->getLogger()->addInfo('ADD Yongo Permission Scheme ' . $name, $this->getLoggerContext()); return new RedirectResponse('/yongo/administration/permission-schemes'); } } $sectionPageTitle = $session->get('client/settings/title_name') . ' / ' . SystemProduct::SYS_PRODUCT_YONGO_NAME . ' / Create Issue Permission Scheme'; return $this->render(__DIR__ . '/../../../Resources/views/administration/permission_scheme/Add.php', get_defined_vars()); }
public function indexAction(Request $request, SessionInterface $session) { Util::checkUserIsLoggedInAndRedirect(); $permissionSchemeId = $request->get('id'); $permissionScheme = $this->getRepository(PermissionScheme::class)->getMetaDataById($permissionSchemeId); if ($permissionScheme['client_id'] != $session->get('client/id')) { return new RedirectResponse('/general-settings/bad-link-access-denied'); } $emptyName = false; $duplicateName = false; if ($request->request->has('copy_permission_scheme')) { $name = Util::cleanRegularInputField($request->request->get('name')); $description = Util::cleanRegularInputField($request->request->get('description')); if (empty($name)) { $emptyName = true; } $duplicatePermissionScheme = $this->getRepository(PermissionScheme::class)->getMetaDataByNameAndClientId($session->get('client/id'), mb_strtolower($name)); if ($duplicatePermissionScheme) { $duplicateName = true; } if (!$emptyName && !$duplicateName) { $copiedPermissionScheme = new PermissionScheme($session->get('client/id'), $name, $description); $currentDate = Util::getServerCurrentDateTime(); $copiedPermissionSchemeId = $copiedPermissionScheme->save($currentDate); $permissionSchemeData = $this->getRepository(PermissionScheme::class)->getDataByPermissionSchemeId($permissionSchemeId); while ($permissionSchemeData && ($data = $permissionSchemeData->fetch_array(MYSQLI_ASSOC))) { $copiedPermissionScheme->addDataRaw($copiedPermissionSchemeId, $data['sys_permission_id'], $data['permission_role_id'], $data['group_id'], $data['user_id'], $data['current_assignee'], $data['reporter'], $data['project_lead'], $currentDate); } $this->getLogger()->addInfo('Copy Yongo Permission Scheme ' . $permissionScheme['name'], $this->getLoggerContext()); return new RedirectResponse('/yongo/administration/permission-schemes'); } } $menuSelectedCategory = 'issue'; $sectionPageTitle = $session->get('client/settings/title_name') . ' / ' . SystemProduct::SYS_PRODUCT_YONGO_NAME . ' / Copy Permission Scheme'; return $this->render(__DIR__ . '/../../../Resources/views/administration/permission_scheme/Copy.php', get_defined_vars()); }