public function setChilds($childIds)
 {
     $currentChildIds = $this->childIds();
     $deleteIds = array_diff($currentChildIds, $childIds);
     foreach ($deleteIds as $id) {
         $delete = Resourcepermission::find($id);
         self::where('parent_id', $this->id)->where('permission_id', $delete->permission_id)->where('resource_id', $delete->resource_id)->delete();
         foreach (Role::all() as $role) {
             DB::table('lcc_resourcepermission_role')->where('role_id', $role->id)->where('parent_id', $this->id)->where('resourcepermission_id', $delete->id)->delete();
         }
     }
     $newChildIds = array_diff($childIds, $currentChildIds);
     foreach ($newChildIds as $id) {
         $child = new Resourcepermission();
         $child->permission_id = Resourcepermission::find($id)->permission_id;
         $child->resource_id = Resourcepermission::find($id)->resource_id;
         $child->parent_id = $this->id;
         $child->save();
         foreach (Role::all() as $role) {
             if ($role->resourcePermissions()->where('id', $this->id)->exists()) {
                 DB::table('lcc_resourcepermission_role')->insert(array('role_id' => $role->id, 'resourcepermission_id' => $child->id, 'parent_id' => $this->id));
             }
         }
     }
 }
Пример #2
0
 /**
  * Display a listing of the resource.
  *
  * @return Response
  */
 public function index()
 {
     if (Auth::user() && Auth::user()->id == Config::get('laracancan.super_admin')) {
         $roles = Role::all();
         return view('laracancan::role.list')->with('roles', $roles);
     }
     return response(view('laracancan::master.401'), 401);
 }