server/internal/logic/admin/order/createOrderLogic.go
Chang lue Tsen 8addcc584b init: 1.0.0
2025-04-25 12:08:29 +09:00

60 lines
1.8 KiB
Go

package order
import (
"context"
"github.com/perfect-panel/ppanel-server/internal/model/order"
"github.com/perfect-panel/ppanel-server/internal/svc"
"github.com/perfect-panel/ppanel-server/internal/types"
"github.com/perfect-panel/ppanel-server/pkg/logger"
"github.com/perfect-panel/ppanel-server/pkg/tool"
"github.com/perfect-panel/ppanel-server/pkg/xerr"
"github.com/pkg/errors"
)
type CreateOrderLogic struct {
logger.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
// Create order
func NewCreateOrderLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateOrderLogic {
return &CreateOrderLogic{
Logger: logger.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
func (l *CreateOrderLogic) CreateOrder(req *types.CreateOrderRequest) error {
paymentMethod, err := l.svcCtx.PaymentModel.FindOne(l.ctx, req.PaymentId)
if err != nil {
l.Logger.Error("[CreateOrder] PaymentMethod Not Found", logger.Field("error", err.Error()))
return errors.Wrapf(xerr.NewErrCode(xerr.PaymentMethodNotFound), "PaymentMethod not found: %v", err.Error())
}
err = l.svcCtx.OrderModel.Insert(l.ctx, &order.Order{
UserId: req.UserId,
OrderNo: tool.GenerateTradeNo(),
Type: req.Type,
Quantity: req.Quantity,
Price: req.Price,
Amount: req.Amount,
Discount: req.Discount,
Coupon: req.Coupon,
CouponDiscount: req.CouponDiscount,
PaymentId: req.PaymentId,
Method: paymentMethod.Token,
FeeAmount: req.FeeAmount,
TradeNo: req.TradeNo,
Status: req.Status,
SubscribeId: req.SubscribeId,
})
if err != nil {
l.Logger.Error("[CreateOrder] Database Error", logger.Field("error", err.Error()))
return errors.Wrapf(xerr.NewErrCode(xerr.DatabaseInsertError), "Insert error: %v", err.Error())
}
return nil
}