When verifying users, the verification checks performed by Adyen can return a range of error messages.
In your test environment, all verification checks are passed by default when the required fields and documents are provided. To test your error handling flow, you can force a scenario where one or more verification checks fail.
This allows you to reproduce an unsuccessful verification flow, including the result and corresponding verification codes. You can then also test the remediating flow to resolve the verification errors.
Requirements
Make sure that you have API credentials for the Legal Entity Management APIand Configuration API.
Step 1: Make an API request
Using the Legal Entity Management API, you can include a x-requested-verification-code in the header of your API request.
Note that requested verification codes cannot be used with hosted onboarding.
You can use requested verification codes for the following endpoints:
Use a suberror code as your requested verification code. You can include one code at a time in your request header. Requested verification codes can only be used in your test environment.
In this example, you want to test the 1_3004
suberror code The name and residence country couldn't be verified
for an individual legal entity. This triggers the following verification checks:
- Name and date of birth check
- Residency country check
In the header of your POST /legalEntities request, include x-requested-verification-code: 1_3004
.
curl https://kyc-test.adyen.com/lem/v3/legalEntities \ -H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \ -H 'content-type: application/json' \ -H 'x-requested-verification-code: 1_3004' \ -X POST \ -d '{ "type": "individual", "individual": { "phone": { "number": "+31612345678", "type": "mobile" }, "birthData": { "dateOfBirth": "1977-01-01" }, "name": { "firstName": "KYC", "lastName": "My Test scenario" }, "nationality": "NL", "residentialAddress": { "city": "Amsterdam", "country": "NL", "postalCode": "1111AB", "street": "Main street" }, "identificationData": { "type": "nationalIdNumber", "number": "12345678", "issuerState": "NL" } } }'
Step 2: Create account holder
For error tests for legal entities, you need to create an account holder for the legal entity of the organization, individual, or sole proprietorship.
For error tests for documents or transfer instruments, you need to create an account holder for the legal entity who owns the resource.
Step 3: Check verification errors
To get updates about the failed verification and the corresponding error codes, you can:
- Listen to the balancePlatform.accountHolder.updated or
- Make a GET API request for the particular legal entity, document, or transfer instrument.
Make a GET /legalEntities/{id} request, specifying the id in the path.
{ "verificationErrors": [ { "code": "1_30", "message": "Individual details couldn't be verified", "remediatingActions": [ { "code": "1_300", "message": "Update individual details" } ], "subErrors": [ { "code": "1_3004", "message": "The name and residence country couldn't be verified", "remediatingActions": [ { "code": "1_305", "message": "Upload a different proof of residency" }, { "code": "1_300", "message": "Update individual details" } ], "type": "invalidInput" } ], "type": "invalidInput" } ] }
{ "data":{ "balancePlatform": "YOUR_BALANCE_PLATFORM", "accountHolder": { "description": "YOUR_DESCRIPTION", "reference": "YOUR_REFERENCE", "legalEntityId": "LE00000000000000000000001", "capabilities": { "sendToTransferInstrument": { "allowed": false, "requested": true, "enabled": true, "problems": [ { "entity": { "id": "LE00000000000000000000001", "type": "LegalEntity" }, "verificationErrors": [ { "code": "1_30", "message": "Individual details couldn't be verified.", "remediatingActions": [ { "code": "1_300", "message": "Update individual details" } ], "subErrors": [ { "code": "1_3004", "message": "The name and residence country couldn't be verified", "remediatingActions": [ { "code": "1_305", "message": "Upload a different proof of residency" }, { "code": "1_300", "message": "Update individual details" } ], "type": "invalidInput" } ] } ] } ], "transferInstruments": [ { "enabled": true, "requested": true, "allowed": false, "id": "SE00000000000000000000001", "verificationStatus": "invalid" } ], "verificationStatus": "invalid" } }, "id": "AH00000000000000000000001", "status": "Active" } }, "environment": "test", "type": "balancePlatform.accountHolder.updated" }
The response returns the specified requested verification code and associated error codes.
Step 4: Test the remediating flow and resolve verification errors
To simulate the resolution of the verification errors, in your test environment, include the x-requested-verification-code: 0_0001
in the header of your API request.
Note that requested verification codes cannot be used with hosted onboarding.
The requested verification code can be used for the following endpoints in the Legal Entity Management API:
If your error handling is successful, the requested verification code resolves any suberrors associated with the legal entity, document, or transfer instrument.
Make a PATCH /legalEntities/{id} request, specifying the id in the path and x-requested-verification-code: 0_0001
in the API header.
curl https://kyc-test.adyen.com/lem/v3/legalEntities/LE00000000000000000000001 \ -H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \ -H 'content-type: application/json' \ -H "x-requested-verification-code: 0_0001" \ -X PATCH \ -d '{ "individual": { "phone": { "number": "+31612345678", "type": "mobile" }, "birthData": { "dateOfBirth": "1977-01-01" }, "name": { "firstName": "KYC", "lastName": "My Test scenario" }, "nationality": "NL", "residentialAddress": { "city": "Amsterdam", "country": "NL", "postalCode": "1111AB", "street": "Main street" }, "identificationData": { "type": "nationalIdNumber", "number": "12345678", "issuerState": "NL" } } }'