updateMemberLogic.go 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package member
  2. import (
  3. "context"
  4. "time"
  5. "perms-system-server/internal/consts"
  6. authHelper "perms-system-server/internal/logic/auth"
  7. "perms-system-server/internal/response"
  8. "perms-system-server/internal/svc"
  9. "perms-system-server/internal/types"
  10. "github.com/zeromicro/go-zero/core/logx"
  11. "github.com/zeromicro/go-zero/core/stores/sqlx"
  12. )
  13. type UpdateMemberLogic struct {
  14. logx.Logger
  15. ctx context.Context
  16. svcCtx *svc.ServiceContext
  17. }
  18. func NewUpdateMemberLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateMemberLogic {
  19. return &UpdateMemberLogic{
  20. Logger: logx.WithContext(ctx),
  21. ctx: ctx,
  22. svcCtx: svcCtx,
  23. }
  24. }
  25. // UpdateMember 更新产品成员。修改成员类型或启用/禁用状态。降级最后一个 ADMIN 时会被拒绝以保证产品始终有管理员。
  26. func (l *UpdateMemberLogic) UpdateMember(req *types.UpdateMemberReq) error {
  27. member, err := l.svcCtx.SysProductMemberModel.FindOne(l.ctx, req.Id)
  28. if err != nil {
  29. return response.ErrNotFound("成员不存在")
  30. }
  31. if req.MemberType != consts.MemberTypeAdmin &&
  32. req.MemberType != consts.MemberTypeDeveloper &&
  33. req.MemberType != consts.MemberTypeMember {
  34. return response.ErrBadRequest("无效的成员类型")
  35. }
  36. if err := authHelper.CheckManageAccess(l.ctx, l.svcCtx, member.UserId, member.ProductCode); err != nil {
  37. return err
  38. }
  39. if err := authHelper.CheckMemberTypeAssignment(l.ctx, req.MemberType); err != nil {
  40. return err
  41. }
  42. nextType := req.MemberType
  43. nextStatus := member.Status
  44. if req.Status != 0 {
  45. if req.Status != consts.StatusEnabled && req.Status != consts.StatusDisabled {
  46. return response.ErrBadRequest("状态值无效,仅支持 1(启用) 和 2(禁用)")
  47. }
  48. nextStatus = req.Status
  49. }
  50. if err := l.svcCtx.SysProductMemberModel.TransactCtx(l.ctx, func(ctx context.Context, session sqlx.Session) error {
  51. locked, err := l.svcCtx.SysProductMemberModel.FindOneForUpdateTx(ctx, session, req.Id)
  52. if err != nil {
  53. return response.ErrNotFound("成员不存在")
  54. }
  55. wasActiveAdmin := locked.MemberType == consts.MemberTypeAdmin && locked.Status == consts.StatusEnabled
  56. willBeActiveAdmin := nextType == consts.MemberTypeAdmin && nextStatus == consts.StatusEnabled
  57. if wasActiveAdmin && !willBeActiveAdmin {
  58. adminCount, err := l.svcCtx.SysProductMemberModel.CountActiveAdminsTx(ctx, session, member.ProductCode)
  59. if err != nil {
  60. return err
  61. }
  62. if adminCount <= 1 {
  63. return response.ErrBadRequest("不能降级或禁用该产品的最后一个管理员")
  64. }
  65. }
  66. locked.MemberType = nextType
  67. locked.Status = nextStatus
  68. locked.UpdateTime = time.Now().Unix()
  69. return l.svcCtx.SysProductMemberModel.UpdateWithTx(ctx, session, locked)
  70. }); err != nil {
  71. return err
  72. }
  73. l.svcCtx.UserDetailsLoader.Del(l.ctx, member.UserId, member.ProductCode)
  74. return nil
  75. }