Documentation ¶
Index ¶
- Constants
- type OrderService
- func (os *OrderService) CancelOrder(ctx context.Context, session *web.Session, order *PlaceOrderInfo) (*cart.Cart, error)
- func (os *OrderService) CancelOrderWithoutRestore(ctx context.Context, session *web.Session, order *PlaceOrderInfo) error
- func (os *OrderService) CartPlaceOrder(ctx context.Context, decoratedCart *decorator.DecoratedCart, ...) (*PlaceOrderInfo, error)
- func (os *OrderService) CartPlaceOrderWithPaymentProcessing(ctx context.Context, decoratedCart *decorator.DecoratedCart, ...) (*PlaceOrderInfo, error)
- func (os *OrderService) ClearLastPlacedOrder(ctx context.Context)
- func (os *OrderService) CurrentCartPlaceOrder(ctx context.Context, session *web.Session, cartPayment placeorder.Payment) (*PlaceOrderInfo, error)
- func (os *OrderService) CurrentCartPlaceOrderWithPaymentProcessing(ctx context.Context, session *web.Session) (*PlaceOrderInfo, error)
- func (os *OrderService) CurrentCartSaveInfos(ctx context.Context, session *web.Session, billingAddress *cart.Address, ...) error
- func (os *OrderService) GetAvailablePaymentGateways(_ context.Context) map[string]interfaces.WebCartPaymentGateway
- func (os *OrderService) GetPaymentGateway(_ context.Context, paymentGatewayCode string) (interfaces.WebCartPaymentGateway, error)
- func (os *OrderService) HasLastPlacedOrder(ctx context.Context) bool
- func (os *OrderService) Inject(SourcingEngine *domain.SourcingEngine, logger flamingo.Logger, ...)
- func (os *OrderService) LastPlacedOrCurrentCart(ctx context.Context) (*decorator.DecoratedCart, error)
- func (os *OrderService) LastPlacedOrder(ctx context.Context) (*PlaceOrderInfo, error)
- func (os *OrderService) SetSources(ctx context.Context, session *web.Session) error
- type PlaceOrderInfo
- type PlaceOrderPaymentInfo
Constants ¶
const ( // PaymentFlowStandardCorrelationID used as correlationid for the start of the payment (session scoped) PaymentFlowStandardCorrelationID = "checkout" // LastPlacedOrderSessionKey is the session key for storing the last placed order LastPlacedOrderSessionKey = "orderservice_last_placed" )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type OrderService ¶
type OrderService struct {
// contains filtered or unexported fields
}
OrderService defines the order service
func (*OrderService) CancelOrder ¶
func (os *OrderService) CancelOrder(ctx context.Context, session *web.Session, order *PlaceOrderInfo) (*cart.Cart, error)
CancelOrder cancels an previously placed order and returns the restored cart with the order content
func (*OrderService) CancelOrderWithoutRestore ¶ added in v3.1.0
func (os *OrderService) CancelOrderWithoutRestore(ctx context.Context, session *web.Session, order *PlaceOrderInfo) error
CancelOrderWithoutRestore cancels an previously placed order
func (*OrderService) CartPlaceOrder ¶ added in v3.1.0
func (os *OrderService) CartPlaceOrder(ctx context.Context, decoratedCart *decorator.DecoratedCart, payment placeorder.Payment) (*PlaceOrderInfo, error)
CartPlaceOrder places the cart passed to the function this function enables clients to pass a cart as is, without the usage of the cartReceiverService
func (*OrderService) CartPlaceOrderWithPaymentProcessing ¶
func (os *OrderService) CartPlaceOrderWithPaymentProcessing(ctx context.Context, decoratedCart *decorator.DecoratedCart, session *web.Session) (*PlaceOrderInfo, error)
CartPlaceOrderWithPaymentProcessing places the cart passed to the function this function enables clients to pass a cart as is, without the usage of the cartReceiverService
func (*OrderService) ClearLastPlacedOrder ¶
func (os *OrderService) ClearLastPlacedOrder(ctx context.Context)
ClearLastPlacedOrder clears the last placed cart, this can be useful if an cart / order is finished
func (*OrderService) CurrentCartPlaceOrder ¶
func (os *OrderService) CurrentCartPlaceOrder(ctx context.Context, session *web.Session, cartPayment placeorder.Payment) (*PlaceOrderInfo, error)
CurrentCartPlaceOrder places the current cart without additional payment processing
func (*OrderService) CurrentCartPlaceOrderWithPaymentProcessing ¶
func (os *OrderService) CurrentCartPlaceOrderWithPaymentProcessing(ctx context.Context, session *web.Session) (*PlaceOrderInfo, error)
CurrentCartPlaceOrderWithPaymentProcessing places the current cart which is fetched from the context
func (*OrderService) CurrentCartSaveInfos ¶
func (os *OrderService) CurrentCartSaveInfos(ctx context.Context, session *web.Session, billingAddress *cart.Address, shippingAddress *cart.Address, purchaser *cart.Person, additionalData *cart.AdditionalData) error
CurrentCartSaveInfos saves additional information on current cart Deprecated: method is not called within flamingo-commerce and method does not support multiple delivery addresses
func (*OrderService) GetAvailablePaymentGateways ¶
func (os *OrderService) GetAvailablePaymentGateways(_ context.Context) map[string]interfaces.WebCartPaymentGateway
GetAvailablePaymentGateways returns the list of registered WebCartPaymentGateway
func (*OrderService) GetPaymentGateway ¶
func (os *OrderService) GetPaymentGateway(_ context.Context, paymentGatewayCode string) (interfaces.WebCartPaymentGateway, error)
GetPaymentGateway tries to get the supplied payment gateway by code from the registered payment gateways
func (*OrderService) HasLastPlacedOrder ¶
func (os *OrderService) HasLastPlacedOrder(ctx context.Context) bool
HasLastPlacedOrder returns if a order has been previously placed
func (*OrderService) Inject ¶
func (os *OrderService) Inject( SourcingEngine *domain.SourcingEngine, logger flamingo.Logger, CartService *application.CartService, CartReceiverService *application.CartReceiverService, DeliveryInfoBuilder cart.DeliveryInfoBuilder, webCartPaymentGatewayProvider interfaces.WebCartPaymentGatewayProvider, decoratedCartFactory *decorator.DecoratedCartFactory, cfg *struct { DeprecatedSourcingActive bool `inject:"config:commerce.checkout.activateDeprecatedSourcing,optional"` }, )
Inject dependencies
func (*OrderService) LastPlacedOrCurrentCart ¶
func (os *OrderService) LastPlacedOrCurrentCart(ctx context.Context) (*decorator.DecoratedCart, error)
LastPlacedOrCurrentCart returns the decorated cart of the last placed order if there is one if not return the current cart
func (*OrderService) LastPlacedOrder ¶
func (os *OrderService) LastPlacedOrder(ctx context.Context) (*PlaceOrderInfo, error)
LastPlacedOrder returns the last placed order/cart if available
func (*OrderService) SetSources ¶
SetSources sets sources for sessions carts items Deprecated: Sourcing moved to new module see sourcing module
type PlaceOrderInfo ¶
type PlaceOrderInfo struct { PaymentInfos []PlaceOrderPaymentInfo PlacedOrders placeorder.PlacedOrderInfos ContactEmail string Cart cart.Cart }
PlaceOrderInfo struct defines the data of payments on placed orders
type PlaceOrderPaymentInfo ¶
type PlaceOrderPaymentInfo struct { Gateway string PaymentProvider string Method string CreditCardInfo *placeorder.CreditCardInfo Amount priceDomain.Price Title string }
PlaceOrderPaymentInfo holding payment infos