The connector does not manage the payment flows on your Marketplace. To process transactions such as authorisations, captures, or refunds for your sellers, you must implement payment flows yourself. For more information, see Process payments for marketplaces.
Although the connector does not manage these flows, there are things you must keep in mind when processing transactions while being integrated with Adyen's Mirakl connector.
To keep the connector synchronized, you must perform captures and refunds only from Mirakl. If you perform any operations outside Mirakl, you must manually adjust balances in Mirakl.
Supported payment methods
You can enable your users to accept online payments using all payment methods supported for marketplaces.
Before you can use new payment methods, you need to request them for your merchant account.
Payments
When processing a payment, you can split the funds between any number of balance accounts in your platform, including your liable balance account. You can send the data to split the payment in your payment request or in your capture request. Note that you can only split at capture for payment methods that support separate captures.
The connector populates the custom fields you added to Mirakl when performing the synchronizations you set up. After a shopper places an order, it results in a pending debit. You resolve pending debits by processing the payments.
To process payments:
- Use Mirakl's PA11 API to get a list of pending debits.
- Make a request to the Mirakl S20 API to get the seller information, including the
adyen-v2-account-holder-id
andadyen-v2-balance-account-id
.
These values inform you of the account that is linked to a debit request.The Mirakl S20 API has a rate limit, therefore, we do not recommend making requests for each transaction. You can keep a local mapping of the Adyen account IDs and Mirakl shop IDs.
-
Make a /payments or /payments/{paymentPspReference}/captures request:
-
In the body, include the applicationInfo and splits arrays.
For applicationInfo, specify the following fields:Parameter Required Description externalPlatform
Details of the Mirakl Connector v2. merchantApplication
Your own details, refer to Application Information for information on how to fill this field. adyenLibrary
Only if you are using an Adyen Library, the name and the version of the library you are using. For splits, specify the following fields:
- If a shopper orders from multiple sellers in the same transaction, the splits array needs to indicate the split of funds between all sellers on that transaction.
Parameter Required Description account
Adyen Balance account ID. Get it from your Balance Platform Customer Area > Accounts & balances > Balance accounts. type
BalanceAccount.
If you want to usetype
: PaymentFee in your request, contact Adyen. This type reduces the seller's available balance and increases failure rates for initial payouts that you must then correct with retrials. We recommend to increase the default value from 10 retries to a value that is suitable for your platform.amount.value
The split amount, in minor units. reference
Your unique identifier for the specific transaction split.
-
# Set your X-API-KEY with the API key from the Customer Area. curl https://checkout-test.adyen.com/v71/payments \ -H 'x-api-key: YOUR_X-API-KEY' \ -H 'content-type: application/json' \ -d '{ "applicationInfo": [ "externalPlatform": { "integrator": "Mirakl Connector v2", "name" : "Mirakl", "version": "2.0" }, "merchantApplication": { "name": "Best Ecom", "version": "2.0" }, "adyenLibrary": { "name": "adyen-java-api-library", "version" : "18.0.0" } ], "paymentMethod": { "type": "scheme", "number": "4111111111111111", "cvc": "737", "expiryMonth": "03", "expiryYear": "2030", "holderName": "John Smith" }, "amount": { "value": 4000, "currency": "EUR" }, "reference": "YOUR_ORDER_NUMBER", "merchantAccount": "YOUR_MERCHANT_ACCOUNT", "returnUrl": "https://your-company.com/...", "splits":[ { "amount": { "value": 4000 }, "type": "BalanceAccount", "account": "BA00000000000000000000001", "reference": "YOUR_REFERENCE", }, ] }'
Captures
Webhooks
Learn more about webhooks.
When we have processed your capture request, we send you a CAPTURE webhook.
In rare cases, a capture can fail even after you received a successful CAPTURE webhook. You then receive a CAPTURE_FAILED webhook.
We recommend to implement delay of 15 minutes in your order management process before the order status is modified in Mirakl after you receive a CAPTURE webhook. This is to prevent modifying the order status to soon, in case you receive a CAPTURE_FAILED webhook later, because Mirakl does not allow to revert order statuses.
Refunds
In Mirakl, both the marketplace operator and sellers can issue refunds. To learn more about when and how refunds can be issued, refer to Mirakl documentation.
Refunds are calculated as a part of the billing cycle. Seller balances are adjusted to reflect the net balance in the next billing cycle after a refund takes place.
After a refund is initiated in Mirakl, you can process and split the refund amount between the balance accounts in your platform.
When we have processed your refund request, we send you a REFUND webhook.
In rare cases, a refund can fail even after you received a successful REFUND webhook. You then receive a REFUND_FAILED webhook.
We recommend to implement delay of 15 minutes in your order management process before the order status is modified in Mirakl after you receive a REFUND webhook. This is to prevent modifying the order status to soon, in case you receive a REFUND webhook later, because Mirakl does not allow to revert order statuses.
Chargebacks
When a chargeback occurs in your marketplace, you can choose to book the disputed amount:
- Entirely to your liable balance account
- According to the original split ratio of the payment
Refer to Chargeback and disputes for more information on how to configure chargebacks.