Adyen Python Online Payment integration demos
This repository showcases a PCI-compliant integration of the Sessions Flow, the default integration that we recommend for merchants. Explore this simplified e-commerce demo to discover the code, libraries and configuration you need to enable various payment options in your checkout experience.
The demo leverages Adyen's API Library for Python GitHub | Docs.
- Python 3.5 or greater
- Python libraries:
- flask
- uuid
- Adyen v12.0.0 or higher
This repository is configured to work with GitHub Codespaces. Click the badge below to launch a Codespace with all dependencies pre-installed.
For detailed setup instructions, see the GitHub Codespaces Instructions.
- Clone this repo:
git clone https://github.com/adyen-examples/adyen-python-online-payments.git
-
Run
source ./setup.shto:- Create and activate a virtual environment
- Download the necessary python dependencies
-
Set the following environment variables in your terminal:
- PORT (default 8080)
- API key
- Client Key
- Merchant Account
- HMAC Key
export ADYEN_API_KEY="your_adyen_api_key"
export ADYEN_CLIENT_KEY="your_adyen_client_key"
export ADYEN_MERCHANT_ACCOUNT="your_adyen_merchant_account"
export ADYEN_HMAC_KEY="your_adyen_hmac_key"- Configure allowed origins (CORS)
- It is required to specify the domain or URL of the web applications that will make requests to Adyen. In the Customer Area, add
https://localhost:8080in the list of Allowed Origins associated with the Client Key.
-
Run
./start.shto:- Initialize the required environment variables. This step is necessary every time you re-activate your venv
- Start Python app
-
Visit https://localhost:8080/ and select an integration type.
To try out integrations with test card numbers and payment method details, see Test card numbers.
Webhooks deliver asynchronous notifications about the payment status and other events that are important to receive and process.
You can find more information about webhooks in this blog post.
In the Customer Area under the Developers → Webhooks section, create a new Standard webhook.
A good practice is to set up basic authentication, copy the generated HMAC Key and set it as an environment variable. The application will use this to verify the HMAC signatures.
Make sure the webhook is enabled, so it can receive notifications.
This demo provides a simple webhook implementation exposed at /api/webhooks/notifications that shows you how to receive, validate and consume the webhook payload.
The following webhooks events should be enabled:
- AUTHORISATION
To make sure that the Adyen platform can reach your application, we have written a Webhooks Testing Guide that explores several options on how you can easily achieve this (e.g. running on localhost or cloud).
We commit all our new features directly into our GitHub repository. Feel free to request or suggest new features or code changes yourself as well!
Find out more in our Contributing guidelines.
MIT license. For more information, see the LICENSE file in the root directory.
