diff --git a/app/Http/Controllers/Admin/InfoController.php b/app/Http/Controllers/Admin/InfoController.php index a11bf74..faf2909 100644 --- a/app/Http/Controllers/Admin/InfoController.php +++ b/app/Http/Controllers/Admin/InfoController.php @@ -3,6 +3,7 @@ namespace App\Http\Controllers\Admin; use App\Http\Controllers\Controller; +use App\Http\Requests\AdminInfoStoreRequest; use App\Information; use Illuminate\Http\Request; use Illuminate\Support\Facades\Validator; @@ -31,21 +32,13 @@ class InfoController extends Controller ]); } - public function store(Request $request) + public function store(AdminInfoStoreRequest $request) { $inputs = $request->all(); if (!$request->has('pinned')) { $inputs['pinned'] = false; } - // TODO: #updateと全く同じだし、フォームリクエストにしたほうがよいのでは? - Validator::make($inputs, [ - 'category' => ['required', Rule::in(array_keys(Information::CATEGORIES))], - 'pinned' => 'nullable|boolean', - 'title' => 'required|string|max:255', - 'content' => 'required|string|max:10000' - ])->validate(); - $info = Information::create($inputs); return redirect()->route('admin.info.edit', ['info' => $info])->with('status', 'お知らせを更新しました。'); @@ -61,20 +54,13 @@ class InfoController extends Controller ]); } - public function update(Request $request, Information $info) + public function update(AdminInfoStoreRequest $request, Information $info) { $inputs = $request->all(); if (!$request->has('pinned')) { $inputs['pinned'] = false; } - Validator::make($inputs, [ - 'category' => ['required', Rule::in(array_keys(Information::CATEGORIES))], - 'pinned' => 'nullable|boolean', - 'title' => 'required|string|max:255', - 'content' => 'required|string|max:10000' - ])->validate(); - $info->fill($inputs)->save(); return redirect()->route('admin.info.edit', ['info' => $info])->with('status', 'お知らせを更新しました。'); diff --git a/app/Http/Requests/AdminInfoStoreRequest.php b/app/Http/Requests/AdminInfoStoreRequest.php new file mode 100644 index 0000000..45b3d2e --- /dev/null +++ b/app/Http/Requests/AdminInfoStoreRequest.php @@ -0,0 +1,35 @@ + ['required', Rule::in(array_keys(Information::CATEGORIES))], + 'pinned' => 'nullable|boolean', + 'title' => 'required|string|max:255', + 'content' => 'required|string|max:10000' + ]; + } +}