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.0.tar.gz (52.6 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.0-py3-none-any.whl (86.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for checkout_sdk-3.5.0.tar.gz
Algorithm Hash digest
SHA256 ec8b3ea1389cec78eb97b227ca9eac7b1e6eb8a86616bbfde2631bac03e3296e
MD5 0f453967ea9c694c38e3613bb38cb925
BLAKE2b-256 c1ce12b57613e5a4797c31ee482d7c32225f2f9a81003d4372e35568829442ef

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for checkout_sdk-3.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 95175905bb64b5b64d4bd4dd09776a70fbd36739088f6f9478052a253c78836a
MD5 9ff6e0dc404b1fde650e8f8ce0c93d5b
BLAKE2b-256 bb356ca6cd654694adca23ed695721c02c3226668f39333ad4259c84c77ca751

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