Skip to main content

Messaging utilities for dojo applications

Project description

Dojo Messaging

why?

  • enables us to use higher compression ratio algorithms like zstandard

  • uses aiohttp under the hood for client-side, and fastapi for server side

  • uses AsyncRetrying from tenacity, and asyncio.BoundedSemaphore by default for controlling batching & concurrency

  • fully typed, so you can simply access your Synapse's fields directly from response.body

  • dedicated function for batch sending to target URLs

  • explicitly raise HTTPExceptions in code where server logic will propagate to client

  • decoupling traditional HTTP status codes from protocol level status codes (e.g. blacklisted requests return "200 OK" but with an "error" message field)

  • server (typically miner)

    • must call serve_synapse with both async def handler(fastapi.Request, pydantic.BaseModel)
    • must initialise
  • client (typically validator)

Example Usage

from http import HTTPStatus

from aiohttp import ClientSession, TCPConnector
from pydantic import BaseModel, Field
from typing import Any

from dojo_messaging import Client


# retry logic handled under the hood
class ExampleModel(BaseModel):
    field: bool = Field(default=False, description="Example field")


async def main():
    # provide a session is optional, or use the convenience function
    client = Client(
        hotkey="your hotkey",  # used for signing and verification,
        session=ClientSession(
            connector=TCPConnector(
                limit=100
            )  # specify your own session, connector, etc. as needed
        ),
    )

    example_model = ExampleModel()
    # any other kwargs may be propagated to the underlying POST request using aiohttp
    kwargs: dict[str, Any] = {}
    response = await client.send(
        "http://ip:port",
        model=example_model,
        timeout_sec=12,
        max_retries=10,
        max_wait_sec=100,
        **kwargs,
    )

    # check for errors
    if response.error:
        # check for response.error that comes from server side
        print(f"Error received from server: {response.error}")
    if response.exception:
        # check for response.exception that comes from client side
        print(f"Exception occurred {response.exception}")

    if response.client_response and response.client_response.status != HTTPStatus.OK:
        # access fields from ExampleModel directly
        print(f"Received {response.body.field=}")

    # dedicated batch_send method
    # use an asyncio semaphore for concurrency & batch control
    # if semaphore isn't provided, asyncio.gather is called
    responses = await client.batch_send(
        urls=["http://ip:port"] * 5, models=[ExampleModel()] * 5
    )
    for response in responses:
        # access fields as needed...

        # check for errors
        if response.error:
            # check for response.error that comes from server side
            print(f"Error received from server: {response.error}")
        if response.exception:
            # check for response.exception that comes from client side
            print(f"Exception occurred {response.exception}")

        if (
            response.client_response
            and response.client_response.status != HTTPStatus.OK
        ):
            # access fields from ExampleModel directly
            print(f"Received {response.body.field=}")

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

dojo_messaging-1.0.15rc1.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

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

dojo_messaging-1.0.15rc1-py3-none-any.whl (15.1 kB view details)

Uploaded Python 3

File details

Details for the file dojo_messaging-1.0.15rc1.tar.gz.

File metadata

  • Download URL: dojo_messaging-1.0.15rc1.tar.gz
  • Upload date:
  • Size: 18.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for dojo_messaging-1.0.15rc1.tar.gz
Algorithm Hash digest
SHA256 7a6959025029b4bb06372df98278ab86a48db72a17bb9da2163fce9de167debf
MD5 49773d46081e688962f966c9b854613f
BLAKE2b-256 b757dd14509efc69ce38140e2f5df9146e111be39de30f47f9f02ad6971a6c5e

See more details on using hashes here.

Provenance

The following attestation bundles were made for dojo_messaging-1.0.15rc1.tar.gz:

Publisher: release.yml on tensorplex-labs/dojo-messaging

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

File details

Details for the file dojo_messaging-1.0.15rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for dojo_messaging-1.0.15rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 8d378dc0f2f50f4bf7e55fa1a724c016229160998f35853cb7b47b62a3537359
MD5 d5d24a0303635d67073d24f61cfe377a
BLAKE2b-256 85d0a5560168b0e4806f1c6e22328f95eaad59577757b2eecad64a8796ec7034

See more details on using hashes here.

Provenance

The following attestation bundles were made for dojo_messaging-1.0.15rc1-py3-none-any.whl:

Publisher: release.yml on tensorplex-labs/dojo-messaging

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