Metadata-Version: 2.4
Name: Adyen
Version: 15.0.0
Summary: Adyen Python Api
Home-page: https://github.com/Adyen/adyen-python-api-library
Author: Adyen
Author-email: Adyen <support@adyen.com>
Maintainer: Adyen
Maintainer-email: Adyen <support@adyen.com>
Keywords: payments,adyen,fintech
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Topic :: Software Development :: Libraries
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE.md
Requires-Dist: pydantic>=2.0
Provides-Extra: requests
Requires-Dist: requests>=2.25.0; extra == "requests"
Provides-Extra: pycurl
Requires-Dist: pycurl>=7.43.0; extra == "pycurl"
Provides-Extra: test
Requires-Dist: pytest>=7.0.0; extra == "test"
Requires-Dist: pytest-cov>=4.0.0; extra == "test"
Requires-Dist: mock>=4.0.0; extra == "test"
Requires-Dist: requests>=2.25.0; extra == "test"
Provides-Extra: dev
Requires-Dist: ruff>=0.4.4; extra == "dev"
Requires-Dist: pre-commit>=3.0.0; extra == "dev"
Dynamic: author
Dynamic: home-page
Dynamic: license-file
Dynamic: maintainer
Dynamic: requires-python

![Python](https://user-images.githubusercontent.com/55943882/212274988-4e58b807-d39b-4274-b712-06008b1ef5fc.png)

# Adyen APIs Library for Python

[![version](https://img.shields.io/pypi/v/Adyen.svg)](https://pypi.org/project/Adyen/)

This is the officially supported Python library for using Adyen's APIs.

## Supported API versions

| API                                                                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Service Name          | Supported version |
|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------| 
| [BIN lookup API](https://docs.adyen.com/api-explorer/BinLookup/54/overview)                       | The BIN Lookup API provides endpoints for retrieving information based on a given BIN.                                                                                                                                                                                                                                                                                                                                                                                | binLookup             | **v54**           |
| [Balance Platform API](https://docs.adyen.com/api-explorer/balanceplatform/2/overview)            | The Balance Platform API enables you to create a platform where you can onboard your users as account holders and create balance accounts, cards, and business accounts.                                                                                                                                                                                                                                                                                              | balancePlatform       | **v2**            |
| [Checkout API](https://docs.adyen.com/api-explorer/Checkout/71/overview)                          | Our latest integration for accepting online payments.                                                                                                                                                                                                                                                                                                                                                                                                                 | checkout              | **v71**           |
| [Capital API](https://docs.adyen.com/api-explorer/capital/1/overview)                          | Provides endpoints for embedding Adyen Capital into your marketplace or platform.                                                                                                                                                                                                                                                                                                                                                                                                                 | capital              | **v1**           |
| [Data Protection API](https://docs.adyen.com/development-resources/data-protection-api)           | Endpoint for requesting data erasure.                                                                                                                                                                                                                                                                                                                                                                                                                                 | dataProtection        | **v1**            |
| [Legal Entity Management API](https://docs.adyen.com/api-explorer/legalentity/4/overview)         | The Legal Entity Management API enables you to manage legal entities that contain information required for verification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | legalEntityManagement | **v4**            |
| [Management API](https://docs.adyen.com/api-explorer/Management/3/overview)                       | Configure and manage your Adyen company and merchant accounts, stores, and payment terminals.                                                                                                                                                                                                                                                                                                                                                                         | management            | **v3**            |
| [Payments API](https://docs.adyen.com/api-explorer/Payment/68/overview)                           | Our classic integration for online payments.                                                                                                                                                                                                                                                                                                                                                                                                                          | payments              | **v68**           |
| [Payouts API](https://docs.adyen.com/api-explorer/Payout/68/overview)                             | Endpoints for sending funds to your customers.                                                                                                                                                                                                                                                                                                                                                                                                                        | payouts               | **v68**           |
| [POS Terminal Management API](https://docs.adyen.com/api-explorer/postfmapi/1/overview)           | ~~Endpoints for managing your point-of-sale payment terminals.~~ ‼️ **Deprecated**: use instead the [Management API](https://docs.adyen.com/api-explorer/Management/latest/overview) for the management of your terminal fleet.                                                                                                                                                                                                                                       | ~~terminal~~          | ~~**v1**~~        |
| [Recurring API](https://docs.adyen.com/api-explorer/Recurring/68/overview)                        | Endpoints for managing saved payment details.                                                                                                                                                                                                                                                                                                                                                                                                                         | recurring             | **v68**           |
| [Stored Value API](https://docs.adyen.com/payment-methods/gift-cards/stored-value-api)            | Endpoints for managing gift cards.                                                                                                                                                                                                                                                                                                                                                                                                                                    | storedValue           | **v46**           |
| [Transfers API](https://docs.adyen.com/api-explorer/transfers/4/overview)                         | Endpoints for managing transfers, getting information about transactions or moving fund                                                                                                                                                                                                                                                                                                                                                                               | transfers             | **v4**            |
| [Disputes API](https://docs.adyen.com/api-explorer/Disputes/30/overview)                          | You can use the [Disputes API](https://docs.adyen.com/risk-management/disputes-api) to automate the dispute handling process so that you can respond to disputes and chargebacks as soon as they are initiated. The Disputes API lets you retrieve defense reasons, supply and delete defense documents, and accept or defend disputes.                                                                                                                               | disputes              | **v30**           |
| [POS Mobile API](https://docs.adyen.com/api-explorer/possdk/68/overview)                          | The POS Mobile API is used in the mutual authentication flow between an Adyen Android or iOS [POS Mobile SDK](https://docs.adyen.com/point-of-sale/ipp-mobile/) and the Adyen payments platform. The POS Mobile SDK for Android or iOS devices enables businesses to accept in-person payments using a commercial off-the-shelf (COTS) device like a phone. For example, Tap to Pay transactions, or transactions on a mobile device in combination with a card reader. | posMobile             | **v68**           |
| [Payments App API](https://docs.adyen.com/api-explorer/payments-app/1/overview)                   | The Payments App API is used to Board and manage the Adyen Payments App on your Android mobile devices.                                                                                                                                                                                                                                                                                                                                                               | paymentsApp           | **v1**            |
| [SessionAuthentication API](https://docs.adyen.com/api-explorer/sessionauthentication/1/overview) | The Session authentication API enables you to create and manage the JSON Web Tokens (JWT) required for integrating                                                                                                                                                                                                                                                                                                                                                    | sessionAuthentication | **v1**            |

For more information, refer to our [documentation](https://docs.adyen.com/) or the [API Explorer](https://docs.adyen.com/api-explorer/).

## Prerequisites
 
- [Adyen test account](https://docs.adyen.com/get-started-with-adyen)
- [API key](https://docs.adyen.com/development-resources/api-credentials#generate-api-key). For testing, your API credential needs to have the [API PCI Payments role](https://docs.adyen.com/development-resources/api-credentials#roles).
- Python 3.8 or higher
- Packages (optional): requests or pycurl  

## Installation

### For development purpose

Clone this repository and run 

~~~~ bash 
make install
~~~~

### For usage purpose

Use pip command: 

~~~~ bash 
pip install Adyen
~~~~

## Using the library

Every API the library supports is represented by a service object. The name of the service matching the corresponding API is listed in the [Integrations](#supported-api-versions) section of this document.

This library offers two ways to initialize and use the Adyen API services.

#### Using all services

For simple scripts or applications that only use a single set of API credentials, you can use the main `Adyen` object. This creates a convenient "facade" that loads and provides easy access to all available APIs. Keep in mind that different API keys will have different scopes so you may still need more than one instance.

~~~~python
import Adyen

# Create the all-in-one client
adyen = Adyen.Adyen()

# Configure the client
adyen.client.xapikey = "YourXapikey"
adyen.client.platform = "test"  # change to "live" for production
adyen.client.application_name = "MyTestApp" # if applicable, set application name (for tracking purposes)


# Prepare the request
request = {
    "merchantAccount": "YOUR_MERCHANT_ACCOUNT",
    "amount": {
        "currency": "USD",
        "value": 1000  # value in minor units
    },
    "reference": "Your order number",
    "paymentMethod": {
        "type": "visa",
        "encryptedCardNumber": "test_4111111111111111",
        "encryptedExpiryMonth": "test_03",
        "encryptedExpiryYear": "test_2030",
        "encryptedSecurityCode": "test_737"
    },
    "returnUrl": "https://your-company.com/..."
}

# Make the API call through the long-form path
result = adyen.checkout.payments_api.payments(request)
~~~~

#### Using Individual Service Clients

For some web applications (e.g., using Flask or Django), multi-threaded environments, or any use case where you might need to manage multiple API credentials (for different merchant accounts, ECOM vs. POS, etc.), it is recommended to instantiate API clients directly.

~~~~python
# Import the core client and the service-level API class
from Adyen.client import AdyenClient
from Adyen.services import AdyenCheckoutApi

# Create and configure the core AdyenClient
adyen_client = AdyenClient()
adyen_client.xapikey = "YourXapikey"
adyen_client.platform = "test"
adyen_client.application_name = "MyTestApp" # if applicable, set application name (for tracking purposes)

# Instantiate the AdyenCheckoutApi service
checkout_service = AdyenCheckoutApi(client=adyen_client)

# Make API calls using the sub-clients within the service
request = {"merchantAccount": "YOUR_MERCHANT_ACCOUNT", ...}
payment_result = checkout_service.payments_api.payments(request)
order_result = checkout_service.orders_api.orders(request)
~~~~

Similarly you can instantiate a separate client for services that required different API keys

~~~~python
adyen_lem_client = AdyenClient()
adyen_lem_client.xapikey = "YourLEMXapikey"
adyen_lem_client.platform = "test"
adyen_lem_client.application_name = "MyTestApp" # if applicable, set application name (for tracking purposes)
~~~~

#### Force HTTP library

~~~~python
import Adyen

adyen = Adyen.Adyen()
adyen.client.http_force = 'requests' # or 'pycurl'
~~~~

### Using query parameters (management API only)

Define a dictionary with query parameters that you want to use.

~~~~ python
query_parameters = {
    'pageSize': 10,
    'pageNumber': 3
}
~~~~

pass the dictionary to the method as an additional argument.

~~~~ python
adyen.management.account_company_level_api.get_companies(query_parameters=query_parameters)
~~~~

### Using Header Parameters

Define a dictionary containing the headers you want to include in your request.

~~~~ python    
    headers = {
        "Var1": "Var2",
        "Var2": "Var1"
    }
~~~~

Pass the dictionary as an additional argument to the method where you make the API call.

~~~~ python  
    adyen.checkout.payments_api.payments(header_parameters=headers)
~~~~

### Customizing Base URL

Instantiate the service and replace the baseUrl with your own URL

~~~~ python
    service = adyen.checkout.payments_api
    service.baseUrl = "localhost:8080"
~~~~

### Handling exceptions

Adyen service exceptions extend the AdyenError class. After you catch this exception, you can access the 
class arguments for the specifics around this error or use the debug method which prints all the arguments.

~~~~python
try:
    adyen.checkout.payments_api.payments(request)
except Adyen.exceptions.AdyenError as error:
    print(error.debug())
~~~~

<details><summary>List of exceptions</summary>
<p>AdyenInvalidRequestError</p>
<p>AdyenAPIResponseError</p>
<p>AdyenAPIAuthenticationError</p>
<p>AdyenAPIInvalidPermission</p>
<p>AdyenAPICommunicationError</p>
<p>AdyenAPIValidationError</p>
<p>AdyenAPIUnprocessableEntity</p>
<p>AdyenAPIInvalidFormat</p>
<p>AdyenEndpointInvalidFormat</p>
</details>

### Example integration
 
For a closer look at how our Python library works, clone our [example integration](https://github.com/adyen-examples/adyen-python-online-payments). This includes commented code, highlighting key features and concepts, and examples of API calls that can be made using the library.

## Feedback

We value your input! Help us enhance our API Libraries and improve the integration experience by providing your feedback. Please take a moment to fill out [our feedback form](https://forms.gle/A4EERrR6CWgKWe5r9) to share your thoughts, suggestions or ideas.

## Contributing
 
We encourage you to contribute to this repository, so everyone can benefit from new features, bug fixes, and any other improvements.
 
Have a look at our [contributing guidelines](CONTRIBUTING.md) to find out how to raise a pull request.
 
## Support

If you have a feature request, or spotted a bug or a technical problem, [create an issue here](https://github.com/Adyen/adyen-web/issues/new/choose).
 
For other questions, [contact our Support Team](https://www.adyen.help/hc/en-us/requests/new?ticket_form_id=360000705420).
 
## Licence

This repository is available under the [MIT license](LICENSE.md).
 
## See also

* [Example integration](https://github.com/adyen-examples/adyen-python-online-payments)
* [Adyen docs](https://docs.adyen.com/)
* [API Explorer](https://docs.adyen.com/api-explorer/)
