Files
juwan-backend/app/player/rpc/internal/logic/getPlayerByUserIdLogic.go
T
2026-04-04 03:49:34 +08:00

64 lines
1.7 KiB
Go

package logic
import (
"context"
"errors"
"juwan-backend/app/player/rpc/internal/models"
"juwan-backend/app/player/rpc/internal/models/players"
"juwan-backend/app/player/rpc/internal/svc"
"juwan-backend/app/player/rpc/pb"
"github.com/zeromicro/go-zero/core/logx"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"
)
type GetPlayerByUserIdLogic struct {
ctx context.Context
svcCtx *svc.ServiceContext
logx.Logger
}
func NewGetPlayerByUserIdLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetPlayerByUserIdLogic {
return &GetPlayerByUserIdLogic{
ctx: ctx,
svcCtx: svcCtx,
Logger: logx.WithContext(ctx),
}
}
func (l *GetPlayerByUserIdLogic) GetPlayerByUserId(in *pb.SearchPlayersReq) (*pb.GetPlayersByIdResp, error) {
if in.UserId == nil {
return nil, errors.New("user id is required")
}
player, err := l.svcCtx.PlayerModelRO.Players.Query().Where(players.UserIDEQ(in.GetUserId())).First(l.ctx)
if err != nil {
if models.IsNotFound(err) {
return nil, status.Error(codes.NotFound, "player not found")
}
logx.WithContext(l.ctx).Errorf("GetPlayerByUserIdLogic err: %v", err)
return nil, errors.New("get player by user id failed")
}
pbPlayer := pb.Players{
Id: player.ID,
UserId: player.UserID,
Status: player.Status,
Gender: player.Gender,
Rating: player.Rating.InexactFloat64(),
TotalOrders: int64(player.TotalOrders),
CompletedOrders: int64(player.CompletedOrders),
Tags: player.Tags,
Games: []int64(player.Games),
CreatedAt: player.CreatedAt.Unix(),
UpdatedAt: player.UpdatedAt.Unix(),
}
if player.ShopID != nil {
pbPlayer.ShopId = *player.ShopID
}
return &pb.GetPlayersByIdResp{Players: &pbPlayer}, nil
}