Files
UNIT3D-Community-Edition/app/Http/Controllers/ImageController.php
2018-06-05 16:23:39 -04:00

146 lines
4.3 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 \Toastr;
class ImageController extends Controller
{
/**
* 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 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 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 {
abort(403, 'Unauthorized action.');
}
}
/**
* 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)
{
if (auth()->user()->group->is_modo) {
$image = Image::findOrFail($id);
$image->delete();
return redirect()->route('show_album', ['id' => $image->album_id])
->with(Toastr::success('Image has successfully been deleted', 'Yay!', ['options']));
} else {
abort(403, 'Unauthorized action.');
}
}
}