Skip to main content

Reusable integration framework for external service connectors (shops, couriers, payments, messaging, storage)

Project description

bapp-connectors

A ports-and-adapters integration framework for connecting to external services: marketplaces, couriers, payment gateways, messaging providers, and file storage.

Architecture

┌──────────────────────────────────────────────┐
│  Django Layer (django-bapp-connectors)        │
│  Models, Services, Tasks, Circuit Breaker     │
├──────────────────────────────────────────────┤
│  Core Framework (bapp-connectors)             │
│  Ports, DTOs, HTTP Client, Registry, Webhooks │
├──────────────────────────────────────────────┤
│  Provider Adapters                            │
│  Trendyol, eMAG, Sameday, Stripe, ...        │
└──────────────────────────────────────────────┘

Two packages, one monorepo:

Package Purpose Dependencies
bapp-connectors Core framework + all provider adapters requests, pydantic (no Django)
django-bapp-connectors Multi-tenant Django integration django, bapp-connectors, cryptography

Providers

Family Providers Count
Shop CEL.ro, eMAG, Gomag, Magento, Okazii, PrestaShop, Shopify, Trendyol, Vendigo, WooCommerce 10
Courier Colete Online, GLS, Sameday 3
Payment Cardinity, EuPlatesc, LibraPay, Netopia, PayPal, Stripe, Utrust 7
Messaging GoIP, RoboSMS, SMTP Email, Telegram, WhatsApp 5
Storage Dropbox, FTP File Storage, Google Drive, OneDrive, S3 Storage, SFTP, WebDAV 7
LLM Anthropic, Google Gemini, Ollama, OpenAI 4
Feed Compari.ro, Facebook Commerce, Google Merchant Center, Okazii.ro 4
Total 40

Quick Start

Install

uv add bapp-connectors              # core only
uv add django-bapp-connectors       # with Django integration

Use a provider directly

from bapp_connectors.providers.shop.trendyol import TrendyolShopAdapter

adapter = TrendyolShopAdapter(credentials={
    "username": "api_user",
    "password": "api_pass",
    "seller_id": "12345",
    "country": "RO",
})

# Test connection
result = adapter.test_connection()
print(result.success)

# Fetch orders
orders = adapter.get_orders()
for order in orders.items:
    print(order.order_id, order.status, order.total)

# Check capabilities
from bapp_connectors.core.capabilities import BulkUpdateCapability
if adapter.supports(BulkUpdateCapability):
    adapter.bulk_update_products(updates)

Use the registry

from bapp_connectors.core.registry import registry

# Import providers to register them
import bapp_connectors.providers.shop.trendyol

# Create adapter via registry
adapter = registry.create_adapter(
    family="shop",
    provider="trendyol",
    credentials={"username": "...", "password": "...", "seller_id": "..."},
)

# List all registered providers
for manifest in registry.list_providers():
    print(f"{manifest.family}: {manifest.name}")

Django integration

# models.py
from django_bapp_connectors.models import AbstractConnection

class Connection(AbstractConnection):
    company = models.ForeignKey("company.Company", on_delete=models.CASCADE)

# Usage
conn = Connection.objects.create(
    company=company,
    provider_family="shop",
    provider_name="trendyol",
)
conn.credentials = {"username": "...", "password": "...", "seller_id": "..."}
conn.save()

# Get adapter and use it
adapter = conn.get_adapter()
orders = adapter.get_orders()

# Circuit breaker: auto-disables after 3 auth failures
conn.is_operational  # True when is_enabled AND is_connected

Core Concepts

Ports (Interfaces)

Each provider family has a port that defines the common contract:

  • ShopPort — orders, products, stock/price sync
  • CourierPort — AWB generation, tracking, shipment management
  • PaymentPort — checkout sessions, payment status, refunds
  • MessagingPort — send messages (SMS, email, WhatsApp, Telegram), reply to inbound
  • StoragePort — save, open, delete, exists, listdir, size (Django Storage API compatible)
  • LLMPort — chat completion, model listing, tool/function calling

Capabilities (Optional Features)

Adapters can implement optional capabilities beyond their port:

  • BulkUpdateCapability — batch product updates
  • WebhookCapability — signature verification, webhook parsing
  • OAuthCapability — OAuth2 flow (authorize, exchange, refresh)
  • InvoiceAttachmentCapability — attach invoices to orders
  • ProductFeedCapability — generate product feeds
  • EmbeddingCapability — text embeddings for RAG/search
  • TranscriptionCapability — audio-to-text (Whisper)
  • StreamingCapability — streaming LLM responses
  • ImageGenerationCapability — AI image generation

Feature discovery: adapter.supports(BulkUpdateCapability)

Normalized DTOs

All providers return the same data types:

  • Order, OrderItem, OrderStatus, PaymentStatus
  • Product, ProductUpdate, ProductCategory
  • Shipment, AWBLabel, TrackingEvent
  • CheckoutSession, PaymentResult, Refund
  • OutboundMessage, InboundMessage, DeliveryReport
  • ChatMessage, LLMResponse, TokenUsage, ModelInfo, ToolCall
  • EmbeddingResult, TranscriptionResult, ImageResult
  • Contact, Address
  • PaginatedResult[T] — cursor-based pagination

