/** * update * * @param Request $request * @param BoardPermissionHandler $boardPermission * @param string $boardId board id * @return \Illuminate\Http\RedirectResponse */ public function update(Request $request, BoardPermissionHandler $boardPermission, $boardId) { if ($request->get('useCaptcha') === 'true') { $driver = config('captcha.driver'); $captcha = config("captcha.apis.{$driver}.siteKey"); if (!$captcha) { throw new ConfigurationNotExistsException(); } } $config = $this->configHandler->get($boardId); $permissionNames = []; $permissionNames['read'] = ['readMode', 'readRating', 'readUser', 'readExcept']; $permissionNames['list'] = ['listMode', 'listRating', 'listUser', 'listExcept']; $permissionNames['create'] = ['createMode', 'createRating', 'createUser', 'createExcept']; $permissionNames['manage'] = ['manageMode', 'manageRating', 'manageUser', 'manageExcept']; $inputs = $request->except(array_merge(['_token'], $permissionNames['read'], $permissionNames['list'], $permissionNames['create'], $permissionNames['manage'])); foreach ($inputs as $key => $value) { $config->set($key, $value); } foreach ($config->getPureAll() as $key => $value) { if ($config->getParent()->get($key) != null && isset($inputs[$key]) === false) { unset($config[$key]); } } XeDB::beginTransaction(); $config = $this->instanceManager->updateConfig($config->getPureAll()); $boardPermission->set($request, $boardId); XeDB::commit(); return redirect()->to($this->urlHandler->managerUrl('edit', ['boardId' => $boardId])); }
/** * update * * @param string $boardId board id * @return \Illuminate\Http\RedirectResponse */ public function update($boardId) { $config = $this->configHandler->get($boardId); $permissionNames = []; $permissionNames['read'] = ['readMode', 'readRating', 'readUser', 'readExcept']; $permissionNames['list'] = ['listMode', 'listRating', 'listUser', 'listExcept']; $permissionNames['create'] = ['createMode', 'createRating', 'createUser', 'createExcept']; $permissionNames['manage'] = ['manageMode', 'manageRating', 'manageUser', 'manageExcept']; $inputs = Input::except(array_merge(['_token'], $permissionNames['read'], $permissionNames['list'], $permissionNames['create'], $permissionNames['manage'])); //$inputs['extensions'] = isset($inputs['extensions']) ? $inputs['extensions'] : []; foreach ($inputs as $key => $value) { $config->set($key, $value); } $config = $this->instanceManager->updateConfig($config->getPureAll()); // 확장 기능 사용 //$this->extensionHandler->activate($inputs['extensions'], $config); // permission update $grant = new Grant(); foreach ($this->permissionHandler->getActions() as $action) { $permInputs = Input::only($permissionNames[$action]); if ($permInputs[$action . 'Mode'] == 'manual') { $grant = $this->permissionHandler->createGrant($grant, $action, [Grant::RATING_TYPE => $permInputs[$action . 'Rating'], Grant::GROUP_TYPE => isset($permInputs[$action . 'Group']) ? $permInputs[$action . 'Group'] : [], Grant::USER_TYPE => explode(',', $permInputs[$action . 'User']), Grant::EXCEPT_TYPE => explode(',', $permInputs[$action . 'Except'])]); } } $this->permissionHandler->set($boardId, $grant); return Redirect::to($this->urlHandler->managerUrl('edit', ['boardId' => $boardId])); }