185 lines
4.8 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Facade\Theme;
use App\Facade\UserConfig;
use App\Group;
use App\Http\Controllers\Controller;
use App\Http\Requests\StoreGroupRequest;
use App\Permission;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\App;
use Illuminate\Support\Facades\View;
class GroupController extends Controller
{
public function __construct()
{
$this->middleware('auth');
View::share('is_admin', true);
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
return Theme::render('admin.create_group');
}
public function delete($id)
{
$this->authorizeAccessToAdminPanel();
$group = Group::where('id', intval($id))->first();
if (is_null($group))
{
App::abort(404);
}
return Theme::render('admin.delete_group', ['group' => $group]);
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy(Request $request, $id)
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
/** @var Group $group */
$group = Group::where('id', intval($id))->first();
if (is_null($group))
{
App::abort(404);
}
try
{
$group->delete();
$request->session()->flash('success', trans('admin.group_deletion_successful', [
'name' => $group->name
]));
}
catch (\Exception $ex)
{
$request->session()->flash('error', trans('admin.group_deletion_failed', [
'error_message' => $ex->getMessage(),
'name' => $group->name
]));
}
return redirect(route('groups.index'));
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit(Request $request, $id)
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
$group = Group::where('id', intval($id))->first();
if (is_null($group))
{
App::abort(404);
}
if (!$request->session()->has('_old_input'))
{
$request->session()->flash('_old_input', $group->toArray());
}
return Theme::render('admin.edit_group', [
'all_permissions' => Permission::where('section', 'admin')->get(),
'group' => $group
]);
}
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index(Request $request)
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
$groups = Group::orderBy('name')
->paginate(UserConfig::get('items_per_page'));
return Theme::render('admin.list_groups', [
'error' => $request->session()->get('error'),
'groups' => $groups,
'success' => $request->session()->get('success'),
'warning' => $request->session()->get('warning')
]);
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(StoreGroupRequest $request)
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
$group = new Group();
$group->fill($request->only(['name']));
$group->save();
return redirect(route('groups.index'));
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(StoreGroupRequest $request, $id)
{
$this->authorizeAccessToAdminPanel('admin:manage-groups');
/** @var Group $group */
$group = Group::where('id', intval($id))->first();
if (is_null($group))
{
App::abort(404);
}
$group->fill($request->only(['name']));
// Update the admin permissions
$group->adminPermissions()->detach();
$permissions = $request->get('permissions');
if (is_array($permissions) && array_key_exists($id, $permissions))
{
foreach ($permissions[$id] as $permissionID)
{
$group->adminPermissions()->attach($permissionID, [
'created_at' => new \DateTime(),
'updated_at' => new \DateTime()
]);
}
}
$group->save();
return redirect(route('groups.index'));
}
}