updateRoleLogic.go 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package role
  2. import (
  3. "context"
  4. "errors"
  5. "time"
  6. "perms-system-server/internal/consts"
  7. authHelper "perms-system-server/internal/logic/auth"
  8. "perms-system-server/internal/middleware"
  9. roleModel "perms-system-server/internal/model/role"
  10. "perms-system-server/internal/response"
  11. "perms-system-server/internal/svc"
  12. "perms-system-server/internal/types"
  13. "github.com/zeromicro/go-zero/core/logx"
  14. )
  15. type UpdateRoleLogic struct {
  16. logx.Logger
  17. ctx context.Context
  18. svcCtx *svc.ServiceContext
  19. }
  20. func NewUpdateRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateRoleLogic {
  21. return &UpdateRoleLogic{
  22. Logger: logx.WithContext(ctx),
  23. ctx: ctx,
  24. svcCtx: svcCtx,
  25. }
  26. }
  27. // UpdateRole 更新角色。修改角色名称、备注、权限级别和启用/禁用状态。非超管不能降低权限级别。变更后自动清理绑定该角色的用户缓存。
  28. func (l *UpdateRoleLogic) UpdateRole(req *types.UpdateRoleReq) error {
  29. role, err := l.svcCtx.SysRoleModel.FindOne(l.ctx, req.Id)
  30. if err != nil {
  31. return response.ErrNotFound("角色不存在")
  32. }
  33. if err := authHelper.RequireProductAdminFor(l.ctx, role.ProductCode); err != nil {
  34. return err
  35. }
  36. if len(req.Name) > 64 {
  37. return response.ErrBadRequest("角色名长度不能超过64个字符")
  38. }
  39. if len(req.Remark) > 255 {
  40. return response.ErrBadRequest("备注长度不能超过255个字符")
  41. }
  42. if req.PermsLevel < 1 || req.PermsLevel > 999 {
  43. return response.ErrBadRequest("权限级别必须在 1-999 之间")
  44. }
  45. caller := middleware.GetUserDetails(l.ctx)
  46. if caller != nil && !caller.IsSuperAdmin && req.PermsLevel < role.PermsLevel {
  47. return response.ErrForbidden("非超管不能降低角色的权限级别")
  48. }
  49. prevUpdateTime := role.UpdateTime
  50. role.Name = req.Name
  51. role.Remark = req.Remark
  52. role.PermsLevel = req.PermsLevel
  53. if req.Status != 0 {
  54. if req.Status != consts.StatusEnabled && req.Status != consts.StatusDisabled {
  55. return response.ErrBadRequest("状态值无效,仅支持 1(启用) 和 2(禁用)")
  56. }
  57. role.Status = req.Status
  58. }
  59. role.UpdateTime = time.Now().Unix()
  60. if err := l.svcCtx.SysRoleModel.UpdateWithOptLock(l.ctx, role, prevUpdateTime); err != nil {
  61. if errors.Is(err, roleModel.ErrUpdateConflict) {
  62. return response.ErrConflict("数据已被其他操作修改,请刷新后重试")
  63. }
  64. return err
  65. }
  66. affectedUserIds, err := l.svcCtx.SysUserRoleModel.FindUserIdsByRoleId(l.ctx, req.Id)
  67. if err != nil {
  68. logx.WithContext(l.ctx).Errorf("角色已更新但缓存清理失败 roleId=%d: %v", req.Id, err)
  69. return response.NewCodeError(500, "角色已更新但缓存刷新失败,请稍后手动刷新")
  70. }
  71. l.svcCtx.UserDetailsLoader.BatchDel(l.ctx, affectedUserIds, role.ProductCode)
  72. return nil
  73. }