RoleController::store()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

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