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 Discord, GoIP, Matrix, Facebook Messenger, RoboSMS, SMTP Email, Telegram, WhatsApp 8
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 43

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/     # Discord, GoIP, Matrix, Facebook Messenger, 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.11.0.tar.gz (1.3 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.11.0-py3-none-any.whl (502.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: bapp_connectors-0.11.0.tar.gz
  • Upload date:
  • Size: 1.3 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.11.0.tar.gz
Algorithm Hash digest
SHA256 3501224f423fa9e3611c88221f3f530ebf27794c0dd58ed0daa47481eb08d9f9
MD5 d7cfacbb4bfa4bb45948e54de2bd954a
BLAKE2b-256 70bb14ff47476fc161fb27a50e611f2ee6694c979538587df04a90c4798eacdf

See more details on using hashes here.

Provenance

The following attestation bundles were made for bapp_connectors-0.11.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.11.0-py3-none-any.whl.

File metadata

File hashes

Hashes for bapp_connectors-0.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 030c0595779dafededc84ebd2da74ef613b9e2745742de7a6efa4faf5084e04e
MD5 f1a6fdcef1b0f7cd85d364137f6e09da
BLAKE2b-256 af98be80eb38b8739ba8368b7dc1c5df449d91be8d65be277c9837bc174e1450

See more details on using hashes here.

Provenance

The following attestation bundles were made for bapp_connectors-0.11.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