Provider-specific data lives in the extra: dict field and provider_meta.

Resilient HTTP Client

Built-in retry, rate limiting, and observability:

  • Exponential backoff with configurable max retries
  • Token-bucket rate limiting per provider
  • Request/response middleware chain for logging
  • Error classification: retryable vs permanent

Error Hierarchy

ConnectorError
├── AuthenticationError      (401/403, not retryable)
├── ConfigurationError       (bad config, not retryable)
├── ValidationError          (bad request, not retryable)
├── RateLimitError           (429, retryable, has retry_after)
├── ProviderError            (5xx, retryable)
├── PermanentProviderError   (4xx non-auth, not retryable)
├── UnsupportedFeatureError  (capability not supported)
└── WebhookVerificationError (bad signature)

Development

# Setup
cd packages/connectors
uv sync --extra dev

# Run tests
uv run pytest tests/ src/bapp_connectors/providers/shop/trendyol/tests/ -v -p no:django

# Lint
uv run ruff check src/
uv run ruff format src/

Django workspace

cd packages/connectors/packages/django
uv sync --extra dev
uv run pytest tests/ -v

Documentation

Project Structure

packages/connectors/
├── src/bapp_connectors/
│   ├── core/
│   │   ├── ports/          # Port interfaces (contracts)
│   │   ├── capabilities/   # Optional capability interfaces
│   │   ├── dto/            # Normalized data transfer objects
│   │   ├── http/           # Resilient HTTP client + auth + retry + rate limit
│   │   ├── webhooks/       # Webhook dispatcher + signature verification
│   │   ├── errors.py       # Error hierarchy
│   │   ├── types.py        # Enums
│   │   ├── manifest.py     # Provider manifest schema
│   │   └── registry.py     # Provider registry
│   └── providers/
<!-- STRUCTURE:BEGIN -->
│       ├── shop/          # CEL.ro, eMAG, Gomag, Magento, Okazii, PrestaShop, Shopify, Trendyol, Vendigo, WooCommerce
│       ├── courier/       # Colete Online, GLS, Sameday
│       ├── payment/       # Cardinity, EuPlatesc, LibraPay, Netopia, PayPal, Stripe, Utrust
│       ├── messaging/     # GoIP, RoboSMS, SMTP Email, Telegram, WhatsApp
│       ├── storage/       # Dropbox, FTP File Storage, Google Drive, OneDrive, S3 Storage, SFTP, WebDAV
│       ├── llm/           # Anthropic, Google Gemini, Ollama, OpenAI
│       └── feed/          # Compari.ro, Facebook Commerce, Google Merchant Center, Okazii.ro
<!-- STRUCTURE:END -->
├── packages/django/        # Django integration (separate uv workspace)
│   └── src/django_bapp_connectors/
│       ├── models/         # Abstract models (Connection, SyncState, WebhookEvent, ExecutionLog)
│       ├── services/       # Service layer (Connection, Sync, Webhook)
│       ├── webhooks/       # Django views + URL routing
│       ├── tasks.py        # Celery tasks with circuit breaker
│       ├── callbacks.py    # Execution logging middleware
│       ├── encryption.py   # Fernet credential encryption
│       └── admin.py        # Admin mixins
├── tests/                  # Core framework tests
└── docs/                   # Documentation

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

bapp_connectors-0.7.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

bapp_connectors-0.7.0-py3-none-any.whl (475.1 kB view details)

Uploaded Python 3

File details

Details for the file bapp_connectors-0.7.0.tar.gz.

File metadata

  • Download URL: bapp_connectors-0.7.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bapp_connectors-0.7.0.tar.gz
Algorithm Hash digest
SHA256 741830c41a2c2dd8364f57296fc9f52dcf3a626916039bda0a007878a0ee74b7
MD5 8d409d4c9946921ef45a6e0f6ffa6d65
BLAKE2b-256 66aecdbd8e55c14ade097a28186dcf0e5ed193a56cfcd49556f8be0662cf5908

See more details on using hashes here.

Provenance

The following attestation bundles were made for bapp_connectors-0.7.0.tar.gz:

Publisher: publish.yml on bapp-open/bapp-connectors

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bapp_connectors-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: bapp_connectors-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 475.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bapp_connectors-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6ea3bc51ca37faab53c1dfc04738c4bf09c8427d4d538c4a5259c3bebf985ed4
MD5 b54510cbcd71d5cef6d1c0ab571821a4
BLAKE2b-256 bdbb8323542dadf48765e72e58dc577af82fc838f495f7d77e6bfcc9974ae60f

See more details on using hashes here.

Provenance

The following attestation bundles were made for bapp_connectors-0.7.0-py3-none-any.whl:

Publisher: publish.yml on bapp-open/bapp-connectors

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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