141 lines
3.3 KiB
PHP
Raw Normal View History

2017-09-14 22:21:00 +03:00
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Http\Requests\Auth\Role as Request;
use App\Models\Auth\Permission;
use App\Models\Auth\Role;
class Roles extends Controller
{
/**
* Display a listing of the resource.
*
* @return Response
*/
public function index()
{
$roles = Role::collect();
return view('auth.roles.index', compact('roles'));
}
/**
* Show the form for creating a new resource.
*
* @return Response
*/
public function create()
{
2018-09-26 17:20:19 +03:00
$names = $permissions = [];
$allPermissions = Permission::all();
2017-09-14 22:21:00 +03:00
2018-09-26 17:20:19 +03:00
foreach ($allPermissions as $permission) {
// permission code explode - and get permission type
$n = explode('-', $permission->name);
if (!in_array($n[0], $names)) {
$names[] = $n[0];
}
$permissions[$n[0]][] = $permission;
}
return view('auth.roles.create', compact('names', 'permissions'));
2017-09-14 22:21:00 +03:00
}
/**
* Store a newly created resource in storage.
*
* @param Request $request
*
* @return Response
*/
public function store(Request $request)
{
// Create role
$role = Role::create($request->all());
// Attach permissions
$role->permissions()->attach($request['permissions']);
$message = trans('messages.success.added', ['type' => trans_choice('general.roles', 1)]);
flash($message)->success();
return redirect('auth/roles');
}
/**
* Show the form for editing the specified resource.
*
* @param Role $role
*
* @return Response
*/
public function edit(Role $role)
{
//$permissions = Permission::all()->sortBy('display_name');
2018-09-26 17:20:19 +03:00
$names = $permissions = [];
$allPermissions = Permission::all();
2017-09-14 22:21:00 +03:00
$rolePermissions = $role->permissions->pluck('id', 'id')->toArray();
2018-09-26 17:20:19 +03:00
foreach ($allPermissions as $permission) {
// permission code explode - and get permission type
$n = explode('-', $permission->name);
if (!in_array($n[0], $names)) {
$names[] = $n[0];
}
$permissions[$n[0]][] = $permission;
}
return view('auth.roles.edit', compact('role', 'names', 'permissions', 'rolePermissions'));
2017-09-14 22:21:00 +03:00
}
/**
* Update the specified resource in storage.
*
* @param Role $role
* @param Request $request
*
* @return Response
*/
public function update(Role $role, Request $request)
{
// Update role
$role->update($request->all());
// Sync permissions
$role->permissions()->sync($request['permissions']);
$message = trans('messages.success.updated', ['type' => trans_choice('general.roles', 1)]);
flash($message)->success();
return redirect('auth/roles');
}
/**
* Remove the specified resource from storage.
*
* @param Role $role
*
* @return Response
*/
public function destroy(Role $role)
{
$role->delete();
$message = trans('messages.success.deleted', ['type' => trans_choice('general.roles', 1)]);
flash($message)->success();
return redirect('auth/roles');
}
}