Skip to main content

Ensign driver, SDK, and helpers for Python

Project description

PyEnsign

PyEnsign is the official Python SDK for Ensign, a distributed event store and stream-processing platform. This library allows you to interact with the Ensign API directly from Python in order to create publishers and subscribers.

Installation

pip install pyensign

Usage

Create a client from a client ID and client secret. If not provided, these will be obtained from the ENSIGN_CLIENT_ID and ENSIGN_CLIENT_SECRET variables.

from pyensign.ensign import Ensign

client = Ensign(client_id=<your client ID>, client_secret=<your client secret>)

The Event class can be used to create events from the raw data and mimetype.

from pyensign.events import Event

event = Event(b'{"temp": 72, "units": "fahrenheit"}', "application/json")

Publish events to a topic. This coroutine accepts one or more events, so the following uses are all valid.

await client.publish("weather", event)
await client.publish("weather", event1, event2)
await client.publish("weather", [event1, event2])

Publish is asynchronous. You should generally call flush() before your program exits to ensure that all events are published to the server.

# Wait for events to be published with a default timeout of 2 seconds.
await client.flush()

For more precision, you can wait for individual events to be acked by the server.

ack = await event.wait_for_ack()
print(ack)

Subscribe to one or more topics by providing the topic name(s) or ID(s).

async for event in client.subscribe("weather"):
    print("Received event with data: {}".format(event.data))
    await event.ack()

Advanced Usage

The publish coroutine accepts asynchronous callbacks so the client can distinguish between committed and uncommitted events. Callbacks are invoked when acks and nacks are received from the server and the first argument passed to the callback is the Ack or Nack itself. An Ack contains a committed timestamp. A Nack is returned if the event couldn't be committed and contains the ID of the event along with an error describing what went wrong.

async def handle_ack(self, ack):
    ts = datetime.fromtimestamp(ack.committed.seconds + ack.committed.nanos / 1e9)
    print(f"Event committed at {ts}")

async def handle_nack(self, nack):
    print(f"Could not commit event {nack.id} with error {nack.code}: {nack.error}")

await client.publish("weather", event, on_ack=handle_ack, on_nack=handle_nack)

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

pyensign-0.12.1b0.tar.gz (61.7 kB view details)

Uploaded Source

Built Distribution

pyensign-0.12.1b0-py3-none-any.whl (65.4 kB view details)

Uploaded Python 3

File details

Details for the file pyensign-0.12.1b0.tar.gz.

File metadata

  • Download URL: pyensign-0.12.1b0.tar.gz
  • Upload date:
  • Size: 61.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pyensign-0.12.1b0.tar.gz
Algorithm Hash digest
SHA256 447d9852b184a719bcca04b9beac4861d5976f679adf8506b4ae7f121c3e4993
MD5 dbc2a8e093a67d150f7586008b4efed2
BLAKE2b-256 28d33a4511add97e74b095163093f36c64e8f1c5c2845734894a84ec6b2b51bb

See more details on using hashes here.

File details

Details for the file pyensign-0.12.1b0-py3-none-any.whl.

File metadata

  • Download URL: pyensign-0.12.1b0-py3-none-any.whl
  • Upload date:
  • Size: 65.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pyensign-0.12.1b0-py3-none-any.whl
Algorithm Hash digest
SHA256 49d166d7a5eed2d3d587a9a75894b4519f6656deda2e10f41aae1336ad53193a
MD5 11427d6d57f0c3d84c51723b1b13c8aa
BLAKE2b-256 e0f8d4f26bc4356036d628d1f349f0b37716ce68ebf48478bc0c6d9e129563cf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page