Skip to main content

An asynchronous Python 3 library designed to communicate with the LOL server via the LCU API in a simple and flexible way.

Project description

moonblade

An asynchronous Python 3 library designed to communicate with the LOL server via the LCU API in a simple and flexible way.

Setup

pip install moonblade

Usage

moonblade consists of three core components: MoonBlade, Router, and Node.

MoonBlade

MoonBlade is a connector for establishing communication with the LOL server. Before using it, you need to import the class:

from moonblade import MoonBlade

To start communication with the LOL server, create an instance of MoonBlade and call start():

mb = MoonBlade()
await mb.start()

To stop communication:

await mb.stop()

MoonBlade also supports use as an asynchronous context manager:

async with MoonBlade() as mb:
    ...
    while True:
        await asyncio.sleep(1)

Router

Router is responsible for dispatching events received from the LOL server. Before using it, import the class:

from moonblade import Router

register

To receive events, you need to register asynchronous handlers. The register function accepts three parameters: route, event_types, and handler.

route

A route can be a URI or a path. If the route ends with a "/", it is treated as a path; otherwise, as a URI. Additionally, moonblade exposes the URI "/moonblade", which dispatches: A Create event when a connection to the LOL service is successfully established; A Delete event when the connection is lost; No Update event is dispatched for this URI.

event_types

Accepts one of the strings Create, Update, Delete, or All, or an iterable containing any combination of these strings. Defaults to "All". Case-insensitive.

handler

The handler must be an asynchronous function that accepts a single dict.

async def example(data: dict):
    pass

You can create a Router instance and register a route:

router = Router()
router.register(route = "/moonblade", event_types = "Create", handler = example)

Note: Router is a singleton. All instances refer to the same underlying object.

You can also register without instantiating:

Router.register(route = "/moonblade", event_types = ("Create",), handler = example)

Or use the decorator style (recommended). When using the decorator, you must omit the handler parameter:

@Router.register(route = "/moonblade", event_types = ["Create"])
async def example(data: dict):
    pass

Router also supports registering asynchronous class methods, described below.

unregister

You can unregister a previously registered handler:

router.unregister(route = "/moonblade", event_types = {"Create"}, handler = example)

If handler is set to None, all handlers for the specified route and event types will be unregistered.

fake

You can simulate events from the server using the asynchronous fake method:

await Router.fake(data = None, event_type = 'Create', uri = '/moonblade')
await Router.fake(data = None, event_type = 'Delete', uri = '/moonblade')

Node

You can also register asynchronous class methods as event handlers. In this case, the class must inherit from Node:

class N(Node):

    def __init__(self) -> None:
        ...
        super().__init__()

    @Router.register('/moonblade', 'Create')
    async def moonblade_start(self, data: dict):
        pass

Alternatively, if not inheriting from Node, you can trigger handler registration by iterating over __dir__():

class N:
    def __init__(self) -> None:
        for key in self.__dir__():
            getattr(self, key)

    @Router.register('/moonblade', 'Delete')
    async def moonblade_stop(self, data: dict):
        pass

Application

For more detailed usage instructions, reference the library Diana which is built on top of moonblade.

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

moonblade-1.1.5.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

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

moonblade-1.1.5-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

Details for the file moonblade-1.1.5.tar.gz.

File metadata

  • Download URL: moonblade-1.1.5.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for moonblade-1.1.5.tar.gz
Algorithm Hash digest
SHA256 4e155f26563b318ee37168914ac36dbede24d141d23cf0a6569d5ece666526f5
MD5 41d8fd495f09c7cdbcfa0ae43511edc7
BLAKE2b-256 8fdf991fd0d9c9ca44383d59d8652740879bb3fde580d008868737b3ebf37273

See more details on using hashes here.

File details

Details for the file moonblade-1.1.5-py3-none-any.whl.

File metadata

  • Download URL: moonblade-1.1.5-py3-none-any.whl
  • Upload date:
  • Size: 9.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for moonblade-1.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 f1a5bf1680072a00b736903d1fbd06b8552718e651744cd4134630a33e6061b7
MD5 2a91d40250f3c83a3816b9cdc094447c
BLAKE2b-256 fca415789fe31b399238e60b0a7dc12d5513f01a9aaf02ac61df7019a7d4efb5

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