Skip to main content

Official Python stack for xAAL protocol

Project description

xaal.lib is the official Python stack to develop home-automation devices and gateways with the xAAL protocol. For a full description of the protocol check out http://recherche.imt-atlantique.fr/xaal/

Dependencies

xaal.lib depends on :
  • cbor2

  • pysodium

  • configobj

  • coloredlogs

  • decorator

  • tabulate

  • aioconsole

Install

Please refer to the official full documentation to install the lib in a virtualenv

Usage

The main goal of xaal.lib is to provide an API to easily develop devices & gateways. xaal.lib.Engine send / receive / parse to|from xAAL Bus.

To receive / parse / display incoming xAAL messages, you can simply try something like this:

from xaal.lib import Engine, Message

def display(msg: Message):
    print(msg)

eng = Engine()
eng.subscribe(display)
eng.disable_msg_filter()
eng.run()

The Engine will call the display function every time it receive a xAAL message.

Let’s take a look at a simple lamp device :

from xaal.lib import Device,Engine,tools

# create and configure the lamp device, with a random address
dev = Device("lamp.basic", tools.get_random_uuid())
dev.product_id = 'Dummy Lamp'
dev.url  = 'http://www.acme.org'
dev.info = 'My fake lamp'

# add an xAAL attribute 'light'
light = dev.new_attribute('light')

# declare two device methods ON & OFF
def on():
    light.value = True

def off():
    light.value = False

dev.add_method('turn_on',on)
dev.add_method('turn_off',off)

# last step, create an engine and register the lamp
eng = Engine()
eng.add_device(dev)
eng.run()

To avoid to rewrite the same code for each device, you can use the xaal.schemas package. This package provides a set of predefined devices, you can use them as a template to create your own device.

from xaal.schemas import devices
from xaal.lib import Engine

# create and configure the lamp device
dev = devices.lamp()

# last step, create an engine and register the lamp
eng = Engine()
eng.add_device(dev)
eng.run()

FAQ

The core engine run forever so how can I use it in webserver, GUI or to develop device with IO. The whole API is absolutely not thread safe, so don’t use threads unless you exactly know what’s going on. Anyways, you have several options to fix this issue:

  • You can use you own loop and periodically call eng.loop() for example, you can do something like this:

    while 1:
        do_some_stuff()
        eng.loop()
  • You can use a engine timer, to perform some stuff.

    def read_io():
        pass
    
    # call the read_io function every 10 sec
    eng.add_timer(read_io,10)
    eng.run()
  • Use the AsyncEngine. Python version > 3.8 provides async programming with asyncio package. AsyncEngine use the same API as Engine, but it is a asynchronous engine. You can use coroutines in device methods, timers functions and callbacks. It provides additionals features like the on_start and on_stop callbacks.

  • Use an alternate coroutine lib, you can use gevent or greenlet for example. Look at apps/rest for a simple greenlet example.

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

xaal_lib-0.8.1.tar.gz (32.2 kB view details)

Uploaded Source

Built Distribution

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

xaal_lib-0.8.1-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

Details for the file xaal_lib-0.8.1.tar.gz.

File metadata

  • Download URL: xaal_lib-0.8.1.tar.gz
  • Upload date:
  • Size: 32.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for xaal_lib-0.8.1.tar.gz
Algorithm Hash digest
SHA256 e3397aec6550b2225572fe16e96bfb7b2eb273b8a4c33d4f79073b34091fdc51
MD5 5d3f45a15cc9f081cd5c03f77becbc17
BLAKE2b-256 0d01c2e044955ea52148ff4dbdf633a98f5c3877be4cdc5cbcb9128c0181514c

See more details on using hashes here.

File details

Details for the file xaal_lib-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: xaal_lib-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 32.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for xaal_lib-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 144400bd7720d4a828e75c2aa3ad245d30414fd2c63384909b73d4a66ea40d52
MD5 e8069a64feaec5b31544760122e89399
BLAKE2b-256 1c7cc9253b1054f1add4f3318ca1409b5b1bce8dc009f7c54655e6b0b0c2980a

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