userDetailLogic.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package user
  2. import (
  3. "context"
  4. "perms-system-server/internal/middleware"
  5. "perms-system-server/internal/response"
  6. "perms-system-server/internal/svc"
  7. "perms-system-server/internal/types"
  8. "github.com/zeromicro/go-zero/core/logx"
  9. )
  10. type UserDetailLogic struct {
  11. logx.Logger
  12. ctx context.Context
  13. svcCtx *svc.ServiceContext
  14. }
  15. func NewUserDetailLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UserDetailLogic {
  16. return &UserDetailLogic{
  17. Logger: logx.WithContext(ctx),
  18. ctx: ctx,
  19. svcCtx: svcCtx,
  20. }
  21. }
  22. // UserDetail 用户详情。查询指定用户的基本信息和当前产品下的角色绑定。产品成员只能查看同产品下用户,超管可查看任意用户。
  23. func (l *UserDetailLogic) UserDetail(req *types.UserDetailReq) (resp *types.UserItem, err error) {
  24. caller := middleware.GetUserDetails(l.ctx)
  25. if caller == nil {
  26. return nil, response.ErrUnauthorized("未登录")
  27. }
  28. if !caller.IsSuperAdmin {
  29. if caller.ProductCode == "" {
  30. return nil, response.ErrForbidden("会话缺少产品上下文")
  31. }
  32. if _, err := l.svcCtx.SysProductMemberModel.FindOneByProductCodeUserId(l.ctx, caller.ProductCode, req.Id); err != nil {
  33. return nil, response.ErrForbidden("无权查看非本产品成员的用户信息")
  34. }
  35. }
  36. user, err := l.svcCtx.SysUserModel.FindOne(l.ctx, req.Id)
  37. if err != nil {
  38. return nil, response.ErrNotFound("用户不存在")
  39. }
  40. productCode := middleware.GetProductCode(l.ctx)
  41. if caller.IsSuperAdmin {
  42. productCode = req.ProductCode
  43. }
  44. var roleIds []int64
  45. if productCode != "" {
  46. roleIds, err = l.svcCtx.SysUserRoleModel.FindRoleIdsByUserIdForProduct(l.ctx, user.Id, productCode)
  47. } else {
  48. roleIds, err = l.svcCtx.SysUserRoleModel.FindRoleIdsByUserId(l.ctx, user.Id)
  49. }
  50. if err != nil {
  51. return nil, err
  52. }
  53. avatar := ""
  54. if user.Avatar.Valid {
  55. avatar = user.Avatar.String
  56. }
  57. // 审计 M-R16-1:与 UserList 同口径——只在 SuperAdmin / 产品 ADMIN / 产品 DEVELOPER / caller 本人
  58. // 才回填 email/phone/remark;普通 MEMBER 看他人时三个 PII 字段置空,避免全员通讯录外泄。
  59. email, phone, remark := maskUserPII(caller, user)
  60. return &types.UserItem{
  61. Id: user.Id,
  62. Username: user.Username,
  63. Nickname: user.Nickname,
  64. Avatar: avatar,
  65. Email: email,
  66. Phone: phone,
  67. Remark: remark,
  68. DeptId: user.DeptId,
  69. Status: user.Status,
  70. RoleIds: roleIds,
  71. CreateTime: user.CreateTime,
  72. }, nil
  73. }