This program provides integration between Rhasspy and Hubitat by listening to the Rhasspy MQTT event service for intents to handle and Hubitat's Maker API app to control the appropriate devices in Hubitat.
This application handles intents triggered by voice queries to Rhasspy such as:
- Tell me the time
- Answers whether the garage doors are closed
- Turn on|off the TV (turns on a virtual switch used by a Hubitat rule to control the TV, AV receiver, and Tivo)
- Set the to low|medium low|medium|medium high|high
- Turn on|off the <light_name>
- Set the <light_name> to percent
- Open|close the shades|blinds
- Turn on|off music
- Play some music genre or playlist
- Turn on channel_name
The last three are not yet implemented, but examples of what can be done.
The intents and entities used must first be defined in the sentences.ini configuration in Rhasspy. The devices you want to control need to be selected in Maker API app in Hubitat.
For initialization, this application makes a call to the Maker API to obtain all device details for later use. This means that the device names used in the Rhasspy sentences.ini config must match (although they can be lower case in sentences.ini).
There is also code to support 2016 and later Samsung TVs connected via Ethernet or WiFi. This allows selecting Samsung applications like Prime Video or Plex server, by lookup of the list of installed apps to find the numeric codes required to select an app (future enhancement).
The following are basic instructions to set up the environment, configure and install the software:
- Setup Rhasspy hardware with a good microphone, computer and speakers. Instructions are at https://rhasspy.readthedocs.io/en/latest/installation/
- A key configuration for Rhasspy is that its MQTT event broker's IP port has to be available on your network so the Python code can listen for intent events. If you are using docker (highly recommended), I have included two docker shell scripts in this repo that set this up (at least for Linux). The only difference between the two is that start-rhasspy.sh is for interactive use where the docker messages come to the console. The other, start-rhasspy-d.sh starts docker as a background process. The latter will likely be how to set up Rhasspy to run whenever your computer boots or restarts.
- Using the Rhasspy web interface, edit the sentences.ini with the items you want to control in Hubitat. An example configuration is in this repository. Be sure to use the exact device names defined in Hubitat. The web interface is accessible via http://ip-address-of-rhasspy:12101.
- Test your Rhasspy system using the web interface's Home view to be sure that the intents are being recognized and variables are being passed as required.
- Install the Maker API app on your Hubitat hub and configure the devices you want to make available for Rhasspy to control or check status on.
- Set up your Python environment to run the integration code. This can be on the same computer that runs Rhasspy. I use pipenv to manage this in a virtual environment, but you can use venv or just pip to install the necessary modules. There are only two modules to install as the rest are automatically installed as dependencies or built-in to Python. The modules are:
- pyhubitat
- rhasspy-hermes-app
Optionally, you can install samsungtvws if you have a Samsung TV and want to read its application codes for switching apps on the TV. If you just want to install everything with pip:
pip install pyhubitat rhasspy-hermes-app
IMPORTANT: The library httpx should be at least version 0.23 as earlier versions have a security vulnerability. Also, the requirements.txt has frozen versions that I originally installed on my PC for development, this file is for reference only.
Next are the steps to download and configure the Python components:
-
If you have git installed, you can clone the software to a local directory on the Rhasspy computer.
-
Create a file called config.py and enter the IP Address and Hub token for Maker API in the format shown in the comments of porcupine.py.
-
You will likely need to open up the firewall for Rhasspy to make the MQTT event service port available to the Python code. For Ubuntu or Raspbian Linux the command is:
sudo ufw allow 12183/tcp
-
You should then be able to launch the Python code with the following:
python3 ./porcupine.py --host localhost --port 12183
This assumes that porcupine is running on the same computer and the MQTT event service port is set to the default 12183.
- Note that this is example code and you will need to modify the porcupine.py code to meet your specific requirements. Some of the intent-handling apps should word as-is, assuming you modify the sentences.ini file to match the device names you have, but some are specific to my environment. The pattern for each intent-handling app is pretty straightforward and just a few lines of code and there is documentation for the rhasspy-hermes-app module at https://rhasspy-hermes-app.readthedocs.io/en/latest/. This will give you additional examples for more complex voice applications.