60 lines
1.8 KiB
Go
60 lines
1.8 KiB
Go
package order
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/perfect-panel/server/internal/model/order"
|
|
"github.com/perfect-panel/server/internal/svc"
|
|
"github.com/perfect-panel/server/internal/types"
|
|
"github.com/perfect-panel/server/pkg/logger"
|
|
"github.com/perfect-panel/server/pkg/tool"
|
|
"github.com/perfect-panel/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
|
|
}
|