Files
juwan-backend/app/order/rpc/internal/logic/updateOrderStateLogsLogic.go
T
wwweww 19cc7a778c Refactor: Remove deprecated gRPC service files and implement new API structure
- 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`.
2026-02-28 18:35:56 +08:00

69 lines
1.6 KiB
Go

package logic
import (
"context"
"errors"
"juwan-backend/app/order/rpc/internal/models"
"juwan-backend/app/order/rpc/internal/svc"
"juwan-backend/app/order/rpc/pb"
"github.com/zeromicro/go-zero/core/logx"
)
type UpdateOrderStateLogsLogic struct {
ctx context.Context
svcCtx *svc.ServiceContext
logx.Logger
}
func NewUpdateOrderStateLogsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateOrderStateLogsLogic {
return &UpdateOrderStateLogsLogic{
ctx: ctx,
svcCtx: svcCtx,
Logger: logx.WithContext(ctx),
}
}
func (l *UpdateOrderStateLogsLogic) UpdateOrderStateLogs(in *pb.UpdateOrderStateLogsReq) (*pb.UpdateOrderStateLogsResp, error) {
if in == nil {
return nil, errors.New("order state log is required")
}
builder := l.svcCtx.OrderModelsRW.OrderStateLogs.UpdateOneID(in.Id)
if in.OrderId != nil {
builder = builder.SetOrderID(*in.OrderId)
}
if in.FromStatus != nil {
builder = builder.SetFromStatus(*in.FromStatus)
}
if in.ToStatus != nil {
builder = builder.SetToStatus(*in.ToStatus)
}
if in.Action != nil {
builder = builder.SetAction(*in.Action)
}
if in.ActorId != nil {
builder = builder.SetActorID(*in.ActorId)
}
if in.ActorRole != nil {
builder = builder.SetActorRole(*in.ActorRole)
}
if in.Metadata != nil {
metadata, err := parseJSONMap(*in.Metadata)
if err != nil {
return nil, err
}
builder = builder.SetMetadata(metadata)
}
if _, err := builder.Save(l.ctx); err != nil {
if models.IsNotFound(err) {
return nil, errors.New("order state log not found")
}
return nil, err
}
return &pb.UpdateOrderStateLogsResp{}, nil
}