$album]); } /** * Add A Image To A Album * * @param \Illuminate\Http\Request $request * @return Illuminate\Http\RedirectResponse */ public function add(Request $request) { $image = new Image(); $image->user_id = auth()->user()->id; $image->album_id = $request->input('album_id'); $image->description = $request->input('description'); $image->type = $request->input('type'); $file = $request->file('image'); $random_name = uniqid(); $destinationPath = public_path('/files/img/'); $extension = $file->getClientOriginalExtension(); $filename = 'album-image_' . $random_name . '.' . $extension; $uploadSuccess = $request->file('image')->move($destinationPath, $filename); $image->image = $filename; $v = validator($image->toArray(), [ 'album_id' => 'required|numeric|exists:albums,id', 'user_id' => 'required', 'description' => 'required', 'type' => 'required', 'image' => 'required' ]); if ($v->fails()) { return redirect()->route('add_image', ['id' => $request->input('album_id')]) ->with(Toastr::error($v->errors()->toJson(), 'Whoops!', ['options'])); } else { $image->save(); return redirect()->route('show_album', ['id' => $request->input('album_id')]) ->with(Toastr::success('Your image has successfully published!', 'Yay!', ['options'])); } } /** * Move A Image * * @param \Illuminate\Http\Request $request * @return Illuminate\Http\RedirectResponse */ public function move(Request $request) { if (auth()->user()->group->is_modo) { $image = Image::findOrFail($request->input('photo')); $image->album_id = $request->input('new_album'); $v = validator($image->toArray(), [ 'new_album' => 'required|numeric|exists:albums,id', 'image' => 'required|numeric|exists:images,id' ]); if ($v->fails()) { return redirect()->route('gallery') ->with(Toastr::error($v->errors()->toJson(), 'Whoops!', ['options'])); } else { $image->save(); return redirect()->route('show_album', ['id' => $request->input('new_album')]); } } else { return back()->with(Toastr::error('You Are Not Authorized To Perform This Action!', 'Error 403', ['options'])); } } /** * Download A Image * * @param $id * @return Illuminate\Http\RedirectResponse */ public function download($id) { $image = Image::findOrFail($id); $filename = $image->image; if (!file_exists(getcwd() . '/files/img/' . $filename)) { return redirect()->route('show_album', ['id' => $image->album_id]) ->with(Toastr::error('Image File Not Found! Please Report This To Staff!', 'Error!', ['options'])); } $image->downloads++; $image->save(); return response()->download(getcwd() . '/files/img/' . $filename); } /** * Delete A Image * * @param $id * @return Illuminate\Http\RedirectResponse */ public function destroy($id) { $image = Image::findOrFail($id); if (auth()->user()->group->is_modo || auth()->user()->id === $image->user_id) { $image->delete(); return redirect()->route('show_album', ['id' => $image->album_id]) ->with(Toastr::success('Image has successfully been deleted', 'Yay!', ['options'])); } else { return back()->with(Toastr::error('You Are Not Authorized To Perform This Action!', 'Error 403', ['options'])); } } }