Library for communication with ČSOB API
Project description
CSOB client
Python library for communicating with ČSOB (https://platbakartou.csob.cz/) payment gateway API. The API is described here: https://github.com/csob/paymentgateway.
The library currently implements API v.1.9 only.
Installation
pip install csobpg
Basic usage
API client initialization
from csobpg.v19 import APIClient
client = APIClient("merchantId", "merch_private.key", "csob.pub", base_url=..., http_client=...)
HTTP client
The library uses the HTTPClient
interface for making HTTP requests.
It provides the following HTTP clients:
csobpg.http.urllib_client.UrllibHTTPClient
- the default one using theurllib
under the hoodcsobpg.http.requests_client.RequestsHTTPClient
- an extra HTTP client using therequests
under the hood. The library must be installed with therequests-client
extra to be able to use this client
It is also possible to implement the HTTPClient
interface to use your custom HTTP client.
The HTTP client is set as the following:
from csobpg.v19 import APIClient
from csobpg.http import HTTPClient
class CustomHTTPClient(HTTPClient):
...
client = APIClient(..., http_client=CustomHTTPClient(...))
Payment initialization
from csobpg.v19 import Cart, CartItem
response = client.init_payment(
order_no="2233823251",
total_amount=100,
return_url="http://127.0.0.1:5000/",
cart=Cart([CartItem("Apples", 1, 100)]),
merchant_data=b"Hello, World!",
)
Get payment URL
url = client.get_payment_process_url(pay_id)
Process the gateway redirect
response = client.process_gateway_return(data_dict)
Get payment status
response = client.get_payment_status(pay_id)
Reverse payment
response = client.reverse_payment(pay_id)
Refund payment
response = client.refund_payment(pay_id, amount=100)
Exceptions handling
from csobpg.v19.errors import APIError, APIClientError
from csobpg.http import HTTPRequestError
response = client.<operation>(...)
# you can access the response_code directly:
assert response.result_code == 0
# or call the `raise_for_result_code` method and handle exceptions:
try:
response.raise_for_result_code()
except APIError as exc:
# handle API error
# it is raised on any API error. You may also catch the specific API error
except APIClientError as exc:
# handle API client error
# it is raised when API returns unexpected response (e.g. invalid JSON, invalid signature)
except HTTPRequestError as exc:
# handle HTTP error
# it is raised on any HTTP error
except ValueError as exc:
# handle value error
# it is raised on any library's misuse (e.g. passing invalid parameters)
# it always means developer's mistake
RSA keys management
The simples way to pass RSA keys is to pass their file paths:
from csobpg.v19 import APIClient
client = APIClient(..., "merch_private.key", "csob.pub")
The library will read the private key from the file when needed. The public key will be cached into the RAM.
If you want to change it, use special classes:
from csobpg.v19 import APIClient, FileRSAKey, CachedRSAKey
client = APIClient(..., FileRSAKey("merch_private.key"), FileRSAKey("csob.pub"))
You may also override the base RSAKey class to define your own key access strategy:
from csobpg.v19 import RSAKey
class MyRSAKey(RSAKey):
def __str__(self) -> str:
return "my key"
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
Built Distribution
File details
Details for the file csobpg-0.1.0.tar.gz
.
File metadata
- Download URL: csobpg-0.1.0.tar.gz
- Upload date:
- Size: 19.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.9 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d5e7d8dd1c2376b78ca9ae4c62dd017140fb2808e67cadc6247e0c71b536ed7c |
|
MD5 | 9b1805730f652c170a16eb14b648d466 |
|
BLAKE2b-256 | ea3eca491b1a1e9f64f2c8420d125b553d0a7a9d0c3797a04bf9dcfcc3500527 |
File details
Details for the file csobpg-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: csobpg-0.1.0-py3-none-any.whl
- Upload date:
- Size: 32.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.9 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fc1e8d49141f03b33be1f6485def3367ba11720349aeb8fa4f1d83cea1dd7a21 |
|
MD5 | e77efdfbfcff9f5104a3a2fa0b416945 |
|
BLAKE2b-256 | dcdbae3a4411cc1ccfef693b7d8dc19a4a443a7095bad534ef7dde79f3442ad6 |