Skip to main content

API for local communication with LIFX devices over a LAN with asyncio.

Project description

AioLifxC

https://img.shields.io/pypi/v/aiolifxc.svg https://img.shields.io/travis/brianmay/aiolifxc.svg Documentation Status Updates

AioLifxC is a Python 3/asyncio library to control Lifx LED lightbulbs over your LAN.

Most of it was originally taken from the Meghan Clarkk lifxlan package and adapted to Python 3 (and asyncio obviously)

This is a fork from François Wautier’s package. It uses coroutines as opposed to callbacks. If you prefer callbacks, please see his implementation instead. This was forked from version 0.5.0.

This should be considered Alpha status. While it works, and seems to work well, there are still changes I wish to make that may break the API.

Installation

We are on PyPi so:

pip3 install aiolifxc

or:

python3 -m pip install aiolifxc

How to use

In essence, the test program is this:

def readin():
"""Reading from stdin and displaying menu"""

    selection = sys.stdin.readline().strip("\n")
    DoSomething()

loop = aio.get_event_loop()
devices = Devices(loop=loop)

loop.add_reader(sys.stdin, readin)

server = devices.start_discover()

try:
    loop.run_forever()
except Exception as e:
    print("Got exception %s" % e)
finally:
    server.cancel()
    loop.remove_reader(sys.stdin)
    loop.close()

Other things worth noting:

  • Whilst LifxDiscover uses UDP broadcast, the bulbs are connected with Unicast UDP

  • The socket connecting to a bulb is not closed unless the bulb is deemed to have gone the way of the Dodo. I’ve been using that for days with no problem

  • You can select to used IPv6 connection to the bulbs by passing an IPv6 prefix to LifxDiscover. It’s only been tried with /64 prefix. If you want to use a /48 prefix, add “:” (colon) at the end of the prefix and pray. (This means 2 colons at the end!)

  • I only have Original 1000, so I could not test with other types of bulbs

  • Unlike in lifxlan, set_waveform takes a dictionary with the right keys instead of all those parameters

History

0.5.4 (2017-07-07)

Fixed

  • Fix failure to re-register a light that went off-line.

0.5.3 (2017-07-03)

Fixed

  • Fixed FD resource leak in discovery of existing lights.

0.5.2 (2017-07-02)

Changed

  • Significant changes. Improvements to the API. Type hints, doc strings, etc.

0.5.1 (2017-06-26)

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

aiolifxc-0.5.4.tar.gz (26.3 kB view details)

Uploaded Source

Built Distribution

aiolifxc-0.5.4-py2.py3-none-any.whl (28.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file aiolifxc-0.5.4.tar.gz.

File metadata

  • Download URL: aiolifxc-0.5.4.tar.gz
  • Upload date:
  • Size: 26.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for aiolifxc-0.5.4.tar.gz
Algorithm Hash digest
SHA256 2602e631e32d72571f62cf1b21a96d7f7e64796bddd58657b013c8f4595cd847
MD5 cdad3992ce87645952891a6d6608907e
BLAKE2b-256 5958cabb46aa7555d742805480fc50ed128e85f33d9ea5f106363b5752e82d59

See more details on using hashes here.

Provenance

File details

Details for the file aiolifxc-0.5.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for aiolifxc-0.5.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 19a2c2daf61760edbef1a1385487b7764102b3f454107ab47d45c39175a469d1
MD5 bb385c8ae03ac0d9ca9843b9c8d552dc
BLAKE2b-256 f40fe902a23b7c497ddc3433467476e094e2ee03ffda6f9bc43dc7d6d78b2bae

See more details on using hashes here.

Provenance

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