Homebridge platform plugin for FRITZ!Box.
This plugin exposes:
- WLAN guest access switch
- Fritz!DECT outlets (200, 210)
- Fritz!Powerline outlets (510, 540)
- Fritz!DECT (300, 301) and Comet!DECT thermostats
- Fritz!DECT (400) buttons
- Fritz!DECT repeaters as temperature sensor (100)
- Window sensors including HAN FUN devices e.g. of Deutsche Telekom
Follow the homebridge installation instructions at homebridge.
Install this plugin globally:
npm install -g homebridge-fritz
Add platform to config.json
, for configuration see below.
{
"platforms": [
{
"platform": "Fritz!Box",
"name": "My FritzBox",
"username": "<username>",
"password": "<password>",
"url": "http://fritz.box",
"interval": 60,
"concurrent": true,
"devices": {
"wifi": {
"name": "Guest WLAN",
"display": true
},
"outlet-1": {
"TemperatureSensor": false
},
"repeater-1": {
"TemperatureSensor": false
},
"thermostat-2": {
"ContactSensor": false
},
"hidden-3": {
"display": false
}
},
"options": {
"strictSSL": false
}
}
]
}
The following settings are optional:
url
: Fritz!Box addressinterval
: polling interval for updating accessories if state was changed outside homebringeconcurrent
: set tofalse
to avoid concurrent api requests. May work more stable on older FRITZ!Boxes but has slower performancedevices
: detailed configuration for individual devices. To be uniquely addressable, each device uses itsAIN
as key. The guest wifi device is always calledwifi
. Supported device configuration options are:display: false
to disable the device, e.g. useful for main wifiinvert: true
to invert open/closed behaviour ofContactSensor
ContactSensor: false
to disable the thermostat's open windowContactSensor
TemperatureSensor: false
to disable the temperature sensors for outlets or repeaters- the
wifi
device additionally supports thename
option for setting a custom name for the wifi guest access switch
-
Can't login to the FritzBox
Some users have reported that logging into the FritzBox internally via
https
fails. This seems to be caused by the FritzApp occupying the same port. In this case you can connect internally viahttp
or use the external IP.Fritz!Box platform login failed
messages can be caused by invalid login data or wrong url.Log messages if the form of:
{ error: { [Error: self signed certificate] code: 'DEPTH_ZERO_SELF_SIGNED_CERT' }
indicate that there are SSL security problems- most likely due to self-signed certificates. Use the
"strictSSL": false
option to disable the respective check. -
Unable to update my thermostat
Current FritzBox firmwares seem to ignore API updates when the thermostat has been key-locked. No workaround available- please contact AVM to change this behaviour or don't use the locking mechanism.
-
Unable to update thermostat battery charge
Battery charge is not an API function. That means that the user must have access to FritzBox administration, not only to the SmartHome API in order to use this functionality. Update your Fritz!Box user accordingly.
-
Can't toggle guest wifi
Updating guest wifi state requires both a FritzBox username, password and in some cases an https/ssl connection to the FritzBox. If you use the
password only
option (System > FritzBox Users > Login method) of the FritzBox, make sure you provide any random username value at the"username"
parameter, otherwise401 - unauthorized
errors may occur. -
Tips for using thermostat with Home App modes and scenes
When scenes are used in the Home App, a target temperature have to be set. There are the modes Off and On.
- Off - Switches off the thermostat
- On - Set the selected temperature
- Depending on the target and actual temperature, Homekit shows the thermostat as "cooling" or "heating"
If you experience problems with this plugin please provide a homebridge logfile by running homebridge with debugging enabled:
homebridge -D
For even more detailed logs set "debug": true
in the platform configuration.
- homebridge-fritz is based on the fritzapi library
- Original non-working fritz accessory https://github.com/tommasomarchionni/homebridge-FRITZBox
- Platform implementation inspired by https://github.com/rudders/homebridge-platform-wemo.