Skip to main content

Official Sunbay Nexus Python SDK

Project description

Sunbay Nexus Python SDK

Official Python SDK for the Sunbay Nexus payment platform.

This SDK provides a simple and professional way to integrate with Sunbay Nexus payment platform from Python applications, with full support for all payment operations.

Features

  • Simple and intuitive API
  • Thread-safe client with connection pooling
  • Clear separation between network errors and business errors
  • Automatic authentication via API key
  • Configurable timeouts and retries for GET requests
  • Python 3.7+ support

Installation

Once published to PyPI:

pip install sunbay-nexus-sdk

Supported Python versions

  • Officially supported: Python 3.7 and above
  • Python 2 is not supported.

Quick Start

1. Initialize client

from sunbay_nexus_sdk import NexusClient

# Option 1: pass api_key explicitly
client = NexusClient(api_key="sk_test_xxx")

# Option 2: read api_key from environment variable SUNBAY_API_KEY
# client = NexusClient()

The NexusClient is thread-safe and can be reused across multiple threads. Create it once and reuse it in your application.

2. Sale transaction

from sunbay_nexus_sdk import NexusClient, SunbayBusinessError, SunbayNetworkError
from sunbay_nexus_sdk.model.common import SaleAmount
from sunbay_nexus_sdk.model.request import SaleRequest

client = NexusClient(api_key="sk_test_xxx")

amount = SaleAmount(order_amount=100.0, pricing_currency="USD")

request = SaleRequest(
    app_id="app_123456",
    merchant_id="mch_789012",
    reference_order_id="ORDER20231119001",
    transaction_request_id="PAY_REQ_1234567890",
    amount=amount,
    description="Product purchase",
    terminal_sn="T1234567890",
)

try:
    response = client.sale(request)
    if response.is_success():
        print("Transaction ID:", response.transaction_id)
    else:
        print("Error:", response.code, response.msg)
except SunbayNetworkError as e:
    print("Network Error:", e)
except SunbayBusinessError as e:
    print("API Error:", e.code, "-", e)

3. Query transaction

from sunbay_nexus_sdk import NexusClient
from sunbay_nexus_sdk.model.request import QueryRequest

client = NexusClient(api_key="sk_test_xxx")

request = QueryRequest(
    app_id="app_123456",
    merchant_id="mch_789012",
    transaction_id="TXN20231119001",
)

response = client.query(request)

if response.is_success():
    print("Status:", response.transaction_status)
else:
    print("Error:", response.code, response.msg)

API Overview

The SDK provides a NexusClient with comprehensive payment APIs:

  • Transaction APIs:
    • sale(request: SaleRequest) -> SaleResponse
    • auth(request: AuthRequest) -> AuthResponse
    • forced_auth(request: ForcedAuthRequest) -> ForcedAuthResponse
    • incremental_auth(request: IncrementalAuthRequest) -> IncrementalAuthResponse
    • post_auth(request: PostAuthRequest) -> PostAuthResponse
    • refund(request: RefundRequest) -> RefundResponse
    • void_transaction(request: VoidRequest) -> VoidResponse
    • abort(request: AbortRequest) -> AbortResponse
    • tip_adjust(request: TipAdjustRequest) -> TipAdjustResponse
  • Query APIs:
    • query(request: QueryRequest) -> QueryResponse
  • Settlement APIs:
    • batch_close(request: BatchCloseRequest) -> BatchCloseResponse

Exceptions

The SDK differentiates between network-level and business-level errors:

  • SunbayNetworkError
    • Thrown for network errors, timeouts, or HTTP non-2xx responses.
    • Has a retryable flag to indicate whether the request may be retried safely.
  • SunbayBusinessError
    • Thrown for API business errors (e.g. code != "0") and local parameter validation failures.
    • Contains code and trace_id fields when available.

Always catch SunbayNetworkError before SunbayBusinessError if you need to distinguish between them.

Configuration

You can configure the client using constructor arguments:

from sunbay_nexus_sdk import NexusClient

client = NexusClient(
    api_key="sk_test_xxx",
    base_url="https://open.sunbay.us",   # default
    connect_timeout=30.0,                # seconds, default 30.0
    read_timeout=60.0,                   # seconds, default 60.0
    max_retries=3,                       # default 3 for GET requests
    max_connections=200,                 # default 200
    # Optional: custom logger instance
    # logger=my_logger,
)

In addition, the SDK uses the standard Python logging library:

  • By default it logs HTTP requests/responses and errors to the logger named sunbay_nexus_sdk.http.
  • The SDK does not configure handlers or logging levels itself — you are free to integrate with any logging stack (standard logging, loguru, structlog, etc.) by configuring or adapting a logging.Logger.
  • For advanced use cases, you can pass a custom logger via the NexusClient(logger=...) constructor parameter; this logger will be used by the underlying HTTP client for all log output.

Using enums

For some fields (such as transaction status and card network type), the SDK provides enums to make the code more self-documenting:

from sunbay_nexus_sdk import TransactionStatus

if response.is_success() and response.transaction_status == TransactionStatus.SUCCESS:
    print("Transaction succeeded")

Integration in web frameworks

In web frameworks (such as FastAPI or Django), it is recommended to create a single NexusClient instance at startup and reuse it:

from sunbay_nexus_sdk import NexusClient

client = NexusClient(api_key="sk_live_xxx")

def process_payment(request_data):
    # build SaleRequest here...
    response = client.sale(request_data)
    ...

License

MIT License

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

sunbay_nexus_sdk-1.0.3.tar.gz (16.2 kB view details)

Uploaded Source

Built Distribution

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

sunbay_nexus_sdk-1.0.3-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file sunbay_nexus_sdk-1.0.3.tar.gz.

File metadata

  • Download URL: sunbay_nexus_sdk-1.0.3.tar.gz
  • Upload date:
  • Size: 16.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for sunbay_nexus_sdk-1.0.3.tar.gz
Algorithm Hash digest
SHA256 6f98678f1fec2b3463922b07162edff1caa8c0f18c9313b360751846c4e40174
MD5 8b26bbe893348c85dc20e69cb6323e34
BLAKE2b-256 0a56f8a3db474650aaf52da3134e6d735db36dccf4f03fc79f02e481d1cfc039

See more details on using hashes here.

File details

Details for the file sunbay_nexus_sdk-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for sunbay_nexus_sdk-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 fe99f087a847782b4c02e5d8a06bfa8b9dd4fb7984d5ad7be5a64e42c90bef49
MD5 99180b2af2bfb51b4f11c76c8ede916f
BLAKE2b-256 bb42b8cfbf8be93c1c9e6bf68cecf4da60925a8d2c3ba39bf72f22423cdae5c8

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