Skip to main content

Communicate with TWELITE wireless modules

Project description

mono wireless logo

MWings

A library that communicate with TWELITE wireless modules.

Lint with mypy / black / ruff MW-OSSLA

Overview

Receive packets from and send commands to TWELITE child devices through the connected TWELITE parent device.

The App_Wings firmware must be written to the TWELITE parent device connected to the host.

Built for Python 3.12+.

Receive packets from

  • App_Twelite
  • App_IO
  • App_ARIA
    • ARIA mode
  • App_CUE
    • CUE mode
    • PAL Event (Move/Dice) mode
  • App_PAL
    • AMBIENT
    • OPENCLOSE (CUE/ARIA OPENCLOSE mode)
    • MOTION
  • App_Uart (Mode A)
    • Simple
    • Extended
  • act

Send commands to

  • App_Twelite (Signals)
  • App_IO (Digital Signals)
  • App_PAL (NOTICE)
    • Simple
    • Detailed
    • Event
  • App_Uart (Mode A)
    • Simple

Installation

The package is available from PyPI.

Use pip

pip install mwings

Or poetry

poetry add mwings

Features

Written with modern python

Modules of the modern python, by the modern python, for the modern python.

  • Fully typed; passes mypy --strict
  • PEP8 compliance; formatted with black and passes ruff check
  • Built with poetry and pyproject.toml
  • numpy-style docstring, everywhere

Great data portability

Received data can be exported easily.

Data classes are derived from pydantic.BaseModel.

Examples

Receive App_Twelite packets

Using Twelite.receive()

Simplest way to receive some parsed packets.

Below script shows how to receive App_Twelite packets in blocking operations.

import mwings as mw


def main() -> None:
    # Create twelite object
    twelite = mw.Twelite(mw.utils.ask_user_for_port())

    # Attach handlers
    @twelite.on(mw.Twelite.Packet.APP_TWELITE)
    def on_app_twelite(packet: mw.parsers.app_twelite.ParsedPacket) -> None:
        print(packet.to_json())

    # Receive packets
    while True:
        print(twelite.receive())


if __name__ == "__main__":
    try:
        main()
    except KeyboardInterrupt:
        print("...Aborting")

Using Twelite.start()

Practical way to receive some parsed packets.

The Twelite class is a subclass of the threading.Thread.

Below script shows how to receive packets in another thread.

import mwings as mw


def main() -> None:
    # Create twelite object
    twelite = mw.Twelite(mw.utils.ask_user_for_port())

    # Attach handlers
    @twelite.on(mw.Twelite.Packet.APP_TWELITE)
    def on_app_twelite(packet: mw.parsers.app_twelite.ParsedPacket) -> None:
        print(packet.to_json())

    # Start receiving
    try:
        twelite.daemon = True
        twelite.start()
        print("Started receiving")
        while True:
            twelite.join(0.5)
    except KeyboardInterrupt:
        print("...Stopping")
        twelite.stop()
        print("Stopped")


if __name__ == "__main__":
    main()

Note that event handlers are not called from the main thread. When you have to use parsed data from the main thread, data should be passed by queue or something.

Send App_Twelite packets

To send packets, just create a command and send it.

Below script shows how to blink an LED on the DO1 port.

from time import sleep
from typing import Any

import mwings as mw


def main() -> None:
    # Create twelite objec
    twelite = mw.Twelite(mw.utils.ask_user_for_port())

    # Create command (initialize in pydantic style)
    initial: dict[str, Any] = {
        "destination_logical_id": 0x78,
        "di_to_change": [True, False, False, False],
        "di_state": [False, False, False, False],
    }
    command = mw.serializers.app_twelite.Command(**initial)

    # Blinking
    while True:
        command.di_state[0] = not command.di_state[0]
        twelite.send(command)
        print(f"Flip DO1: {command.di_state[0]}")
        sleep(1)


if __name__ == "__main__":
    try:
        main()
    except KeyboardInterrupt:
        print("...Aborting")

Note that command data classes (such as mw.serializers.app_twelite.Command) are derived from [pydantic.BaseModel](https://docs.pydantic.dev/latest/api/base_model/#pydantic.BaseModel.

See more advanced examples at mwings_python/examples at main.

LICENSE

MW-OSSLA

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

mwings-1.0.18.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

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

mwings-1.0.18-py3-none-any.whl (44.1 kB view details)

Uploaded Python 3

File details

Details for the file mwings-1.0.18.tar.gz.

File metadata

  • Download URL: mwings-1.0.18.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.12.9 Darwin/24.5.0

File hashes

Hashes for mwings-1.0.18.tar.gz
Algorithm Hash digest
SHA256 852d0c0bed4758451fff5555425c91f0b3d26e867049a1e8afcab2b1d5bacc0f
MD5 8a9ab51179e8a4b3dc7b1f8bff612915
BLAKE2b-256 ffbd53f8f1bc78e316d72bf0c26a4bcb3bb3b23ed1b0abc2301a730ea3543eb7

See more details on using hashes here.

File details

Details for the file mwings-1.0.18-py3-none-any.whl.

File metadata

  • Download URL: mwings-1.0.18-py3-none-any.whl
  • Upload date:
  • Size: 44.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.12.9 Darwin/24.5.0

File hashes

Hashes for mwings-1.0.18-py3-none-any.whl
Algorithm Hash digest
SHA256 9b70cfdbacd25944e0338b1e8b0ddc00b1141afa9439f5b8b78d9881d4f8af7e
MD5 ed8d16913fb1a2d25548e5846c03e6bb
BLAKE2b-256 bd62d9e44c60073244ceb3d95109223c08880f549e3a963ae5645d84229005ca

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