fix bug role and permission is not defined when user is not loggedin
This commit is contained in:
@@ -47,11 +47,17 @@ class HandleInertiaRequests extends Middleware
|
|||||||
'warning' => $request->session()->get('warning'),
|
'warning' => $request->session()->get('warning'),
|
||||||
],
|
],
|
||||||
|
|
||||||
'$roles' => $roles = fn () => $request->user()?->roles()->with('permissions:id,name')->get(['id', 'name']),
|
'$roles' => $roles = fn () => $request->user()?->roles()->with('permissions:id,name')->get(['id', 'name']) ?: [],
|
||||||
'$permissions' => function () use ($roles, $request) {
|
'$permissions' => function () use ($roles, $request) {
|
||||||
$permissions = $request->user()?->permissions()->get(['id', 'name']);
|
$user = $request->user();
|
||||||
|
|
||||||
return $roles()->reduce(function (Collection $prev, Role $role) {
|
if (!$user) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$permissions = $user->permissions()->get(['id', 'name']);
|
||||||
|
|
||||||
|
return $roles()?->reduce(function (Collection $prev, Role $role) {
|
||||||
$role->permissions->each(fn (Permission $permission) => $prev->push($permission));
|
$role->permissions->each(fn (Permission $permission) => $prev->push($permission));
|
||||||
|
|
||||||
return $prev;
|
return $prev;
|
||||||
|
|||||||
Reference in New Issue
Block a user