fix: 登录和注册返回完整用户信息
This commit is contained in:
@@ -7,11 +7,14 @@ import (
|
||||
"context"
|
||||
"errors"
|
||||
"juwan-backend/app/users/rpc/usercenter"
|
||||
"time"
|
||||
|
||||
"juwan-backend/app/users/api/internal/svc"
|
||||
"juwan-backend/app/users/api/internal/types"
|
||||
|
||||
"github.com/jinzhu/copier"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"k8s.io/apimachinery/pkg/util/json"
|
||||
)
|
||||
|
||||
type LoginLogic struct {
|
||||
@@ -50,7 +53,29 @@ func (l *LoginLogic) Login(req *types.LoginReq) (*types.LoginResp, string, error
|
||||
return nil, "", errors.New("login fail")
|
||||
}
|
||||
|
||||
userResp, err := l.svcCtx.UserRpc.GetUsersById(l.ctx, &usercenter.GetUsersByIdReq{Id: res.Id})
|
||||
if err != nil {
|
||||
logx.Errorf("GetUsersById err: %v", err)
|
||||
return nil, "", errors.New("get user failed")
|
||||
}
|
||||
|
||||
user := &types.User{}
|
||||
err = copier.Copy(user, userResp.Users)
|
||||
if err != nil {
|
||||
logx.Errorf("copier.Copy err: %v", err)
|
||||
return nil, "", errors.New("copy user failed")
|
||||
}
|
||||
var verificationStatus map[string]string
|
||||
err = json.Unmarshal([]byte(userResp.Users.VerificationStatus), &verificationStatus)
|
||||
if err != nil {
|
||||
logx.Errorf("json.Unmarshal err: %v", err)
|
||||
}
|
||||
user.VerifiedRoles = userResp.Users.VerifiedRoles
|
||||
user.VerificationStatus = verificationStatus
|
||||
user.Role = userResp.Users.CurrentRole
|
||||
user.CreatedAt = time.Unix(userResp.Users.CreatedAt, 0).Format(time.DateTime)
|
||||
|
||||
return &types.LoginResp{
|
||||
User: types.User{},
|
||||
User: *user,
|
||||
}, res.Token, nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user