Files
UNIT3D-Community-Edition/app/Http/Controllers/Staff/ModerationController.php
HDVinnie 77a8c2140a (Update) NOTICE OF LICENSE
- Updated Author Names To Match GitHub Usernames For Clarity.
2017-12-15 22:45:37 -05:00

97 lines
2.8 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://choosealicense.com/licenses/gpl-3.0/ GNU General Public License v3.0
* @author HDVinnie
*/
namespace App\Http\Controllers\Staff;
use App\User;
use App\Group;
use App\Torrent;
use App\Requests;
use App\Category;
use App\Peer;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Facades\Request;
use \Toastr;
class ModerationController extends Controller
{
/**
* Torrent Moderation.
*
*/
public function moderation()
{
$pending = Torrent::pending()->get(); //returns all Pending Torrents
$rejected = Torrent::rejected()->get();
$modder = DB::table('torrents')->where('status', '=', '0')->count();
return view('Staff.torrent.moderation', ['pending' => $pending, 'rejected' => $rejected, 'modder' => $modder]);
}
/**
* Torrent Moderation -> approve
*
* @param $slug Slug of the torrent
* @param $id Id of the torrent
*/
public function approve($slug, $id)
{
Torrent::approve($id);
return Redirect::route('moderation')->with(Toastr::success('Torrent Approved', 'Approve', ['options']));
}
/**
* Torrent Moderation -> reject
*
* @param $slug Slug of the torrent
* @param $id Id of the torrent
*/
public function reject($slug, $id)
{
Torrent::reject($id);
return Redirect::route('moderation')->with(Toastr::error('Torrent Rejected', 'Reject', ['options']));
}
/**
* Resets the filled and approved attributes on a given request
* @method resetRequest
*
*/
public function resetRequest($id)
{
$user = Auth::user();
// reset code here
if ($user->group->is_modo) {
$request = Requests::findOrFail($id);
$request->filled_by = null;
$request->filled_when = null;
$request->filled_hash = null;
$request->approved_by = null;
$request->approved_when = null;
$request->save();
return Redirect::route('request', ['id' => $id])->with(Toastr::warning("The request has been reset!", 'Request reset!', ['options']));
} else {
return Redirect::route('request', ['id' => $id])->with(Toastr::warning("You don't have access to this operation!", 'Error!', ['options']));
}
return Redirect::route('requests')->with(Toastr::success("Unable to find request", 'Request not found', ['options']));
}
}