get([ 'name', 'page/d' => 1, 'size/d' => 10 ]); $roles = SysRoleModel::withoutField([ 'pid', 'created_at', 'updated_at', 'deleted_at' ]) ->withSearch(['name'], [ 'name' => $params['name']??null ]) ->order('id', 'desc'); if (!request()->has('scene')) { $roles = $roles->paginate([ 'list_rows' => $params['size'], 'page' => $params['page'] ]); } else if ('all' == request()->param('scene')) { $roles = $roles->select(); } return success('获取成功', $roles); } // 角色详情 public function read() { $id = request()->param('id'); $role = SysRoleModel::withoutField([ 'pid', 'created_at', 'updated_at', 'deleted_at' ]) ->with(['authorities']) ->bypk($id) ->find() ->hidden(['authorities.role_id']); if (empty($role)) { return error('角色不存在'); } return success('获取成功', $role); } // 角色新增 public function save() { $post = request()->post([ 'name', 'desc', // $[*].menu_id // $[*].permissions 'menu_permission' => '[]' ]); $post['menu_permission'] = json_decode($post['menu_permission'], true); $validate = new SysRoleValidate; if (!$validate->scene('create')->check($post)) { return error($validate->getError()); } SysRoleModel::startTrans(); try { $role = SysRoleModel::create($post, ['name', 'desc']); if ($role->isEmpty()) { throw new InvalidOperateException('角色新增失败'); } if (!empty($post['menu_permission'])) { $permissions = []; foreach ($post['menu_permission'] as $menu) { if (!isset($menu['permissions'])) { continue; } foreach ($menu['permissions'] as $permission) { $permissions[] = [ 'role_id' => $role->id, 'menu_id' => $menu['menu_id'], 'permission' => $permission ]; } } $authority = (new SysRoleAuthorityModel)->saveAll($permissions); if ($authority->isEmpty()) { throw new InvalidOperateException('角色权限新增失败'); } } SysRoleModel::commit(); } catch (InvalidOperateException $e) { SysRoleModel::rollback(); return error($e->getMessage()); } catch (\Throwable $th) { SysRoleModel::rollback(); Log::error($th->getMessage()); return error('操作失败'); } return success('操作成功'); } // 角色更新 public function update() { $id = request()->param('id'); $put = request()->put([ 'name', 'desc', // $[*].menu_id // $[*].permissions 'menu_permission' => '[]' ]); $put['menu_permission'] = json_decode($put['menu_permission'], true); $validate = new SysRoleValidate; if (!$validate->scene('update')->check(array_merge($put, ['id' => $id]))) { return error($validate->getError()); } SysRoleModel::startTrans(); try { $role = SysRoleModel::bypk($id)->find(); if (empty($role)) { throw new InvalidOperateException('角色不存在'); } if (!$role->allowField(['name', 'desc'])->save($put)) { throw new InvalidOperateException('角色更新失败'); } if (!empty($put['menu_permission'])) { $permissions = []; foreach ($put['menu_permission'] as $menu) { if (!isset($menu['permissions'])) { continue; } foreach ($menu['permissions'] as $permission) { $permissions[] = [ 'role_id' => $role->id, 'menu_id' => $menu['menu_id'], 'permission' => $permission ]; } } SysRoleAuthorityModel::roleId($role->id)->delete(); $authority = (new SysRoleAuthorityModel)->saveAll($permissions); if ($authority->isEmpty()) { throw new InvalidOperateException('角色权限更新失败'); } } SysRoleModel::commit(); } catch (InvalidOperateException $e) { SysRoleModel::rollback(); return error($e->getMessage()); } catch (\Throwable $th) { SysRoleModel::rollback(); Log::error($th->getMessage()); return error('操作失败'); } return success('操作成功'); } // 角色删除 public function delete() { $id = request()->param('id'); $role = SysRoleModel::bypk($id)->find(); if (empty($role)) { return error('请确认要操作对象是否存在'); } if (!$role->delete()) { return error('操作失败'); } return success('操作成功'); } }