Files
UNIT3D-Community-Edition/app/Http/Controllers/ImageController.php
HDVinnie f6d3a1fabc (Update) Code Cleanup
- replace unauthorized if else checks with a much cleaner approach using the abort_unless() helper.
2018-11-29 17:41:14 -05:00

160 lines
4.5 KiB
PHP

<?php
/**
* NOTICE OF LICENSE
*
* UNIT3D is open-sourced software licensed under the GNU General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
* @author HDVinnie
*/
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Album;
use App\Image;
use Brian2694\Toastr\Toastr;
class ImageController extends Controller
{
/**
* @var Toastr
*/
private $toastr;
/**
* ImageController Constructor
*
* @param Toastr $toastr
*/
public function __construct(Toastr $toastr)
{
$this->toastr = $toastr;
}
/**
* Image Add Form
*
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function addForm($id)
{
$album = Album::find($id);
return view('gallery.addimage', ['album' => $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($this->toastr->error($v->errors()->toJson(), 'Whoops!', ['options']));
} else {
$image->save();
return redirect()->route('show_album', ['id' => $request->input('album_id')])
->with($this->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)
{
$user = auth()->user();
abort_unless($user->group->is_modo, 403);
$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($this->toastr->error($v->errors()->toJson(), 'Whoops!', ['options']));
} else {
$image->save();
return redirect()->route('show_album', ['id' => $request->input('new_album')]);
}
}
/**
* 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($this->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)
{
$user = auth()->user();
$image = Image::findOrFail($id);
abort_unless($user->group->is_modo || $user->id === $image->user_id, 403);
$image->delete();
return redirect()->route('show_album', ['id' => $image->album_id])
->with($this->toastr->success('Image has successfully been deleted', 'Yay!', ['options']));
}
}