Before you begin
Before you begin setting up the Adyen B2B LWR Commerce package, make sure that you:
- Set up your Salesforce B2B LWR Store.
- Activate multiple currencies for your Salesforce B2B store:
- In your Salesforce B2B Org, go to Setup > Company Settings > Company Information.
- Select Activate Multiple Currencies.
Step 1: Install the packages
- Install the following Adyen packages from the Salesforce App Exchange:
- When prompted for an installation key, enter Payments@Adyen.
Step 2: Generate an API key and client key
To connect your Salesforce store to the Adyen API, you need to generate an API key in your Customer Area.
To authenticate requests from your payment environment, the package also needs a client key. You need to generate a client key in your Customer Area.
Generate an API key in your Customer Area
- Log in to your Customer Area.
- Go to Developers > API credentials, and select the API credential username for your integration, for example ws@Company.[YourCompanyAccount].
- Under Server settings > Authentication select the API key tab.
- Select Generate API key.
- Select the copy icon and store your API key securely in your system.
- Select Save changes.
Generate a client key in your Customer Area
- Log in to your Customer Area.
- Go to Developers > API credentials, and select the credential username for your integration, for example ws@Company.[YourCompanyAccount].
- Under Client settings > Authentication select the Client key tab.
- Select Generate client key.
- Select the copy icon and store your client key securely in your system. You will need your client key when configuring package components.
- Under Add allowed origins, enter the URL of your Salesforce store, and select Add.
- To render the Adyen checkout component in Builder mode, add the builder URLs. For example:
https://YOUR-ORG.develop.live-preview.salesforce-experience.com
https://YOUR-ORG.develop.builder.salesforce-experience.com
- Select Save changes.
Step 3: Set up webhooks
Adyen uses webhooks to inform your Salesforce B2B store of payment status changes. To receive these webhooks:
After you have set up webhooks, Salesforce creates a Gateway Log each time your Salesforce B2B Org receives a webhook from Adyen.
Expose a Salesforce site endpoint
- In your Salesforce B2B Org, go to Setup > User Interface > Sites and Domains - Sites.
- Select your store site.
- Select Public Access Settings, and then select Apex Class Access.
- Select Edit and enable the adyen_payment.AdyenAuthWebhookHandler class by moving it from the Available column to the Enabled column.
- Select Save.
- Go back to your Profile Overview, and then select Object Settings.
- Select Log Entries, and then select Edit.
- In the Assigned Record Types column, select the checkboxes for Exception and Information.
- Under Object Permissions, select the checkbox for Create.
- Under Field Permissions, in the Edit Access column, select the checkboxes for all fields.
- Select Save.
Set up webhooks in the Customer Area
-
In your Customer Area, go to Developers > Webhooks. If you want to configure webhooks for a merchant account, switch to that merchant account.
-
Select Webhook.
-
From the list of webhooks, next to Standard webhook, select Add.
-
Under General, configure the following:
Setting Description Enabled Select the toggle to enable or disable the webhook. Version The webhook version. Description Your description of the webhook. -
Under Server configuration, configure the following:
Setting Description URL Construct your webhook endpoint URL by adding /services/apexrest/adyen_payment/authWebhook/v1
to the end of the site endpoint you exposed, for example:http://dev-myorganization--sandbox.cs17.force.com/adyen/services/apexrest/adyen_payment/authWebhook/v1
.Method JSON Encryption protocol The latest TLS version in the list. -
Under Security, configure the following:
Setting Description HMAC Key Generate the HMAC Key, copy it, and store it securely in your system. You will need your HMAC key when configuring package components. -
Under Events, select AUTHORISATION.
-
Select Save configuration.
Configure a webhook job
To process the webhooks you receive from Adyen, schedule a job in your B2B Org. The way to configure the job depends on how frequently you want the job to run:
- For a job that runs multiple times a day, you must configure the job using the Developer Console.
- For a job that runs once a day or less frequently, you can configure the job using the UI.
Gateway Logs
When your Salesforce B2B Org receives an Adyen webhook, a Gateway Log is created to record the event. To view the logs for a payment:
- In the Commerce app, go to App Launcher.
- Search for and select Order Payment Summaries.
- In the list view, select the order payment method for the order you want to view the logs for.
- Under Related, check the Gateways Logs list.
The handling of these logs depends on when Salesforce creates the payment authorization. If Salesforce creates a payment authorization before the Adyen webhook reaches your store, Salesforce processes the webhook synchronously. If Salesforce hasn't yet created the payment authorization, Salesforce processes the webhook asynchronously when the webhook job you configured runs.
After a webhook is processed, the payment authorization status is updated to Processed, or Failed.
Step 4: Configure package components
In your Salesforce B2B Org, configure package components:
Set up the Principal Credential
These steps are based on the Salesforce Enhanced Profile User Interface. If you use the old view, the steps you have to take may differ.
When you install the packages, the Named Credential is set up automatically.
In addition to the Named Credential, you need to set up a Principal Credential. To do this, in your B2B Org:
- Go to Setup > Security > Named Credentials.
- Under External Credential, select Adyen Auth.
- Under Principals, next to the AdyenApiKey, select the Actions button, and then select Edit.
This opens a modal window. - Select Add, and add an authentication parameter with the following properties:
- Name: ApiKey
- Value: Your API key.
After setting up the Principal, give access to this Principal:
- Go to Setup > Users > Permission Sets.
- Next to Adyen Checkout Access, select Clone.
- In the Label field, enter a name, and select Save.
- Select the permission set you have cloned.
- Select External Credential Principal Access.
- Select Edit and enable the Principal you have set up by moving it from the Available to the Enabled column.
- Go back to the permission set, and select Object Settings.
- Select User External Credentials, and select Edit.
- Next to Read, select the checkbox to give read access.
- Assign the permission set you have created to the users of your Salesforce B2B Store:
- Select Manage Assignments, and then select Add Assignment.
- In the user list, select the users that you want to assign, and select Next.
- Select Assign.
Create a Payment Gateway
- In the Commerce app, select App Launcher and type Payment Gateways.
-
Select New, and enter the following values:
Field Value Payment Gateway Name Adyen Payment Gateway Provider CommercePaymentsAdyenAsyncAdapter Merchant Credential AdyenCheckout Status Active External Reference Leave blank. - Select Save.
- In your store administration section, select Payments.
- Select Select Provider, and choose the gateway you have created to link it to your store.
Configure custom metadata
- In your B2B Org, go to Setup > Custom Code > Custom Metadata Types.
- Next to Adyen Adapter, select Manage Records.
- Next to Adyen Default, select Edit.
- Fill the following fields:
- Merchant Account: your Adyen merchant account name. This field is case-sensitive.
- Client Key: your client key.
- HMAC Key: your HMAC key.
- Select Save.
Step 5: Set up the Adyen Lightning Web Component
To process payments with Adyen in your Salesforce B2B store:
- Add the Adyen Lightning Web Component to your store.
- Enable tokenization (optional).
- Add Adyen to your trusted URL list.
Add the Adyen Lightning Web Component to your store
- In your B2B Org, go to Setup > Feature Settings > Digital Experiences > All Sites.
- Next to your site, select Builder.
- On the top left, in the Pages menu, select Checkout.
- Scroll to the Payment section.
- Delete the standard Salesforce payment component.
- Select the Components icon, and search for Adyen Checkout.
- Drag the Adyen Checkout component to the place you deleted the Salesforce payment component from.
- Verify that the billing address component is present on the page and in the same checkout section as the Adyen Checkout.
- In the Pages menu, select Payment Processing.
- Add the Adyen Checkout component to the Payment Processing page.
- Select Publish.
Enable tokenization
To allow shoppers to store their payment details and use them later, enable tokenization.
- In your B2B Org, go to Setup > Feature Settings > Digital Experiences > All Sites.
- Next to your site, select Builder.
- On the top left, in the Pages menu, select Checkout.
- Under Payment, select the Adyen Checkout component.
This opens the Adyen Checkout modal window. - Under Settings, select Enable Save Payment Methods.
- Select Publish.
Add Adyen to your trusted URL list
- In your B2B Org, go to Setup > Security > Trusted URLs.
- To add a new trusted URL, select New trusted URL.
- Add the Adyen URL, specifying the following fields:
- API Name: select a descriptive name, for example, Adyen.
- URL:
https://*.adyen.com
Make sure that the Active checkbox is selected.
- Under CSP Directives, select all checkboxes.
- Select Save.
When you are ready to go live:
- Add new trusted URLs for all card schemes that you want to offer in your checkout to render the Adyen 3D Secure component and implement your Content Security Policy (CSP).
To add new trusted URLs, follow the steps above for each card scheme.
We recommend that you learn the implications of implementing a Content Security Policy (CSP) to manage scripts for PCI DSS v4.0.
Depending on your integration, loading the 3D Secure 2 interface might require you to add more URLs for access control servers to your CSP. Implementing a CSP with Access Control Server (ACS) URLs requires additional integration effort. Adyen does not maintain a list of all URLs.
Error handling
Redirect errors
The package uses Native 3D Secure in most cases. For some payment methods, the redirect flow may be triggered. We recommend setting up an error page for cases where an error occurs during the redirect flow to offer a better shopping experience.
The package redirects shoppers to the standard error page with the URL parameter paymentError
, and value not_authorized
, for example: https://your.site.com/mystore/error?paymentError=not_authorized
. You can customize the page and the error message displayed to your shoppers.
Override error message labels contents
If you want to override or translate error message labels, follow the steps in the Salesforce documentation.
Troubleshooting errors
When an error occurs during checkout or while processing webhooks, a Log Entry object is created with the Exception record type. Monitor these records to take action in case of errors.
When a payment attempt fails, a Log Entry object is created with the Information record type.
To view Log Entries:
- In your Commerce App, go to App Launcher.
- Search for and select Log Entries.
Test your integration
Before you go live with your integration, we recommend to test your integration to verify everything works correctly.
Test the following scenario:
- Log in to your store as a shopper, and pay for an order using one of Adyen's test cards.
In your Salesforce B2B Org:
- Verify that the order has the correct billing address.
- Verify that the log entries are free of errors.
- Verify that the webhook job you scheduled was executed after the payment, and the payment authorization status moved from Pending to Processed.
In your Adyen Customer Area:
- Check the status of a test payment under Transactions > Payments.
- Test your webhook server.
- Complete an end-to-end webhook test for the test payment.
Go live
- Apply for a live account. Review the process to start accepting payments on Get started with Adyen.
- Configure your live account:
- Set up your live account.
- Set up finances.
- Generate an API key and a Client key in your live Customer Area.
- Add allowed origins to your live API credential.
- Set up webhooks in the live Customer Area in your live account.
- Submit a request to add payment methods in your live Customer Area .
- Update the Adyen credentials you used to set up your Salesforce B2B Org:
- In the custom metadata record:
- Update your HMAC key and Client key.
- If you are using a different merchant account in the live environment, update the merchant account name.
- In the custom metadata record:
- Switch the URL for the Adyen Checkout named credential to your live URL:
- In your B2B Org, go to Setup > Security > Named Credentials.
- Select the Adyen Checkout named credential.
- Replace the test URL with
https://[YOUR_LIVE_PREFIX]-checkout-live.adyenpayments.com/checkout
. Get your live prefix from the live Customer Area.
- Switch your test API key to your live API Key:
- Select the External Credential linked to your Adyen Checkout named credential.
- Under Principals, update your API key authentication parameter to your live API key.
-
Change the Adyen Environment value of the Adyen Lightning Web Component you added to your Checkout and Payment Processing pages to match your live endpoint region:
Endpoint region Value Europe (EU) live live United States (US) live live-us Australia (AU) live live-au Asia Pacific & Southeast (APSE) live live-apse India (IN) live live-in - Test the 3D Secure 2 authentication flow in the live environment to make sure that your CSP implementation supports all the payment methods that you offer to your shoppers.