185 lines
4.7 KiB
PHP
185 lines
4.7 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();
|
|
|
|
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();
|
|
|
|
/** @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();
|
|
|
|
$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();
|
|
|
|
$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();
|
|
|
|
$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();
|
|
|
|
/** @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'));
|
|
}
|
|
} |