RoleController.php
2.95 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?php
namespace App\Http\Controllers\Backend\Access\Role;
use App\Access\Model\Role\Role;
use App\Http\Controllers\Controller;
use App\Access\Repository\Role\RoleRepository;
use App\Http\Requests\Backend\Access\Role\StoreRoleRequest;
use App\Http\Requests\Backend\Access\Role\ManageRoleRequest;
use App\Http\Requests\Backend\Access\Role\UpdateRoleRequest;
use App\Access\Repository\Permission\PermissionRepository;
/**
* Class RoleController.
*/
class RoleController extends Controller
{
/**
* @var RoleRepository
*/
protected $roles;
/**
* @var PermissionRepository
*/
protected $permissions;
/**
* @param RoleRepository $roles
* @param PermissionRepository $permissions
*/
public function __construct(RoleRepository $roles, PermissionRepository $permissions)
{
$this->roles = $roles;
$this->permissions = $permissions;
}
/**
* @param ManageRoleRequest $request
*
* @return mixed
*/
public function index(ManageRoleRequest $request)
{
return view('backend.access.roles.index');
}
/**
* @param ManageRoleRequest $request
*
* @return mixed
*/
public function create(ManageRoleRequest $request)
{
return view('backend.access.roles.create')
->withPermissions($this->permissions->getAll())
->withRoleCount($this->roles->getCount());
}
/**
* @param StoreRoleRequest $request
*
* @return mixed
*/
public function store(StoreRoleRequest $request)
{
$this->roles->create($request->only('name', 'associated-permissions', 'permissions', 'sort'));
return redirect()->route('admin.access.role.index')->withFlashSuccess(trans('alerts.backend.roles.created'));
}
/**
* @param Role $role
* @param ManageRoleRequest $request
*
* @return mixed
*/
public function edit(Role $role, ManageRoleRequest $request)
{
return view('backend.access.roles.edit')
->withRole($role)
->withRolePermissions($role->permissions->pluck('id')->all())
->withPermissions($this->permissions->getAll());
}
/**
* @param Role $role
* @param UpdateRoleRequest $request
*
* @return mixed
*/
public function update(Role $role, UpdateRoleRequest $request)
{
$this->roles->update($role, $request->only('name', 'associated-permissions', 'permissions', 'sort'));
return redirect()->route('admin.access.role.index')->withFlashSuccess(trans('alerts.backend.roles.updated'));
}
/**
* @param Role $role
* @param ManageRoleRequest $request
*
* @return mixed
*/
public function destroy(Role $role, ManageRoleRequest $request)
{
$this->roles->delete($role);
return redirect()->route('admin.access.role.index')->withFlashSuccess(trans('alerts.backend.roles.deleted'));
}
}