Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/luc-ass/homebridge-evohome

Homebridge plugin for Honeywell Evohome
https://github.com/luc-ass/homebridge-evohome

homebridge homebridge-plugin homekit honeywell-evohome verified-by-homebridge

Last synced: 5 days ago
JSON representation

Homebridge plugin for Honeywell Evohome

Awesome Lists containing this project

README

        

![Honeywell Evohome Controller](assets/honeywell_round.png)ย ย 
![Honeywell Evohome Controller](assets/TCC_EMEA.png)ย ย 
![Honeywell Evohome Controller](assets/honeywell_evohome.png)

# Honeywell Evohome support for Homebridge
![npm](https://img.shields.io/npm/dt/homebridge-evohome?logo=npm)
![npm](https://img.shields.io/npm/dw/homebridge-evohome?logo=npm)
![npm](https://img.shields.io/npm/v/homebridge-evohome?logo=npm)
[![verified-by-homebridge](https://badgen.net/badge/homebridge/verified/purple)](https://github.com/homebridge/homebridge/wiki/Verified-Plugins)

This ia a plugin to integrate [Honeywell Evohome](https://getconnected.honeywellhome.com/de/thermostate/evohome) into Apple HomeKit. It is work in progress. Help is greatly appreciated!

Up until now this plugin will only add your Thermostats and central functions (for example "ECO") to Homebridge. Other devices such as domestic hot water will probably follow in the future once we can wrap our heads arround it (and have someone to test it out).

## ๐Ÿš€ Getting Started

**Homebridge with [Config UI X](https://github.com/oznu/homebridge-config-ui-x):**
1. Go to the "Plugins" tab and search for `homebridge-evohome`
2. Install the plugin and fill out the setup form

**Terminal / NPM:**
1. Install this plugin using `npm install -g homebridge-evohome@latest`
2. Update your configuration file ([sample-config below](https://github.com/luc-ass/homebridge-evohome#%EF%B8%8F-configuration))

## โš™๏ธ Configuration

Configuration sample:

```json
"platforms": [
{
"platform": "Evohome",
"name" : "Evohome",
"username" : "username/email",
"password" : "password",
"temperatureUnit" : "Celsius",
"locationIndex" : "0"
}
]
```

| Parameter | optional | accepted values | info |
| :-- | :-- | :-- | :-- |
| `platform` | no | `Evohome` | |
| `name` | no | *any Name you want* | |
| `username` | no | *your Honeywell email adress* | |
| `password` | no | *your Honeywell password* | |
| `temperatureUnit` | yes | `Celsius`, `Fahrenheit` | defaults to `Celsius` |
| `locationIndex` | yes | `0`, `1`, `2`, etc. | only needed if you have multiple locations |
| `switchAway` | yes | `true`, `false` | creates a switch for away mode |
| `switchDayOff` | yes | `true`, `false` | creates a switch for day off mode |
| `switchEco` | yes | `true`, `false` | creates a switch for eco settings |
| `switchHeatingOff` | yes | `true`, `false` | creates a switch to tur off the heating |
| `switchCustom` | yes | `true`, `false` | creates a switch for your custom mode |
| `childBridge` | yes | `true`, `false` | allows you to have persistent accessories, if plugin is run inside a child bridge |
| `temperatureAboveAsOff` | yes | `true`, `false` | allows you to displays thermostats as off, if room temperature is above target temperature |

## ๐Ÿ“ Roadmap

- [x] Get device names
- [x] Read temperature
- [x] Update temperature
- [x] Set target temperature (credits to @zizzex)
- [x] Change temperature until next scheduled event (credits to @fredericvl). This feature sets the temperature until the next scheduled event on the same day. If there is no event on the same day it will be scheduled until 00:00:00. As this is a new feature it contains advanced logging. Please post your log if you encounter any problems.
- [x] Make use of Elgato Eve graphs (using fakegato-history) including automatic updating (credits to @rooi)
- [x] Add "global device" to add Away/Energy saving etc. (credits to @fredericvl)
- [x] Add support for multiple locations. (credits to @ebarnard)
- [x] Add support for Honeywell Round Connected
- [ ] Add "DOMESTIC_HOT_WATER" with matching characteristics. This device will now be ignored to prevent errors (credits to @sOckhamSter).

## โš ๏ธ Known Issues & Notes

- System time/time zone must be the same as the time on your evohome controller or else schedules will work in unexpected ways.
- Your password may not contain `&` or else the login will fail.
- Updating from `<0.5.1` to `>0.6.0` will create new devices and put them into the standard room of your home. They just need to be moved back to their rooms. This is expected behaviour as the UUID has changed. Historic data will be retained. This can also happen without a clear cause. It is under investigation here: [#61](../../issues/61).

## ๐Ÿงช Beta Testing

This part talks about testing pre-release version of the plugin. I strongly recommend, that you don't do this in your production environment. It will frequently reset accessories and break automations. If you still want to or have been asked to, this is my preferred way of installing from github:

In Homebridge Config UI X Terminal:

```sh
# go to node module directory
cd node_modules
# remove homebridge-evohome and contents
rm -r homebridge-evohome
# recreate the folder
mkdir homebridge-evohome
# clone repo to folder
git clone --single-branch --branch main https://github.com/luc-ass/homebridge-evohome.git ./homebridge-evohome
# cd into folder
cd homebridge-evohome
# install plugin
npm install
```
Now restart Homebridge