Skip to main content

Checkout.com Python SDK

Project description

Checkout.com Python SDK

build-status CodeQL

build-status GitHub release PyPI - latest

GitHub license

Getting started

Requirements

  • Python 3.10 or higher
  • pip

Installation

pip install checkout-sdk

For a specific version:

pip install checkout-sdk==<version>

Version 3.0.0 is here!

We improved the initialization of SDK making it easier to understand the available options.
Now NAS accounts are the default instance for the SDK and ABC structure was moved to a previous prefixes.
If you have been using this SDK before, you may find the following important changes:

  • Imports: if you used to import checkout_sdk.payments.payments now use checkout_sdk.payments.payments_previous
  • Marketplace module was moved to Accounts module, same for classes and references.
  • In most cases, IDE can help you determine from where to import, but if you’re still having issues don't hesitate to open a ticket.

:rocket: Please check in GitHub releases for all the versions available.

:book: Checkout our official documentation.

:books: Check out our official API documentation guide, where you can also find more usage examples.

How to use the SDK

This SDK can be used with two different pair of API keys provided by Checkout. However, using different API keys imply using specific API features. Please find in the table below the types of keys that can be used within this SDK.

Account System Public Key (example) Secret Key (example)
Default pk_nruiensgius784thg489hio3481 sk_nguierhg984hg4nig489gh48931
Previous pk_gdf78gdg-rf56-3fgr-34rf-5435g456gg6y sk_hg5643g6-4r5t-gt67-ht6t-5467567g6f56

Note: sandbox keys have a sbox_ or test_ identifier, for Default and Previous accounts respectively.

If you don't have your own API keys, you can sign up for a test account here.

PLEASE NEVER SHARE OR PUBLISH YOUR CHECKOUT CREDENTIALS.

Default

Default keys client instantiation can be done as follows:

from checkout_sdk.checkout_sdk import CheckoutSdk
from checkout_sdk.environment import Environment


def default():
    # public key is optional, only required for operations related with tokens
    checkout_api = CheckoutSdk
        .builder()
        .secret_key('secret_key')
        .public_key('public_key') # optional, only required for operations related with tokens
        .environment(Environment.sandbox()) # or production()
        .environment_subdomain("subdomain") # optional, Merchant-specific DNS name
        .build()

    payments_client = checkout_api.payments
    payments_client.refund_payment('payment_id')

Default OAuth

The SDK supports client credentials OAuth, when initialized as follows:

from checkout_sdk.checkout_sdk import CheckoutSdk
from checkout_sdk.environment import Environment
from checkout_sdk.oauth_scopes import OAuthScopes


def oauth():
    checkout_api = CheckoutSdk
        .builder()
        .oauth()
        .client_credentials(client_id='client_id', client_secret='client_secret')
        .environment(Environment.sandbox()) # or production()
        .environment_subdomain("subdomain") # optional, Merchant-specific DNS name
        .scopes([OAuthScopes.GATEWAY_PAYMENT_REFUNDS, OAuthScopes.FILES]) # optional, array of scopes
        .build()

    payments_client = checkout_api.payments
    payments_client.refund_payment('payment_id')

Previous

If your pair of keys matches the Previous type, this is how the SDK should be used:

from checkout_sdk.checkout_sdk import CheckoutSdk
from checkout_sdk.environment import Environment

def previous():
    # public key is optional, only required for operations related with tokens
    checkout_api = CheckoutSdk
        .builder()
        .previous()
        .secret_key('secret_key')
        .public_key('public_key') # optional, only required for operations related with tokens
        .environment(Environment.sandbox()) # or production()
        .environment_subdomain("subdomain") # optional, Merchant-specific DNS name
        .build()

    payments_client = checkout_api.payments
    payments_client.refund_payment('payment_id')

Logging

Checkout SDK custom logger can be enabled and configured through Python's logging module:

import logging
logging.basicConfig()
logging.getLogger('checkout').setLevel(logging.INFO)

HttpClient

Checkout SDK uses requests library to perform http operations, and you can provide your own custom http client implementing HttpClientBuilderInterface

import requests
from requests import Session

import checkout_sdk
from checkout_sdk.checkout_sdk import CheckoutSdk
from checkout_sdk.environment import Environment
from checkout_sdk.oauth_scopes import OAuthScopes
from checkout_sdk.http_client_interface import HttpClientBuilderInterface


