Skip to main content

A Python 3 asynchronous library committed to communicating with LOL server through 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.2.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.2-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: moonblade-1.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 9faa7feb108790df79939512c0570764e5bd1ccbbabfc8c5cb5a8e67e9ce356e
MD5 9add7041de55e04dbf6fff0e301ae195
BLAKE2b-256 3461314f3eec1149d7f4578c4dff0843a457e2d8bad13a0337a7b7607a036488

See more details on using hashes here.

File details

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

File metadata

  • Download URL: moonblade-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 9.2 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1d83c11d1c2d094c4764e251308ee542234b33b71d2695caa1deb37b8b4c90e1
MD5 3325c71cf342e97e034378249eded265
BLAKE2b-256 5a8a8ed780317aac425ef8573c7470f5ad5a2cfeb3d657d27ea55ac2e8c4fe88

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