/**
  * 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]));
 }