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.7.tar.gz (3.3 MB view details)

Uploaded Source

Built Distribution

mwings-1.0.7-py3-none-any.whl (4.7 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mwings-1.0.7.tar.gz
  • Upload date:
  • Size: 3.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.12.0 Darwin/22.6.0

File hashes

Hashes for mwings-1.0.7.tar.gz
Algorithm Hash digest
SHA256 f8b4de65713f79225d29e000b13d8fe9da3545927f64ee49f22d63b7a36b853c
MD5 fd25688519d9de035cd547e79984351e
BLAKE2b-256 d288e981bac40cbc15f0dc310c1cd6d361b32f8e882d087f72bd523f5b2c96a0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mwings-1.0.7-py3-none-any.whl
  • Upload date:
  • Size: 4.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.12.0 Darwin/22.6.0

File hashes

Hashes for mwings-1.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a821e29233dea7289cb8c0c7422361e13bdc9835b7b4b68bb93f4f703d0c8c5a
MD5 532c74e6db033aacdbab0cd9cecd1292
BLAKE2b-256 0bdde2bbce004dceac26a8a10b2765c2cd1e6f9ca356027f90cca1e5ffdacd92

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