Payment-method icon

ANCV for API only

Add ANCV to an existing API-only integration.

Accept ANCV payments using our APIs, and build your own payment form to have full control over the look and feel of your checkout page.

Requirements

Requirement Description
Integration type Make sure that you have built an API-only integration.
Setup steps Before you begin, add ANCV in your test Customer Area.

Build your payment form for ANCV

Include ANCV as an available payment method in your payment form.

Use the /paymentMethods request to show available payment methods to the shopper. Specify these parameters:

  • countryCode: FR
  • amount.currency: EUR

The response contains paymentMethod.type: ancv.

We provide a logo for ANCV which you can use on your payment form. For more information, refer to Downloading logos.

Make a payment

When a shopper chooses to pay with ANCV, you need to collect the shopper's ANCV ID and wait for the payment outcome on your website.

In your /payments request, specify:

  • paymentMethod.type: ancv
  • paymentMethod.beneficiaryId: string - This is the ANCV ID of the shopper collected during the checkout (either email address or 11-digit value).
Example /payments request
Expand view
Copy link to code block
Copy code
Copy code
{
"amount": {
"currency": "EUR",
"value": 3000
},
"reference": "YOUR_MERCHANT_REFERENCE",
"paymentMethod": {
"type": "ancv",
"beneficiaryId": "SHOPPER_ID"
},
"shopperInteraction": "Ecommerce",
"merchantAccount": "YOUR_MERCHANT_ACCOUNT",
"order": {
"pspReference": "MLSPNCQ8HXSKGK82",
"orderData": "823fh892f8f18f4...148f13f9f3f"
}
}

The response contains:

  • resultCode: Pending - the shopper still needs to complete the payment in the ANCV app
  • order.orderData - ignore this value and take the order.orderData from the /payments/details response
  • action.paymentData - payload required as an input for /payments/details request in order to learn about the payment status
Example /payments response
Expand view
Copy link to code block
Copy code
Copy code
{
"pspReference": "JF89C8JSHVTFWR82",
"resultCode": "Pending",
"order": {
"amount": {
"currency": "EUR",
"value": 3000
},
"expiresAt": "2023-09-15T13:35:33Z",
"orderData": "111aa111a1a11a1...123a11a1a1a",
"pspReference": "MLSPNCQ8HXSKGK82"
},
"action": {
"paymentData": "Ab02b...",
"paymentMethodType": "ancv",
"type": "await"
}
}

Show the waiting screen

  1. Show a waiting screen to the shopper, telling them you are waiting for them to complete the payment.
  2. Once the shopper completes the payment, present the payment result.

Get outcome

To see the payment result, send a request to /payments/details that includes the paymentData provided in the /payments response.

Example /payments/details request
Expand view
Copy link to code block
Copy code
Copy code
curl https://checkout-test.adyen.com/v70/payments/details \
-H 'x-API-key: YOUR_X-API-KEY' \
-H 'content-type: application/json' \
-d '{
"details": {
"paymentData": "Ab02b..."
}
}

The response for when the amount authorised is less than the amount requested:

Example 1 of /payments/details response
Expand view
Copy link to code block
Copy code
Copy code
{
"additionalData": {
"authorisedAmountCurrency": "EUR",
"authorisedAmountValue": "2400"
},
"pspReference": "Q7R7LVQPS8NKGK82",
"resultCode": "PartiallyAuthorised",
"order": {
"amount": {
"currency": "EUR",
"value": 2500
},
"expiresAt": "2023-09-15T13:35:33Z",
"orderData": "111aa111a1a11a1...123a11a1a1a",
"pspReference": "MLSPNCQ8HXSKGK82"
"reference": "YOUR_ORDER_REFERENCE",
"remainingAmount": {
"currency": "EUR",
"value": 100
}
},
"merchantReference": "merchantReference"
}

The response for when the amount authorised is equal to amount requested:

Example 2 of /payments/details response
Expand view
Copy link to code block
Copy code
Copy code
{
"pspReference": "RQWVG8TD4MBX8N82",
"resultCode": "Authorised",
"order": {
"amount": {
"currency": "EUR",
"value": 2500
},
"expiresAt": "2023-09-15T13:35:33Z",
"orderData": "111aa111a1a11a1...123a11a1a1a",
"pspReference": "MLSPNCQ8HXSKGK82",
"reference": "YOUR_PAYMENT_REFERENCE",
"remainingAmount": {
"currency": "EUR",
"value": 0
}
},
"merchantReference": "merchantReference",
"paymentMethod": {
"type": "ancv"
}
}



You will receive an AUTHORISATION webhook after the shopper completes the payment in their ANCV app:

Example AUTHORIZATION webhook
Expand view
Copy link to code block
Copy code
Copy code
{
"live": "false",
"notificationItems": [
{
"NotificationRequestItem": {
"amount": {
"value": 3000,
"currency": "EUR"
},
"reason": "null",
"success": "true",
"eventCode": "AUTHORISATION",
"eventDate": "2023-09-14T15:35:58+02:00",
"pspReference": "JF89C8JSHVTFWR82",
"paymentMethod": "ancv",
"additionalData": {
"hmacSignature": "NugWLawWaf/0FsVy17G/IaEfOhaz4GShU+hnD6tfQs0=",
"merchantOrderReference": "YOUR_ORDER_REFERENCE"
},
"merchantReference": "YOUR_MERCHANT_REFERENCE",
"merchantAccountCode": "YOUR_MERCHANT_ACCOUNT"
}
}
]
}


With partial authorisation the possibility exists that if the amount authorised by the shopper is less than the amount requested by the merchant, only the requested amount displays in Customer Area. However, the correct authorised amount reflects in the /payments/details response and the AUTHORISATION webhook notification. In both the /payments/details response and the AUTHORISATION webhook, you will receive the authorised amount in additionalData.authorisedAmountValue.

Example AUTHORIZATION webhook for partial authorization
Expand view
Copy link to code block
Copy code
Copy code
{
"live": "false",
"notificationItems": [
{
"NotificationRequestItem": {
"amount": {
"value": 3000,
"currency": "EUR"
},
"reason": "null",
"success": "true",
"eventCode": "AUTHORISATION",
"eventDate": "2023-09-14T15:35:58+02:00",
"pspReference": "JF89C8JSHVTFWR82",
"paymentMethod": "ancv",
"additionalData": {
"hmacSignature": "NugWLawWaf/0FsVy17G/IaEfOhaz4GShU+hnD6tfQs0=",
"merchantOrderReference": "YOUR_ORDER_REFERENCE"
"authorisedAmountValue": "2500",
"authorisedAmountCurrency": "EUR"
},
"merchantReference": "YOUR_MERCHANT_REFERENCE",
"merchantAccountCode": "YOUR_MERCHANT_ACCOUNT"
}
}
]
}

Test and go live

  1. Test your integration end-to-end with the ANCV test app. Instructions on how to download, install and onboard ANCV users, as well as the required test credentials, are shared by ANCV directly with the merchant.
  2. Make sure to test ANCV payments with partial payments.
  3. Add ANCV in your live Customer Area and provide the Merchant ID (shopID in ANCV vocabulary), as received from ANCV.

See also