Skip to main content

Python SDK to integrate and interact with Hermes Marketing Automation Platform

Project description

Hermes Messaging SDK

Python Version License

A lightweight Python SDK for integrating with the Hermes Marketing Automation Platform. This SDK provides both synchronous and asynchronous clients for triggering workflows.

Features

  • 🚀 Simple API: Easy-to-use client for triggering workflows
  • Async Support: Full async/await support for high-performance applications
  • 🔄 Retry Logic: Built-in exponential backoff retry mechanism
  • 🛡️ Error Handling: Comprehensive error handling with custom exceptions

Installation

pip install basalam.hermes-messaging-sdk

Quick Start

Synchronous Usage

from basalam.hermes_messaging_sdk import HermesClient

# Initialize the client
client = HermesClient(access_token="your-access-token-here")

# Trigger a single workflow
client.trigger_workflow(
    workflow_id=123,
    data={
        "user_id": 456,
        "product_id": "abc123"
    }
)

# Bulk trigger workflows
client.bulk_trigger_workflow(
    workflow_id=123,
    data=[
        {"user_id": 456, "amount": "10,000,000"},
        {"user_id": 789, "amount": "1,000,000"}
    ]
)

Asynchronous Usage

import asyncio
from basalam.hermes_messaging_sdk import AsyncHermesClient

async def main():
    client = AsyncHermesClient(access_token="your-access-token")

    # Trigger a single workflow
    await client.trigger_workflow(
        workflow_id=123,
        data={
            "user_id": 456,
            "product_id": "abc123"
        }
    )

    # Bulk trigger workflows
    await client.bulk_trigger_workflow(
        workflow_id=456,
        data=[
            {"user_id": 789, "amount": "10,000,000"},
            {"user_id": 101, "amount": "4,000,000"}
        ]
    )

asyncio.run(main())

Configuration

Both HermesClient and AsyncHermesClient support the following configuration options:

client = HermesClient(
    access_token="your-access-token",      # Required: Your Hermes API token
    base_url="https://hermes.basalam.com", # Optional: Custom base URL
    timeout=30,                           # Optional: Request timeout in seconds
    max_retries=3,                        # Optional: Maximum retry attempts
    retry_delay=1.0                       # Optional: Base delay for exponential backoff
)

Retry Configuration

The SDK includes built-in retry logic with exponential backoff:

  • max_retries: Number of retry attempts (default: 3)
  • retry_delay: Base delay in seconds (default: None, disabled)
  • When enabled, uses exponential backoff: retry_delay * (2 ** attempt)

Error Handling

The SDK provides comprehensive error handling with custom exceptions:

from basalam.hermes_messaging_sdk import (
    HermesClient,
    HermesError,
    HermesAPIError,
    HermesConnectionError,
    HermesAuthorizationError
)

try:
    client = HermesClient(access_token="invalid-token")
    client.trigger_workflow(workflow_id=123, data={"test": "data"})
except HermesAuthorizationError as e:
    print(f"Authorization failed: {e}")
    print(f"Status code: {e.status_code}")
except HermesAPIError as e:
    print(f"API error: {e}")
    print(f"Status code: {e.status_code}")
except HermesConnectionError as e:
    print(f"Connection error: {e}")
except HermesError as e:
    print(f"Hermes SDK error: {e}")

API Reference

HermesClient

Methods:

  • trigger_workflow(workflow_id, data=None) - Trigger a single workflow
  • bulk_trigger_workflow(workflow_id, data) - Trigger multiple workflows

AsyncHermesClient

Async Methods:

  • async trigger_workflow(workflow_id, data=None) - Trigger a single workflow
  • async bulk_trigger_workflow(workflow_id, data) - Trigger multiple workflows

Requirements

  • Python 3.8+
  • httpx 0.24.0+

License

This project is licensed under the MIT License - see the LICENSE file for details.

Support

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

basalam_hermes_messaging_sdk-0.0.0.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

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

basalam_hermes_messaging_sdk-0.0.0-py3-none-any.whl (11.1 kB view details)

Uploaded Python 3

File details

Details for the file basalam_hermes_messaging_sdk-0.0.0.tar.gz.

File metadata

File hashes

Hashes for basalam_hermes_messaging_sdk-0.0.0.tar.gz
Algorithm Hash digest
SHA256 06353bb50895917248bccbc0b63ce716119b71d691962e2593181514fb8d2e85
MD5 f6644d0124ec9efa2ad5d99080077598
BLAKE2b-256 d3d8828f554f3c267dc2d83c7fbeeb8646688e8bd21ec623c3d47923ac0a1a4d

See more details on using hashes here.

File details

Details for the file basalam_hermes_messaging_sdk-0.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for basalam_hermes_messaging_sdk-0.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 33605da93c83400d8a0b30c6534350c79b2f540ea988d0d3d18c03bbb8409c9b
MD5 b6140b746a83c89cc401481b8944c293
BLAKE2b-256 ab3af1421d274df4ee5ec0514a53f3a81e4dab2cbe442a0c98da353ee1c70e8b

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