removeMemberLogic.go 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package member
  2. import (
  3. "context"
  4. "perms-system-server/internal/consts"
  5. authHelper "perms-system-server/internal/logic/auth"
  6. "perms-system-server/internal/response"
  7. "perms-system-server/internal/svc"
  8. "perms-system-server/internal/types"
  9. "github.com/zeromicro/go-zero/core/logx"
  10. "github.com/zeromicro/go-zero/core/stores/sqlx"
  11. )
  12. type RemoveMemberLogic struct {
  13. logx.Logger
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. }
  17. func NewRemoveMemberLogic(ctx context.Context, svcCtx *svc.ServiceContext) *RemoveMemberLogic {
  18. return &RemoveMemberLogic{
  19. Logger: logx.WithContext(ctx),
  20. ctx: ctx,
  21. svcCtx: svcCtx,
  22. }
  23. }
  24. // RemoveMember 移除产品成员。在事务内同时清理该用户在产品下的角色和个性化权限绑定后移除成员记录。不能移除产品的最后一个 ADMIN。
  25. func (l *RemoveMemberLogic) RemoveMember(req *types.RemoveMemberReq) error {
  26. member, err := l.svcCtx.SysProductMemberModel.FindOne(l.ctx, req.Id)
  27. if err != nil {
  28. return response.ErrNotFound("成员不存在")
  29. }
  30. if err := authHelper.CheckManageAccess(l.ctx, l.svcCtx, member.UserId, member.ProductCode); err != nil {
  31. return err
  32. }
  33. if err := l.svcCtx.SysProductMemberModel.TransactCtx(l.ctx, func(ctx context.Context, session sqlx.Session) error {
  34. locked, err := l.svcCtx.SysProductMemberModel.FindOneForUpdateTx(ctx, session, req.Id)
  35. if err != nil {
  36. return response.ErrNotFound("成员不存在")
  37. }
  38. if locked.MemberType == consts.MemberTypeAdmin && locked.Status == consts.StatusEnabled {
  39. // 使用 CountOtherActiveAdminsTx 排除目标自己,返回 0 即目标为最后一个 active admin,
  40. // 不再依赖"count<=1 包含自己"的反向推理(见审计 L-5)。
  41. otherAdminCount, err := l.svcCtx.SysProductMemberModel.CountOtherActiveAdminsTx(ctx, session, member.ProductCode, locked.Id)
  42. if err != nil {
  43. return err
  44. }
  45. if otherAdminCount == 0 {
  46. return response.ErrBadRequest("不能移除该产品的最后一个管理员")
  47. }
  48. }
  49. if err := l.svcCtx.SysUserRoleModel.DeleteByUserIdForProductTx(ctx, session, member.UserId, member.ProductCode); err != nil {
  50. return err
  51. }
  52. if err := l.svcCtx.SysUserPermModel.DeleteByUserIdForProductTx(ctx, session, member.UserId, member.ProductCode); err != nil {
  53. return err
  54. }
  55. return l.svcCtx.SysProductMemberModel.DeleteWithTx(ctx, session, req.Id)
  56. }); err != nil {
  57. return err
  58. }
  59. l.svcCtx.UserDetailsLoader.Del(l.ctx, member.UserId, member.ProductCode)
  60. return nil
  61. }