Skip to content

Latest commit

 

History

History
101 lines (66 loc) · 4.08 KB

README.md

File metadata and controls

101 lines (66 loc) · 4.08 KB

libcbus

Build Status Coverage Status

Talks to Clipsal C-Bus using Python 3.7+.

Copyright 2012-2020 Michael Farrell. Licensed under the GNU LGPL3+. For more details see COPYING and COPYING.LESSER.

Note: This software is not certified or endorsed by Clipsal or Schneider Electric. Clipsal claim that use of C-Bus with non-Clipsal hardware or software may void your warranty.

More information about the project is available on the libcbus ReadTheDocs site, and in the docs directory of the source repository.

About this project

This is a reimplementation of the PCI serial protocol from scratch. This is done using a combination Clipsal's Open C-Bus documentation and reverse engineering (to fill in the gaps).

Unlike some contemporary alternatives, it does not use the libcbm library/DLL from Clipsal, or C-Gate, which have serious problems:

  • The libcbm module only runs on x86_32 systems, and is only available as a static library (closed source).

  • C-Gate requires an OS and architecture specific closed source serial library (SerialIO), the Java runtime, and itself has various licensing restrictions.

As such, it should run on any Python supported platform. The software itself has been primarily developed on Linux with on armhf, x86_32 and x86_64 systems.

At a high level, this project includes cmqttd, a daemon to bridge a C-Bus PCI to an MQTT Broker. cmqttd supports Home Assistant's MQTT Light model and MQTT topic auto-discovery.

Integration with Hass.io is still a work in progress.

Hardware interface support

This should work with the following C-Bus PC Interfaces (PCIs):

Recent updates (2020-02-22)

This project has recently completed a migration to Python 3.7.

Most things should work, but I'm still going through updating all the documentation properly.

There are many backward-incompatible changes:

  • This only supports Python 3.7 and later.

  • Python 2.x support has been entirely removed, as Python 2 has been sunset as of 2020.

    Python 3.6 and earlier support is not a goal. We want to use new language features!

  • D-Bus is no longer used by this project:

    • cmqttd (C-Bus to MQTT bridge) replaces cdbusd (C-Bus to D-Bus bridge).

    • dbuspcid (virtual PCI to D-Bus bridge) has been removed. It has no replacement.

  • sage (libcbus' web interface) and staged (scene management system) have been removed. cmqttd supports Home Assistant's MQTT Discovery schema.

    This allows libcbus to reduce its scope significantly -- Home Assistant can interface with much more hardware than C-Bus, and has a large community around it.

  • This no longer uses Twisted -- asyncio (in the standard library) is used instead.

Many APIs have changed due to refactoring, and is subject to further change without notice. The most stable API is via MQTT (cmqttd).