rolesModel = Config::get('laratrust.models.role'); $this->permissionModel = Config::get('laratrust.models.permission'); } public function index() { return View::make('panel.authorization.roles.index', [ 'roles' => $this->rolesModel::withCount('permissions') ->simplePaginate(10), ]); } public function create() { return View::make('panel.authorization.edit', [ 'model' => null, 'permissions' => $this->permissionModel::all(['id', 'name']), 'type' => 'role', ]); } public function store(Request $request) { $data = $request->validate([ 'name' => 'required|string|unique:roles,name', 'display_name' => 'nullable|string', 'description' => 'nullable|string', ]); $role = $this->rolesModel::create($data); $role->syncPermissions($request->get('permissions') ?? []); Session::flash('laratrust-success', 'Role created successfully'); return redirect(route('roles.index')); } public function edit($id) { $role = $this->rolesModel::query() ->with('permissions:id') ->findOrFail($id); $permissions = $this->permissionModel::all(['id', 'name']) ->map(function ($permission) use ($role) { $permission->assigned = $role->permissions ->pluck('id') ->contains($permission->id); return $permission; }); return View::make('panel.authorization.edit', [ 'model' => $role, 'permissions' => $permissions, 'type' => 'role', ]); } public function update(Request $request, $id) { $role = $this->rolesModel::findOrFail($id); $data = $request->validate([ 'display_name' => 'nullable|string', 'description' => 'nullable|string', ]); $role->update($data); $role->syncPermissions($request->get('permissions') ?? []); Session::flash('laratrust-success', 'Role updated successfully'); return redirect(route('roles.index')); } public function destroy($id) { $usersAssignedToRole = DB::table(Config::get('laratrust.tables.role_user')) ->where(Config::get('laratrust.foreign_keys.role'), $id) ->count(); if ($usersAssignedToRole > 0) { Session::flash('laratrust-warning', 'Role is attached to one or more users. It can not be deleted'); } else { Session::flash('laratrust-success', 'Role deleted successfully'); $this->rolesModel::destroy($id); } return redirect(route('roles.index')); } }