Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ironsheep/omega2-garagedoors-mqtt2ha-daemon
Linux service providing garage door control on Onion Omega2+ device with data sent via MQTT to Home Assistant
https://github.com/ironsheep/omega2-garagedoors-mqtt2ha-daemon
home-automation homeassistant mqtt-client omega2 omega2-expansion
Last synced: 23 days ago
JSON representation
Linux service providing garage door control on Onion Omega2+ device with data sent via MQTT to Home Assistant
- Host: GitHub
- URL: https://github.com/ironsheep/omega2-garagedoors-mqtt2ha-daemon
- Owner: ironsheep
- License: gpl-3.0
- Created: 2020-07-29T02:02:51.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-08-15T10:55:34.000Z (over 4 years ago)
- Last Synced: 2024-05-01T14:00:48.434Z (8 months ago)
- Topics: home-automation, homeassistant, mqtt-client, omega2, omega2-expansion
- Language: Python
- Homepage:
- Size: 1.04 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
README
# Omega2 GarageDoors MQTT2HA Daemon
![Project Maintenance][maintenance-shield]
[![GitHub Activity][commits-shield]][commits]
[![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
A simple Python script which is an MQTT sender/listener providing twin switches (left and right garage doors) via [MQTT](https://projects.eclipse.org/projects/iot.mosquitto) to your [Home Assistant](https://www.home-assistant.io/) installation.
This script should be configured to be run in **daemon mode** continously in the background as a System-V init script. (using instructions/scripts provided)
--
**This is a work in progress!**
(*this marker will be removed once the full system is working and code is committed to this repo*)
--
# Project Hardware
![Omega2+ and as seen in HA](./DOCs/images/HardwareDiscovery.png)
This is the [onion Omega2+](https://onion.io/store/omega2p) mounted on an [Expansion Dock](https://onion.io/store/expansion-dock/) with the (dual) relay exapnsion *which they no longer sell* but can still be found in their [Maker Kit](https://docs.onion.io/omega2-maker-kit/)
## Features
* Registers two garage door controls with Home Assistant
* Tested on Omega2+ v0.3.2 b244 running OpenWrt v4.14.81
* Tested with Home Assistant v0.111.0
* Tested with Mosquitto broker v5.1
* Data is published via MQTT
* MQTT discovery messages are sent so this controller is automatically registered with Home Assistant (if MQTT discovery is enabled in your HA installation)
* MQTT authentication support### Omega2+ Device MQTT Discovery
The Omega2 Garage Door device is reported as:
| Name | Description |
|-----------------|-------------|
| `Manufacturer` | Onion Corporation |
| `Model` | Omega2+ |
| `Name` | GarageDoor Controller |
| `sofware ver` | Name, Version (e.g., v0.3.2 b233) |### Omega2+ MQTT Topics
The Omega2 Garage Door device exposes a number of topics:
| Name | Device Class | Units | Description
|-----------------|-------------|-------------|-------------|
| `~/left` | 'timestamp' | n/a | Is a timestamp which shows when the Omega last sent information, carries a template payload conveying all monitored values (attach the lovelace custom card to this sensor!)
| `~/right` | 'timestamp' | n/a | Is a timestamp which shows when the Omega last sent information, carries a template payload conveying all monitored values (attach the lovelace custom card to this sensor!)## Prerequisites
An MQTT broker is needed as the counterpart for this daemon.
MQTT is huge help in connecting different parts of your smart home and setting up of a broker is quick and easy. In many cases you've already set one up when you installed Home Assistant.
## Installation
On OpenWrt just a few steps are needed to get the daemon working.
To begin installation we need to find the latest released version of this script. Visit our [releases page](https://github.com/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon/releases) to find the latest release. Copy the Link Address of the file you want to use for install (.zip or .tar.gz file)
The following example shows the installation below the `/opt` directory:
```shell
# make sure we have python3 installed
opkg install python3 python3-pip python3-relay-exp# go to home directory
cd# download the file
wget {the link address you copied}# make our /opt directory if not already present
mkdir /opt# move to new directory
cd /opt# unpack the release file just downloaded
tar -xzvf /root/{filename}.tar.gz
(or) unzip /root/{filename}.zip# this installed our files in /opt/Omega2-GarageDoors-MQTT2HA-Daemon, go there
cd /opt/Omega2-GarageDoors-MQTT2HA-Daemon# and install our extra python support
pip3 install -r requirements.txt
```## Configuration
To match personal needs, all operational details can be configured by modifying entries within the file [`config.ini`](config.ini.dist).
The file needs to be created first:```shell
cp /opt/Omega2-GarageDoors-MQTT2HA-Daemon/config.{ini.dist,ini}
vim /opt/Omega2-GarageDoors-MQTT2HA-Daemon/config.ini
```You will likely want to locate and configure the following (at a minimum) in your config.ini:
```shell
# ...
hostname = {your-mqtt-broker}# ...
base_topic = {your home-assistant base topic}# ...
username = {your mqtt username if your setup requires one}
password = {your mqtt password if your setup requires one}```
Now that your config.ini is setup let's test!
## Execution
### Initial Test
A first test run is as easy as:
```shell
python3 /opt/Omega2-GarageDoors-MQTT2HA-Daemon/ISP-GarageDoor-mqtt-daemon.py
```**NOTE:** *it is a good idea to execute this script by hand this way each time you modify the config.ini. By running after each modification the script can tell you through error messages if it had any problems with any values in the config.ini file, or any missing values. etc.*``
Using the command line argument `--config`, a directory where to read the config.ini file from can be specified, e.g.
```shell
python3 /opt/Omega2-GarageDoors-MQTT2HA-Daemon/ISP-GarageDoor-mqtt-daemon.py --config /opt/Omega2-GarageDoors-MQTT2HA-Daemon
```### Configure to run script at startup
Now we need to configure our system service. OpenWrt uses the SysV init script convention so let's set this up.
**NOTE:** Daemon mode must be enabled in the configuration file (default).
#### Run as Sys V init scriptIn this form our wrapper script located in the /etc/init.d directory and is run according to symbolic links in the `/etc/rc.x` directories.
Set up the script to be run as a Sys V init script as follows:
```shell
ln -s /opt/Omega2-GarageDoors-MQTT2HA-Daemon/gardoors-daemon /etc/init.d/gardoors-daemon# configure system to start this script at boot time
/etc/init.d/gardoors-daemon enable# let's start the script now, too so we don't have to reboot
/etc/init.d/gardoors-daemon start
# check to make sure all is ok with the start up
/etc/init.d/gardoors-daemon status # look for "Running" vs. "NOT Running"
```### Update to latest
Like most active developers, we periodically upgrade our script.
To begin installation we need to find the latest released version of this script. Visit our [releases page](https://github.com/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon/releases) to find the latest release. Copy the Link Address of the file you want to use for install (.zip or .tar.gz file)
The following example shows the installation below the `/opt` directory:
```shell
# go to home directory
cd# download the file
wget {the link address you copied}
```Now You can update to the latest by following these steps:
```shell
# stop the service
/etc/init.d/gardoors-daemon stop
# disable it in-case we change the Start/Stop numbers
/etc/init.d/gardoors-daemon disable
# move to installed options directory
cd /opt# move our existing directory out of the way
mv Omega2-GarageDoors-MQTT2HA-Daemon Omega2-GarageDoors-MQTT2HA-Daemon-old# unpack the latest release file just downloaded
tar -xzvf /root/{filename}.tar.gz
(or) unzip /root/{filename}.zip# this installed our updated files in /opt/Omega2-GarageDoors-MQTT2HA-Daemon, go there
cd /opt/Omega2-GarageDoors-MQTT2HA-Daemon
# (this makes sure our new files arrived in desired location)
# re-enable the service
/etc/init.d/gardoors-daemon enable
# restart the service with your new version
/etc/init.d/gardoors-daemon start# check status of the running script
/etc/init.d/gardoors-daemon status # look for "Running" vs. "NOT Running"
# if the status looks good then remove the older isntall directory
rm -rf /opt/Omega2-GarageDoors-MQTT2HA-Daemon-old```
## IntegrationWhen this script is running data will be published to the (configured) MQTT broker topic "`dvc-{hostname}/...`" (e.g. `dvc-picam01/...`).
**NOTE:** Where there's an IP address that interface is connected.
This data can be subscribed to and processed by your home assistant installation.
## Credits
Thank you to Thomas Dietrich for providing a wonderful pattern for this project. His project, which I use and heartily recommend, is [miflora-mqtt-deamon](https://github.com/ThomDietrich/miflora-mqtt-daemon)
---
## Disclaimer and Legal
> *Omega2+* is a product offered by *Onion Corporation*
>
> This project is a community project not for commercial use.
> The authors will not be held responsible in the event of device failure or simply errant reporting/control of your garage doors, doggie doors or whatever doors you choose to control with this script.
>
> This project is in no way affiliated with, authorized, maintained, sponsored or endorsed by *Onion Corporation* or any of its affiliates or subsidiaries.---
### [Copyright](copyright) | [License](LICENSE)
[commits-shield]: https://img.shields.io/github/commit-activity/y/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon.svg?style=for-the-badge
[commits]: https://github.com/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon/commits/master[license-shield]: https://img.shields.io/github/license/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon.svg?style=for-the-badge
[maintenance-shield]: https://img.shields.io/badge/maintainer-S%20M%20Moraco%20%40ironsheepbiz-blue.svg?style=for-the-badge
[releases-shield]: https://img.shields.io/github/release/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon.svg?style=for-the-badge
[releases]: https://github.com/ironsheep/Omega2-GarageDoors-MQTT2HA-Daemon/releases