19cc7a778c
- Deleted old gRPC service definitions in `game_grpc.pb.go` and `public.go`. - Added new API server implementations for objectstory, player, and shop services. - Introduced configuration files for new APIs in `etc/*.yaml`. - Created main entry points for each service in `objectstory.go`, `player.go`, and `shop.go`. - Removed unused user update handler and user API files. - Added utility functions for context management and HTTP header parsing. - Introduced PostgreSQL backup configuration in `backup/postgreSql.yaml`.
81 lines
2.2 KiB
Go
81 lines
2.2 KiB
Go
package logic
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"time"
|
|
|
|
"juwan-backend/app/order/rpc/internal/models/orderstatelogs"
|
|
"juwan-backend/app/order/rpc/internal/models/predicate"
|
|
"juwan-backend/app/order/rpc/internal/svc"
|
|
"juwan-backend/app/order/rpc/pb"
|
|
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
)
|
|
|
|
type SearchOrderStateLogsLogic struct {
|
|
ctx context.Context
|
|
svcCtx *svc.ServiceContext
|
|
logx.Logger
|
|
}
|
|
|
|
func NewSearchOrderStateLogsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SearchOrderStateLogsLogic {
|
|
return &SearchOrderStateLogsLogic{
|
|
ctx: ctx,
|
|
svcCtx: svcCtx,
|
|
Logger: logx.WithContext(ctx),
|
|
}
|
|
}
|
|
|
|
func (l *SearchOrderStateLogsLogic) SearchOrderStateLogs(in *pb.SearchOrderStateLogsReq) (*pb.SearchOrderStateLogsResp, error) {
|
|
if in.Limit <= 0 {
|
|
in.Limit = 20
|
|
}
|
|
if in.Limit > 1000 {
|
|
return nil, errors.New("limit too large")
|
|
}
|
|
|
|
preds := make([]predicate.OrderStateLogs, 0, 8)
|
|
if in.Id != nil {
|
|
preds = append(preds, orderstatelogs.IDEQ(*in.Id))
|
|
}
|
|
if in.OrderId != nil {
|
|
preds = append(preds, orderstatelogs.OrderIDEQ(*in.OrderId))
|
|
}
|
|
if in.FromStatus != nil && *in.FromStatus != "" {
|
|
preds = append(preds, orderstatelogs.FromStatusEQ(*in.FromStatus))
|
|
}
|
|
if in.ToStatus != nil && *in.ToStatus != "" {
|
|
preds = append(preds, orderstatelogs.ToStatusEQ(*in.ToStatus))
|
|
}
|
|
if in.Action != nil && *in.Action != "" {
|
|
preds = append(preds, orderstatelogs.ActionContainsFold(*in.Action))
|
|
}
|
|
if in.ActorId != nil {
|
|
preds = append(preds, orderstatelogs.ActorIDEQ(*in.ActorId))
|
|
}
|
|
if in.ActorRole != nil && *in.ActorRole != "" {
|
|
preds = append(preds, orderstatelogs.ActorRoleContainsFold(*in.ActorRole))
|
|
}
|
|
if in.CreatedAt != nil && *in.CreatedAt > 0 {
|
|
preds = append(preds, orderstatelogs.CreatedAtGTE(time.Unix(*in.CreatedAt, 0)))
|
|
}
|
|
|
|
query := l.svcCtx.OrderModelsRO.OrderStateLogs.Query()
|
|
if len(preds) > 0 {
|
|
query = query.Where(orderstatelogs.And(preds...))
|
|
}
|
|
|
|
items, err := query.Offset(int(in.Page * in.Limit)).Limit(int(in.Limit)).All(l.ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
result := make([]*pb.OrderStateLogs, 0, len(items))
|
|
for _, item := range items {
|
|
result = append(result, toPBOrderStateLog(item))
|
|
}
|
|
|
|
return &pb.SearchOrderStateLogsResp{OrderStateLogs: result}, nil
|
|
}
|