/** * create * * @param Request $request request * @param Validator $validator validator * @param BoardPermissionHandler $boardPermission board permission handler * @param IdentifyManager $identifyManager identify manager * @return mixed */ public function store(Request $request, Validator $validator, BoardPermissionHandler $boardPermission, IdentifyManager $identifyManager) { if (Gate::denies(BoardPermissionHandler::ACTION_CREATE, new Instance($boardPermission->name($this->instanceId)))) { throw new AccessDeniedHttpException(); } $this->checkCaptcha(); $user = Auth::user(); $this->validate($request, $validator->getCreateRule($user, $this->config)); $inputs = $request->all(); $inputs['instanceId'] = $this->instanceId; $inputs['title'] = htmlspecialchars($request->originAll()['title'], ENT_COMPAT | ENT_HTML401, 'UTF-8', false); $inputs['content'] = purify($request->originAll()['content']); if ($request->get('status') == Board::STATUS_NOTICE && $this->isManager === false) { throw new HaveNoWritePermissionHttpException(['name' => xe_trans('xe::notice')]); } // 암호 설정 if (empty($inputs['certifyKey']) === false) { $inputs['certifyKey'] = $identifyManager->hash($inputs['certifyKey']); } /** @var \Xpressengine\Editor\AbstractEditor $editor */ $editor = XeEditor::get($this->instanceId); $inputs['format'] = $editor->htmlable() ? Board::FORMAT_HTML : Board::FORMAT_NONE; // set file, tag $inputs['_files'] = array_get($inputs, $editor->getFileInputName(), []); $inputs['_hashTags'] = array_get($inputs, $editor->getTagInputName(), []); $board = $this->handler->add($inputs, $user, $this->config); return XePresenter::redirect()->to($this->urlHandler->getShow($board, $request->query->all()))->setData(['item' => $board]); }
/** * update * * @return \Illuminate\Http\RedirectResponse */ public function update() { /** @var \Xpressengine\Http\Request $request */ $request = app('request'); $user = Auth::user(); $id = $request->get('id'); if ($id === null) { throw new RequiredValueException(); } // 글 수정 시 게시판 설정이 아닌 글의 상태에 따른 처리가 되어야 한다. $item = $this->handler->get($id, $this->boardId); $doc = $item->getDocument(); // 비회원이 작성 한 글 인증 // 비회원이 작성 한 글일 때 인증페이지로 이동 /** @var \Xpressengine\Plugins\Board\IdentifyManager $identifyManager */ $identifyManager = app('xe.board.identify'); if ($doc->isGuest() === true && $identifyManager->identified($item) === false && $user->getRating() != 'super') { $e = new InvalidIdentifyException(); throw $e; } /** @var \Xpressengine\Plugins\Board\Validator $validator */ $validator = app('xe.board.validator'); $rules = $validator->makeRule($this->config); if ($user instanceof Guest) { $rules = array_merge($rules, $validator->guestUpdate()); } $this->validate($request, $rules); $inputs = $request->all(); // replace purifying content to origin content value $inputs['content'] = $request->originAll()['content']; foreach ($this->handler->documentFilter($inputs) as $name => $value) { $doc->{$name} = $value; } // 공지 $doc->notice(false); if ($request->get('status') == 'notice' && $this->isManager) { $doc->notice(true); } $item->setDocument($doc); /** @var \Xpressengine\Storage\Storage $storage */ if (($fileIds = $request->get('_files')) !== null) { $storage = app('xe.storage'); $item->setFiles($storage->getsIn($fileIds)); } // 암호 설정 if ($doc->certifyKey != '') { $doc->certifyKey = $identifyManager->hash($doc->certifyKey); } // 비회원 글 수정시 비밀번호를 입력 안한 경우 원래 비밀번호로 설 $origin = $doc->getOriginal(); if ($origin['certifyKey'] != '' && $doc->certifyKey == '') { $doc->certifyKey = $origin['certifyKey']; } $item->setDocument($doc); XeDB::beginTransaction(); $this->handler->put($item); $doc = $item->getDocument(); // 비회원 비밀번호를 변경 한 경우 세션 변경 if ($origin['certifyKey'] != '' && $origin['certifyKey'] != $doc->certifyKey) { $identifyManager->destroy($item); $identifyManager->create($item); } // 태그 등록 /** @var \Xpressengine\Tag\TagHandler $tag */ $tag = app('xe.tag'); $hashTags = array_unique(Input::get('hashTags', [])); $tag->set($this->boardId, $doc->id, $hashTags); XeDB::commit(); return Redirect::to($this->urlHandler->getShow($item, $this->urlHandler->queryStringToArray(Input::get('queryString')))); }