class CustomHttpClientBuilder(HttpClientBuilderInterface):

    def get_client(self) -> Session:
        session = requests.Session()
        session.max_redirects = 5
        return session


def oauth():
    checkout_api = CheckoutSdk
        .builder()
        .oauth()
        .client_credentials(client_id='client_id', client_secret='client_secret')
        .environment(Environment.sandbox()) # or production()
        .environment_subdomain("subdomain") # optional, Merchant-specific DNS name
        .http_client_builder(CustomHttpClientBuilder()) # optional
        .scopes([OAuthScopes.GATEWAY_PAYMENT_REFUNDS, OAuthScopes.FILES]) # optional, array of scopes
        .build()

    payments_client = checkout_api.payments
    payments_client.refund_payment('payment_id')

Exception handling

All the API responses that do not fall in the 2** status codes will cause a CheckoutApiException. The exception encapsulates the http_metadata, request_id, error_type, and a list of error_details, if available.

try:
    checkout_api.customers.get("customer_id")
except CheckoutApiException as err:
    http_status_code = err.http_metadata.status_code
    request_id = err.request_id
    error_type = err.error_type
    error_details = err.error_details

Building from source

Prerequisites

  • Python 3.10 or higher
  • pip (latest version)

Setup Development Environment

  1. Clone the repository

    git clone https://github.com/checkout/checkout-sdk-python.git
    cd checkout-sdk-python
    
  2. Create and activate virtual environment

    python3.10 -m venv .venv
    source .venv/bin/activate  # On Windows: .venv\Scripts\activate
    
  3. Install dependencies

    pip install --upgrade pip
    pip install -r requirements-dev.txt
    
  4. Install pre-commit hooks (optional but recommended)

    pre-commit install
    

Running Tests

# Run all tests
python -m pytest --import-mode=append --runxfail tests/

# Run specific test file
python -m pytest tests/payments/payments_client_test.py -v

# Run with coverage
python -m pytest --cov=checkout_sdk tests/

Code Quality

The project uses flake8 and pylint for code quality checks:

# Run flake8
flake8 checkout_sdk tests --count --max-complexity=10 --max-line-length=127 --statistics

# Run pylint
pylint checkout_sdk

If you installed pre-commit hooks, these checks will run automatically before each commit.

Environment Variables

The execution of integration tests require the following environment variables set in your system:

  • For Default account systems: CHECKOUT_DEFAULT_PUBLIC_KEY & CHECKOUT_DEFAULT_SECRET_KEY
  • For OAuth account systems: CHECKOUT_DEFAULT_OAUTH_CLIENT_ID & CHECKOUT_DEFAULT_OAUTH_CLIENT_SECRET
  • For Previous account systems: CHECKOUT_PREVIOUS_PUBLIC_KEY & CHECKOUT_PREVIOUS_SECRET_KEY
  • Processing channel: CHECKOUT_PROCESSING_CHANNEL_ID

Code of Conduct

Please refer to Code of Conduct

Licensing

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

checkout_sdk-3.5.1.tar.gz (52.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

checkout_sdk-3.5.1-py3-none-any.whl (86.7 kB view details)

Uploaded Python 3

File details

Details for the file checkout_sdk-3.5.1.tar.gz.

File metadata

  • Download URL: checkout_sdk-3.5.1.tar.gz
  • Upload date:
  • Size: 52.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for checkout_sdk-3.5.1.tar.gz
Algorithm Hash digest
SHA256 0497a283d9436c0936968cf29e2317a74c0c2dec481fdb059b8e1d42998db746
MD5 5447b9752e383523233bc89a793343dc
BLAKE2b-256 d82ba118fcd3a70584251e19e1bd0894332dfc8a721c236293170b4a2fec3b18

See more details on using hashes here.

File details

Details for the file checkout_sdk-3.5.1-py3-none-any.whl.

File metadata

  • Download URL: checkout_sdk-3.5.1-py3-none-any.whl
  • Upload date:
  • Size: 86.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for checkout_sdk-3.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6e73a47bdcb09827dd3844838f53e5afa8d0735db8c6c658debca4146e913e0f
MD5 7a8a8e30d9f98c30c8959831244efda6
BLAKE2b-256 0b1841758aaeef9bfccd3e945988dd3b0eb7a561c93ea17e71e40dfa27183d40

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page