Sylius contains a very flexible payments management system with support for many gateways (payment providers). We are using a payment abstraction library - Payum, which handles all sorts of capturing, refunding and recurring payments logic.
On Sylius side, we integrate it into our checkout and manage all the payment data.
Every payment in Sylius, successful or failed, is represented by the Payment model, which contains basic information and a reference to appropriate order.
Payment State Machine¶
A Payment that is assigned to an order will have it’s own state machine with a few available states:
The available transitions between these states are:
transitions: create: from: [cart] to: new process: from: [new] to: processing complete: from: [new, processing] to: completed fail: from: [new, processing] to: failed cancel: from: [new, processing] to: cancelled refund: from: [completed] to: refunded
Of course, you can define your own states and transitions to create a workflow, that perfectly matches your needs. Full configuration can be seen in the PaymentBundle/Resources/config/app/state_machine.yml.
Changes to payment happen through applying appropriate transitions.
How to create a Payment programmatically?¶
We cannot create a Payment without an Order, therefore let’s assume that you have an Order to which you will assign a new payment.
$payment = $this->container->get('sylius.factory.payment')->createNew(); $payment->setOrder($order); $payment->setCurrencyCode('USD'); $this->container->get('sylius.repository.payment')->add($payment);
Not familiar with the Order concept? Check here.
A PaymentMethod represents a way that your customer pays during the checkout process.
It holds a reference to a specific
gateway with custom configuration.
Gateway is configured for each payment method separately using the payment method form.
How to create a PaymentMethod programmatically?¶
As usually, use a factory to create a new PaymentMethod and give it a unique code.
$paymentMethod = $this->container->get('sylius.factory.payment_method')->createWithGateway('offline'); $paymentMethod->setCode('ALFA1'); $this->container->get('sylius.repository.payment_method')->add($paymentMethod);
In order to have your new payment method available in the checkout remember to add it to your desired channels:
Payment Gateway configuration¶
Payment Gateways that already have a Sylius bridge¶
Then you should register its configuration form type with
After that it will be available in the Admin panel in the gateway choice dropdown.
If you are not sure how your configuration form type should look like, head to Payum documentation.
Other Payment Gateways¶
Learn more about integrating payment gateways in the Payum docs.
When the Payment Gateway you are trying to use does have a bridge available and you integrate them on your own, use our guide on extension development.
You’ll probably need also this kind of configuration in your
app/config/config.yml for the gateway’s factory:
payum: gateways: yourgateway: factory: yourgateway
Sylius stores the payment output inside the details column of the sylius_payment table. It can provide valuable information when debugging the payment process.
PayPal Error Code 10409¶
The 10409 code, also known as the “Checkout token was issued for a merchant account other than yours” error.
You have most likely changed the PayPal credentials from
config.yml during the checkout process. Clear the cache and try again:
Payment complete events¶
There are two events that are triggered on the payment complete action: