/** * Display a listing of the resource. * * @return Response */ public function index() { if (Auth::user() && Auth::user()->id == Config::get('laracancan.super_admin')) { $resources = Resource::all(); return view('laracancan::resource.list')->with('resources', $resources); } return response(view('laracancan::master.401'), 401); }
public function manageRolePermissionsAction($id) { if (Auth::user() && Auth::user()->id == Config::get('laracancan.super_admin')) { $role = Role::find($id); $role->resourcePermissions()->detach(); foreach (Resource::all() as $resource) { $permissions = Input::get($resource->id . "_resourcepermissions"); if ($permissions != null) { foreach ($permissions as $permission) { $resourcePermission = Resourcepermission::where('permission_id', $permission)->where('resource_id', $resource->id)->first(); $role->resourcePermissions()->detach([$resourcePermission->id]); $role->resourcePermissions()->attach([$resourcePermission->id]); foreach ($resourcePermission->childResourcePermissions as $child) { $role->resourcePermissions()->attach([$child->id => ['parent_id' => $resourcePermission->id]]); } } } } return redirect()->back()->with('flash_success', 'Permissions saved successfully!'); } return response(view('laracancan::master.401'), 401); }
/** * Function for resources of user based on a specific permission * @param $permission * @return array */ function resourcesByPermission($permission) { if ($this->id == Config::get('laracancan.super_admin', 0)) { return Resource::all(); } $roles = $this->roles; $resourses = array(); foreach ($roles as $role) { $roleResources = $role->resourcesByPermission($permission); $resourses = array_merge($resourses, $roleResources ? $roleResources : array()); } $resourses = array_unique($resourses); return $resourses; }