RolesController   A
last analyzed

Complexity

Total Complexity 17

Size/Duplication

Total Lines 226
Duplicated Lines 0 %

Coupling/Cohesion

Components 3
Dependencies 10

Importance

Changes 0
Metric Value
wmc 17
lcom 3
cbo 10
dl 0
loc 226
rs 10
c 0
b 0
f 0

13 Methods

Rating   Name   Duplication   Size   Complexity  
A index() 0 6 1
A logs() 0 8 1
A import() 0 9 1
A stash() 0 6 1
A hoard() 0 23 5
A importLogs() 0 8 1
A create() 0 4 1
A edit() 0 4 1
A form() 0 6 1
A store() 0 4 1
A update() 0 4 1
A process() 0 13 1
A destroy() 0 9 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Cortex\Auth\Http\Controllers\Adminarea;
6
7
use Exception;
8
use Cortex\Auth\Models\Role;
9
use Illuminate\Http\Request;
10
use Illuminate\Foundation\Http\FormRequest;
11
use Cortex\Foundation\DataTables\LogsDataTable;
12
use Cortex\Foundation\Importers\DefaultImporter;
13
use Cortex\Auth\DataTables\Adminarea\RolesDataTable;
14
use Cortex\Foundation\DataTables\ImportLogsDataTable;
15
use Cortex\Foundation\Http\Requests\ImportFormRequest;
16
use Cortex\Auth\Http\Requests\Adminarea\RoleFormRequest;
17
use Cortex\Foundation\DataTables\ImportRecordsDataTable;
18
use Cortex\Foundation\Http\Controllers\AuthorizedController;
19
use Cortex\Auth\Http\Requests\Adminarea\RoleFormProcessRequest;
20
21
class RolesController extends AuthorizedController
22
{
23
    /**
24
     * {@inheritdoc}
25
     */
26
    protected $resource = Role::class;
27
28
    /**
29
     * List all roles.
30
     *
31
     * @param \Cortex\Auth\DataTables\Adminarea\RolesDataTable $rolesDataTable
32
     *
33
     * @return \Illuminate\Http\JsonResponse|\Illuminate\View\View
34
     */
35
    public function index(RolesDataTable $rolesDataTable)
36
    {
37
        return $rolesDataTable->with([
38
            'id' => 'adminarea-roles-index-table',
39
        ])->render('cortex/foundation::adminarea.pages.datatable-index');
40
    }
41
42
    /**
43
     * List role logs.
44
     *
45
     * @param \Cortex\Auth\Models\Role                    $role
46
     * @param \Cortex\Foundation\DataTables\LogsDataTable $logsDataTable
47
     *
48
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
0 ignored issues
show
Documentation introduced by
Should the return type not be \Illuminate\Http\JsonRes...e|\Illuminate\View\View?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
49
     */
50
    public function logs(Role $role, LogsDataTable $logsDataTable)
51
    {
52
        return $logsDataTable->with([
53
            'resource' => $role,
54
            'tabs' => 'adminarea.roles.tabs',
55
            'id' => "adminarea-roles-{$role->getRouteKey()}-logs-table",
56
        ])->render('cortex/foundation::adminarea.pages.datatable-tab');
57
    }
58
59
    /**
60
     * Import roles.
61
     *
62
     * @param \Cortex\Auth\Models\Role                             $role
63
     * @param \Cortex\Foundation\DataTables\ImportRecordsDataTable $importRecordsDataTable
64
     *
65
     * @return \Illuminate\View\View
66
     */
67
    public function import(Role $role, ImportRecordsDataTable $importRecordsDataTable)
68
    {
69
        return $importRecordsDataTable->with([
70
            'resource' => $role,
71
            'tabs' => 'adminarea.roles.tabs',
72
            'url' => route('adminarea.roles.stash'),
73
            'id' => "adminarea-roles-{$role->getRouteKey()}-import-table",
74
        ])->render('cortex/foundation::adminarea.pages.datatable-dropzone');
75
    }
76
77
    /**
78
     * Stash roles.
79
     *
80
     * @param \Cortex\Foundation\Http\Requests\ImportFormRequest $request
81
     * @param \Cortex\Foundation\Importers\DefaultImporter       $importer
82
     *
83
     * @return void
84
     */
85
    public function stash(ImportFormRequest $request, DefaultImporter $importer)
0 ignored issues
show
Unused Code introduced by
The parameter $request is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
86
    {
87
        // Handle the import
88
        $importer->config['resource'] = $this->resource;
89
        $importer->handleImport();
90
    }
91
92
    /**
93
     * Hoard roles.
94
     *
95
     * @param \Cortex\Foundation\Http\Requests\ImportFormRequest $request
96
     *
97
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
98
     */
99
    public function hoard(ImportFormRequest $request)
100
    {
101
        foreach ((array) $request->get('selected_ids') as $recordId) {
102
            $record = app('cortex.foundation.import_record')->find($recordId);
103
104
            try {
105
                $fillable = collect($record['data'])->intersectByKeys(array_flip(app('rinvex.auth.role')->getFillable()))->toArray();
106
107
                tap(app('rinvex.auth.role')->firstOrNew($fillable), function ($instance) use ($record) {
108
                    $instance->save() && $record->delete();
109
                });
110
            } catch (Exception $exception) {
111
                $record->notes = $exception->getMessage().(method_exists($exception, 'getMessageBag') ? "\n".json_encode($exception->getMessageBag())."\n\n" : '');
0 ignored issues
show
Bug introduced by
The method getMessageBag() does not exist on Exception. Did you maybe mean getMessage()?

This check marks calls to methods that do not seem to exist on an object.

This is most likely the result of a method being renamed without all references to it being renamed likewise.

Loading history...
112
                $record->status = 'fail';
113
                $record->save();
114
            }
115
        }
116
117
        return intend([
118
            'back' => true,
119
            'with' => ['success' => trans('cortex/foundation::messages.import_complete')],
120
        ]);
121
    }
122
123
    /**
124
     * List role import logs.
125
     *
126
     * @param \Cortex\Foundation\DataTables\ImportLogsDataTable $importLogsDatatable
127
     *
128
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
0 ignored issues
show
Documentation introduced by
Should the return type not be \Illuminate\Http\JsonRes...e|\Illuminate\View\View?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
129
     */
130
    public function importLogs(ImportLogsDataTable $importLogsDatatable)
131
    {
132
        return $importLogsDatatable->with([
133
            'resource' => trans('cortex/auth::common.role'),
134
            'tabs' => 'adminarea.roles.tabs',
135
            'id' => 'adminarea-roles-import-logs-table',
136
        ])->render('cortex/foundation::adminarea.pages.datatable-tab');
137
    }
138
139
    /**
140
     * Create new role.
141
     *
142
     * @param \Illuminate\Http\Request $request
143
     * @param \Cortex\Auth\Models\Role $role
144
     *
145
     * @return \Illuminate\View\View
146
     */
147
    public function create(Request $request, Role $role)
148
    {
149
        return $this->form($request, $role);
150
    }
151
152
    /**
153
     * Edit given role.
154
     *
155
     * @param \Cortex\Auth\Http\Requests\Adminarea\RoleFormRequest $request
156
     * @param \Cortex\Auth\Models\Role                             $role
157
     *
158
     * @return \Illuminate\View\View
159
     */
160
    public function edit(RoleFormRequest $request, Role $role)
161
    {
162
        return $this->form($request, $role);
163
    }
164
165
    /**
166
     * Show role create/edit form.
167
     *
168
     * @param \Illuminate\Http\Request $request
169
     * @param \Cortex\Auth\Models\Role $role
170
     *
171
     * @return \Illuminate\View\View
172
     */
173
    protected function form(Request $request, Role $role)
174
    {
175
        $abilities = $request->user($this->getGuard())->getManagedAbilities();
176
177
        return view('cortex/auth::adminarea.pages.role', compact('role', 'abilities'));
178
    }
179
180
    /**
181
     * Store new role.
182
     *
183
     * @param \Cortex\Auth\Http\Requests\Adminarea\RoleFormProcessRequest $request
184
     * @param \Cortex\Auth\Models\Role                                    $role
185
     *
186
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
187
     */
188
    public function store(RoleFormProcessRequest $request, Role $role)
189
    {
190
        return $this->process($request, $role);
191
    }
192
193
    /**
194
     * Update given role.
195
     *
196
     * @param \Cortex\Auth\Http\Requests\Adminarea\RoleFormProcessRequest $request
197
     * @param \Cortex\Auth\Models\Role                                    $role
198
     *
199
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
200
     */
201
    public function update(RoleFormProcessRequest $request, Role $role)
202
    {
203
        return $this->process($request, $role);
204
    }
205
206
    /**
207
     * Process stored/updated role.
208
     *
209
     * @param \Illuminate\Foundation\Http\FormRequest $request
210
     * @param \Cortex\Auth\Models\Role                $role
211
     *
212
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
213
     */
214
    protected function process(FormRequest $request, Role $role)
215
    {
216
        // Prepare required input fields
217
        $data = $request->validated();
218
219
        // Save role
220
        $role->fill($data)->save();
221
222
        return intend([
223
            'url' => route('adminarea.roles.index'),
224
            'with' => ['success' => trans('cortex/foundation::messages.resource_saved', ['resource' => trans('cortex/auth::common.role'), 'identifier' => $role->title])],
225
        ]);
226
    }
227
228
    /**
229
     * Destroy given role.
230
     *
231
     * @param \Cortex\Auth\Models\Role $role
232
     *
233
     * @throws \Exception
234
     *
235
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
236
     */
237
    public function destroy(Role $role)
238
    {
239
        $role->delete();
240
241
        return intend([
242
            'url' => route('adminarea.roles.index'),
243
            'with' => ['warning' => trans('cortex/foundation::messages.resource_deleted', ['resource' => trans('cortex/auth::common.role'), 'identifier' => $role->title])],
244
        ]);
245
    }
246
}
247