Your users must accept Adyen's Terms of Service before they can perform particular actions in your platform. If you build your own UI to collect data to onboard your users, you must generate a Terms of Service document, show the document to your users, and ask them to accept it. If you are using hosted onboarding, your user will complete this step as part of the onboarding process.
The Terms of Service document must be accepted by an individual legal entity that represents a physical person. For organizations, the document must be accepted by an authorized signatory of the organization. For example:
- A cardholder accepts the document on their own behalf.
- The owner of a restaurant accepts the document on behalf of the legal entity that represents the business.
Requirements
Make sure that you have API credentials for the Legal Entity Management API and that you have created legal entities for:
- The user that has a contractual relationship with your platform.
- The individual legal entity who will accept the document.
Step 1: Confirm Terms of Service requirements
When you create an account holder, certain capabilities are requested for them. To check whether your user must accept the Terms of Service, listen to balancePlatform.accountHolder.updated webhooks.
If your user is required to accept Adyen's Terms of Service, it is indicated in the verificationErrors
array.
{ "data":{ "accountHolder":{ "capabilities":{ "sendToTransferInstrument":{ "allowed":"false", "enabled":"true", "problems":[ { "entity":{ "id":"LE00000000000000000000001", "type":"LegalEntity" }, "verificationErrors":[ { "code":"2_902", "message":"Terms Of Service forms are not accepted.", "remediatingActions":[ { "code":"2_902", "message":"Accept TOS" } ], "type":"invalidInput" } ] } ], "requested":"true", "verificationStatus":"invalid" } }, "description":"Test Account holder", "reference":"YOUR_INTERNAL_IDENTIFIER", "id":"AH00000000000000000000001", "legalEntityId":"LE00000000000000000000001", "status":"Active" }, "balancePlatform":"YOUR_BALANCE_PLATFORM" }, "environment":"test", "type":"balancePlatform.accountHolder.updated" }
Step 2: Get the types of Terms of Service required
If your user is required to accept Adyen's Terms of Service, you must determine which types of documents they need to accept. Make a GET /legalEntities/{id}/termsOfServiceStatus request, specifying the id of the main legal entity in the path. For sole proprietorships, this is the individual legal entity ID of the owner.
Note that your user may need to accept more than one Terms of Service document.
In your test environment, only the document type adyenForPlatformsAdvanced
is returned regardless of your actual integration. This is since all accounts use the same default configuration. In your live environment, the actual Terms of Service document types are returned.
{ "termsOfServiceTypes": [ "adyenForPlatformsAdvanced", "adyenCapital", "adyenAccount" ] }
Step 3: Generate the Terms of Service documents
To generate the Terms of Service documents, make a POST /legalEntities/{id}/termsOfService request, specifying the id of the main legal entity in the path. For sole proprietorships, this is the individual legal entity ID of the owner.
Parameter | Required | Description |
---|---|---|
type | The type of document based on the services and capabilities requested by the user and your platform integration. | |
language | The language used for the Terms of Service document, specified by the two letter ISO 639-1 language code. Possible value: en for English. | |
termsOfServiceDocumentFormat | The requested format for the Terms of Service document. Default value: JSON. Possible values: JSON, PDF, or TXT. |
curl https://kyc-test.adyen.com/lem/v3/legalEntities/LE00000000000000000000001/termsOfService \ -H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \ -d '{ "type": "adyenForPlatformsAdvanced", "language": "en" }'
The response returns the following information:
Parameter | Description |
---|---|
document | The generated document in the Base64-encoded format. |
id | The unique identifier of the organization legal entity. |
language | The language of the document. |
type | The type of document based on the services and capabilities requested by the user and your platform integration. |
termsOfServiceDocumentId | The unique identifier of the document. |
termsOfServiceDocumentFormat | The requested format for the Terms of Service document. Default value: JSON. Possible values: JSON, PDF, or TXT. |
{ "id": "LE00000000000000000000001", "type": "adyenForPlatformsAdvanced", "language": "en", "document": "termsOfServiceDocumentResponse" , "termsOfServiceDocumentId": "abc123", "termsOfServiceDocumentFormat": "JSON" }
The response returns the document and its unique termsOfServiceDocumentId.
Your user may need to accept more than one Terms of Service document depending on your integration. In this case, every required document and termsOfServiceDocumentId is returned in the response.
You will need to present the document to your user in the next step. Use the document ID when you confirm your user has accepted the Terms of Service.
Step 4: Present the Terms of Service document to your user
You need to ask your user to review and accept the Terms of Service document. The process to do this depends on the format of the document.
To present the document to your user, you can use the Adyen Document Viewer to render the document in your website.
Before passing the document to the Adyen Document Viewer, you need to decode it.
const documentViewer = new AdyenDocumentViewer('#test'); const document = JSON.parse(decodeURIComponent(escape(window.atob(termsOfServiceDocumentResponse.document)))); documentViewer.render(document);
Install the Adyen Document Viewer package:
npm install @adyen/adyen-document-viewer --save
Import the Adyen Document Viewer Node package into your application. You can add your own styling by overriding the rules in the CSS file.
import AdyenDocumentViewer from '@adyen/adyen-document-viewer'; import '@adyen/adyen-document-viewer/dist/adyen-document-viewer.min.css';
Step 5: Accept the Terms of Service
To confirm that your user has accepted the Terms of Service, make a PATCH /legalEntities/{id}/termsOfService/termsOfServicedocumentid request, specifying the id of the main legal entity and the termsOfServiceDocumentId of the document in the path. For sole proprietorships, include the legal entity ID of the owner in the path. For organizations, include the legal entity ID of the organization in the path.
In the body of the request, specify the following:
Parameter | Required | Description |
---|---|---|
acceptedBy | The individual legal entity id of the user accepting the Terms of Service. For sole proprietorships, this is the individual legal entity ID of the owner. For organizations, this is the legal entity ID of an authorized signatory for the organization. | |
ipAddress | The IP address of the user. |
This request populates the Terms of Service document with the data of the main legal entity. For sole proprietorships, this is the information for the individual legal entity of the owner. For organizations, this means the document contains both the data for the organization and the individual legal entity of the authorized signatory who accepted the document.
curl https://kyc-test.adyen.com/lem/v3/legalEntities/LE00000000000000000000001/termsOfService/abc123 \ -H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \ -H 'content-type: application/json' \ -X PATCH \ -d '{ "acceptedBy" : "LE00000000000000000000002", "ipAddress" : "127.0.0.1" }'
The response returns the following information.
Parameter | Description |
---|---|
acceptedBy | The individual legal entity id of the user who accepted the terms of service. |
id | The unique identifier of the accepted document. |
ipAddress | The IP address of the user. Only if provided in the request. |
language | The language of the document. |
termsOfServiceDocumentId | The unique identifier of the document. |
type | The type of document based on the services and capabilities requested by the user and your platform integration. |
{ "acceptedBy": "LE00000000000000000000002", "id": "TOSA000AB00000000B2AAAB2BA0AA0", "ipAddress": "127.0.0.1", "language": "en", "termsOfServiceDocumentId": "abc123", "type": "adyenForPlatformsAdvanced" }
Step 6 (Optional): Get the Terms of Service information for a legal entity
To see the Terms of Service information for a legal entity, make a GET /legalEntities/{id}/termsOfServiceAcceptanceInfos request with the id of the main legal entity in the path. For sole proprietorships, this is the individual legal entity ID of the owner.
curl https://kyc-test.adyen.com/lem/v3/legalEntities/LE00000000000000000000001/termsOfServiceAcceptanceInfos \ -H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \ -X GET \
The response returns information about the Terms of Service document linked to the legal entity.
Parameter | Description |
---|---|
createdAt | The date the document was created. |
id | The unique identifier of the accepted document. |
acceptedBy | The id of the individual who accepted the terms of service. |
acceptedFor | The id of the main legal entity. |
type | The type of document based on the services and capabilities requested by the user and your platform integration. |
{ "data": [ { "acceptedBy": "LE00000000000000000000002", "acceptedFor": "LE00000000000000000000001", "createdAt": "2022-12-05T13:36:58.212253Z", "id": "TOSA000AB00000000B2AAAB2BA0AA0", "type": "adyenForPlatformsAdvanced" } ] }