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.4.tar.gz (9.8 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.4-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: moonblade-1.1.4.tar.gz
  • Upload date:
  • Size: 9.8 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.4.tar.gz
Algorithm Hash digest
SHA256 6fb933e1ef269320c41a896400b24a21124149509c712a13fa50a9d238707452
MD5 539988d0ad5f3ba07ace0585618ff801
BLAKE2b-256 e840ef76e3b098807ca39045bb1e99d5bb6be55d525166ce7abaa1a97090ddcd

See more details on using hashes here.

File details

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

File metadata

  • Download URL: moonblade-1.1.4-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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ad9d3bb9686ce987d8b40c9b7dd56b3ff0c1575bd490873e6bce2bbc7c42e002
MD5 196a38c64cec7b194aec12aadb15397f
BLAKE2b-256 255fb155458da86f39fdd14879fadc03b3109a30612a4fbdeaa428212b61c91a

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