Skip to main content

Web Messaging Protocol

Project description

almanet

Web Messaging Protocol is an open application level protocol that provides two messaging patterns:

  • Routed Remote Procedure Calls (RPC)
  • Produce & Consume

NSQ is a realtime distributed queue like message broker.

Almanet uses NSQ to exchange messages between different sessions.

Quick Start

Before install and run NSQD instance using this instruction.

Then install almanet PyPI package

pip install almanet

or

poetry add almanet

Create a new file and

import almanet

Create your own Microservice

Explanation of the code that defines and runs a simple microservice

Define your instance of microservice

example_service = almanet.new_service(
    "localhost:4150",
    prepath="net.example"
)

Arguments:

  • the TCP addresses of the NSQ instances
  • prepath for the service's procedures, helping in identifying and organizing them

Define your custom exception

class denied(almanet.rpc_error):
    """Custom RPC exception"""

This custom exception can be raised within procedures to signal specific error conditions to the caller.

Define your remote procedure to call

@example_service.procedure
async def greeting(
    session: almanet.Almanet,
    payload: str,
) -> str:
    """Procedure that returns greeting message"""
    if payload == "guest":
        raise denied()
    return f"Hello, {payload}!"

Decorator @example_service.procedure registers the greeting function as a remote procedure for the example_service.

Arguments:

  • payload is a data that was passed during invocation.
  • session is a joined service, instance of almanet.Almanet

It raises the custom denied exception, indicating that this payload is not allowed if payload is "guest". Otherwise, it returns a greeting message.

At the end of the file

if __name__ == "__main__":
    example_service.serve()

Starts the service, making it ready to handle incoming RPC requests.

Finally

Run your module using the python command

Call your Microservice

Explanation of the code for creating a new session, calling a remote procedure, and handling potential exceptions during the invocation.

Create a new session

session = almanet.new_session("localhost:4150")

Arguments:

  • the TCP addresses of the NSQ instances

Calling the Remote Procedure

async with session:
    result = await session.call("net.example.greeting", "Aidar")
    print(result.payload)

async with session ensures that the session is properly managed and closed after use. Calls the remote procedure net.example.greeting with the payload "Aidar". Raises TimeoutError if procedure not found or request timed out. result.payload contains the result of the procedure execution.

Catching remote procedure exceptions

async with session:
    try:
        await session.call("net.example.greeting", "guest")
    except almanet.rpc_error as e:
        print("during call net.example.greeting('guest'):", e)

The try block attempts to call the net.example.greeting procedure with the payload "guest". If an exception occurs during the call, specifically an almanet.rpc_error, it is caught by the except block.

Finally

Run your module using the python command


See the full examples in ./examples directory.

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

almanet-0.6.2.tar.gz (14.0 kB view details)

Uploaded Source

Built Distribution

almanet-0.6.2-py3-none-any.whl (17.1 kB view details)

Uploaded Python 3

File details

Details for the file almanet-0.6.2.tar.gz.

File metadata

  • Download URL: almanet-0.6.2.tar.gz
  • Upload date:
  • Size: 14.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/22.6.0

File hashes

Hashes for almanet-0.6.2.tar.gz
Algorithm Hash digest
SHA256 75a7c9d1f135298eed7f388cbcf710ee9a64150248f6a07ffd29e759f662daa6
MD5 a81f227c7c64aee051d5f143efbca447
BLAKE2b-256 5d8a124011e26985fb3a8b01c3799243d6175241d3c983ad2dbb4e31506d39ee

See more details on using hashes here.

File details

Details for the file almanet-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: almanet-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/22.6.0

File hashes

Hashes for almanet-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ab8701b60c603281af6f7862e8083a468811b7c85d715cf7bf7fead616fae10e
MD5 08f397f15bac533f15c1da8429dd20a5
BLAKE2b-256 81e9ac749b3efcca16ae25974572d2ed9081e7107db953ba76f8b7c105bedba7

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