Warning
Please be aware: I am no longer an active user of the underlying products, so my maintenance of this project will be limited.
I’m available for best-effort support, but I won’t be able to test new changes or updates directly. Community contributions are highly encouraged! I’ll do my best to respond to issues and review pull requests, but please expect reduced frequency and no direct testing capacity.
If anyone is interested in taking over as the project maintainer, please don’t hesitate to reach out!
This is an Homebridge plugin. It supports devices (Z-Wave only, Zigbee not supported), scenes, global variables, security systems, climate / heating zones. Exposes them to Homebridge and HomeKit (Apple Home and more).
This plugin comunicates with Fibaro HC / Yubii Home by the official Fibaro API. Homebridge and HC / Yubii Home should be in the same local network with the same IP address range (same subnet), E.G. 192.168.1.XXX.
You must have an account in HC / Yubii Home. The main account has access to all devices, scenes, etc., for additional accounts you can select what to share.
Results will appear in Homebridge and via HomeKit in your Apple Home app (or other HomeKit app).
This plugin can be easily installed through:
-
Homebridge UI
-
via NPM "globally" by typing:
npm install -g homebridge-fibaro-home-center
Configure the plugin through the settings UI or directly in the JSON editor.
config.json example
{
"platforms": [
{
"platform": "FibaroHC",
"name": "FibaroHC",
"url": "192.168.1.100",
"username": "[email protected]",
"password": "your-password",
"pollerperiod": 3,
"markDeadDevices": true,
"thermostattimeout": 7200
"thermostatmaxtemperature": 100,
"switchglobalvariables": "name1,name2,name3"
"dimmerglobalvariables": "name1,name2,name3",
"adminUsername": "admin_name",
"adminPassword": "admin_password",
"securitysystem": "enabled",
"addRoomNameToDeviceName" : "disabled",
"doorbellDeviceId" : 21,
"logsLevel": 1,
"devices": [
{
"id": 42,
"displayAs": "switch",
},
{
"id": 58,
"displayAs": "exclude",
}
]
}
]
}
url
(string) : url or IP of your Home Center / Yubii Home. Using https may be mandatory if you configured HC to use it. Examples:192.168.1.100
- replace with your IP,https://hc-00000XXX.local
- replace with your HC serial, get ca.cer file from HC and put it in Homebridge in same folder as config.json,http://hc-00000XXX.local
- replace with your HC serial.
username
(string) : username of your Home Center / Yubii Home.password
(string) : password of your Home Center / Yubii Home.platform
(string) : platform name, must be 'FibaroHC'.name
(string) : name of the plugin displayed in Homebridge log and as plugin bridge name, default 'FibaroHC'.
pollerperiod
(integer) : Polling interval (refresh interval) for querying Fibaro Home Center (0: disabled, recomended: 3, 1 or 2 seconds allows for a more responsive update of the Home app when changes appear outside the HomeKit environment). If it is disabled the Home app is not updated automatically when such a change happen but only when you close a panel and reopen it. Enabling this option is useful to read the new state when controlling devices outside HomeKit, E.G.: via Fibaro, physical buttons, scenes and automations.markDeadDevices
(boolean) : Show dead devices as not responding in HomeKit. Dead devices are devices that have connection problems and in the Fibaro hub selected option to mark such devices. Warning: Not responding device in HomeKit can break automation, it is recommended to place such device in a separate automation.thermostatmaxtemperature
(integer) : Set max temperature for thermostatic devices (default 100 C).thermostattimeout
(integer) : Number of seconds for the thermostat timeout, default: 7200 (2 hours).switchglobalvariables
(string) : Comma separated list of home center global variables names acting like a bistable switch.dimmerglobalvariables
(string) : Comma separated list of home center global variables names acting like a dimmer.adminUsername
(string) : Admin username of your home center, needed only to set global variables.adminPassword
(string) : Admin password of your home center, needed only to set global variables.securitysystem
(string) : Set 'enabled' or 'disabled' in order to manage the availability of the security system.addRoomNameToDeviceName
(string) : Set 'enabled', 'enabledBefore' or 'disabled'. If enabled, to each device name will be added the name of the room in which it is located. Warning: changing this may cause that some of your devices will be removed and add as new.doorbellDeviceId
(integer) : Home Center binary sensor device id acting as a doorbell.logsLevel
(integer) : Desired log level: 0 disabled, 1 only changes, 2 all.
id
: Device ID (like: 42).displayAS
: Display as: switch, dimmer, etc. or exclude device.
Exclude devices
Exclude one or more devices:
- add id of this device in plugin settings and select display as: 'exclude'
- or in Fibaro panel use a specific user (not an admin one) and grant access to only the needed devices
- or in Fibaro panel rename the device you want to exclude with an initial _ character.
Warning: If you exclude the device, adding it again may require reconfiguration (assignment to a room, automations, etc.).
Scenes
- Any scene with a name that start with _ (in Fibaro panel) will be added to HomeKit as a momentary switch
- Switch name will be same as scene name but without the _.
- Momentary switch means that it will turn off itself after a while.
Global variables
- Switch global variables - It is possible to create Switch in HomeKit with a toggle behaviour:
- creating global variables (one for each switch) with 2 possible values: "true" and "false"
- configuring a new parameter ("switchglobalvariables") in config.json that contains a comma separated list of the variable names you defined.
- Dimmer global variables - It is possible to create Dimmer in HomeKit with a toggle behaviour:
- creating global variables (one for each dimmer) with possible values from 0 to 100
- configuring a new parameter ("dimmerglobalvariables") in config.json that contains a comma separated list of the variable names you defined.
- You can use these variable to trigger Home Center scenes.
- Note: you need to configure homebridge in config.json with a user with superuser privileges because normal users cannot set global variable from the outside of Home Center.
Security System
-
Enable security system in plugin settings or in config.json add the parameter:
"securitysystem": "enabled"
-
In Fibaro Home Center:
-
Create an Enumerated variable named
SecuritySystem
with the following values:StayArmed
AwayArmed
NightArmed
Disarmed
AlarmTriggered
-
Create the following Alarm Zones in the Alarm Zones panel in the settings section (order is important): . StayZone . AwayZone . NightZone
-
For each security zone select the appropriate sensors.
-
Create a
SetAlarmTriggered
scene in the Alarm Scenes panel in the settings section that set the SecuritySystem variable toAlarmTriggered
. The scene can also contain action logic to manage the alarm, eg: activate a siren. -
Create a scene for setting arming status of devices and update the previous global variable. Scene names and code MUST be:
- SetStayArmed:
fibaro.alarm("disarm") fibaro.alarm(1, "arm") fibaro.setGlobalVariable("SecuritySystem", "StayArmed")
- SetAwayArmed
fibaro.alarm("disarm") fibaro.alarm(2, "arm") fibaro.setGlobalVariable("SecuritySystem", "AwayArmed")
- SetNightArmed
fibaro.alarm("disarm") fibaro.alarm(3, "arm") fibaro.setGlobalVariable("SecuritySystem", "NightArmed")
- SetDisarmed
fibaro.alarm("disarm") fibaro.setGlobalVariable("SecuritySystem", "Disarmed")
- SetStayArmed:
-
Scene must have flag
Do not stop scene when alarm breached
checked, in recent versions it'sAllow to run when alarm breached
.
-
Climate / Heating zones
- Thermostat Controls: once a climate / heating zone is created in the Home Center / Yubii Home, a corresponding Thermostat accessory is generated in HomeKit. The Thermostat accessory provides intuitive controls within the HomeKit ecosystem.
- Manual Settings and Timeout: the controls available on the Thermostat activate a manual setting for the specified duration. This duration is set by the
thermostattimeout
parameter in theconfig.json
file. During this period, the manual settings remain in effect for the zone. After the predefined timeout period expires, the normal schedule of the zone is automatically reactivated. This ensures that the zone reverts to its programmed schedule once the manual setting duration elapses.
Child bridge mode
It is recomended to run this plugin as child bridge, there are several reasons and benefits of doing this:
- greater security because it is a separate, isolated process,
- every instance / bridge can expose maximum 150 accessories due to a HomeKit limit, so if you have other plugins and don't use child bridge, you share this limit with them.
Details: https://github.com/homebridge/homebridge/wiki/Child-Bridges.
The device is displayed incorrectly or doesn't display at all
- If device displays incorrectly (e.g. as Switch but should be Outlet) or doubled (one device is displayed as two), you must remove this device from cache (in Homebridge Settings). Unfortunately, in this case, the settings for this device will most likely be lost (room selection, automations, etc.).
- Every change of devices display type (e.g. from Switch to Outlet etc.) can make it display incorrectly (like doubled). It is recommended to turn off Apple hubs during changes.
Get API response for device
- Open in browser: http://FIBARO-IP/api/devices/DEVICE-ID (replace FIBARO-IP with your Home Center IP and DEVICE-ID with device ID) and login.
- Device ID you can check in Fibaro panel or directly in HomeKit device information (serial number field).
- Most important values are: type, baseType, deviceControlType and deviceRole.
API response example:
{
"id": 114,
"name": "Bedroom",
"roomID": 226,
"view": [
{
"assetsPath": "dynamic-plugins/com.fibaro.binarySwitch",
"name": "com.fibaro.binarySwitch",
"translatesPath": "/assets/i18n/com.fibaro.binarySwitch",
"type": "ts"
}
],
"type": "com.fibaro.binarySwitch",
"baseType": "com.fibaro.actor",
"enabled": true,
"visible": true,
"isPlugin": false,
"parentId": 110,
"viewXml": false,
"hasUIView": true,
"configXml": false,
"interfaces": [
"zwave",
"zwaveMultiChannelAssociation",
"zwaveProtection"
],
"properties": {
"parameters": [
{
"id": 1,
"lastReportedValue": 1,
"lastSetValue": 1,
"size": 1,
"value": 1
},
{
"id": 20,
"lastReportedValue": 0,
"lastSetValue": 0,
"size": 1,
"value": 0
}
],
"pollingTimeSec": 0,
"zwaveCompany": "Fibargroup",
"zwaveInfo": "3,6,4",
"zwaveVersion": "5.0",
"RFProtectionState": 0,
"RFProtectionSupport": 3,
"categories": [
"other"
],
"configured": true,
"dead": false,
"deadReason": "",
"deviceControlType": 1,
"deviceIcon": 2,
"deviceRole": "Other",
"endPointId": 2,
"icon": {
"path": "/assets/icon/fibaro/onoff/onoff0.png",
"source": "HC"
},
"localProtectionState": 0,
"localProtectionSupport": 5,
"log": "",
"logTemp": "",
"manufacturer": "",
"markAsDead": true,
"model": "",
"nodeId": 18,
"parametersTemplate": "874",
"productInfo": "1,15,2,4,16,0,5,0",
"protectionExclusiveControl": 0,
"protectionExclusiveControlSupport": false,
"protectionState": 0,
"protectionTimeout": 0,
"protectionTimeoutSupport": false,
"saveLogs": true,
"serialNumber": "h'0000000000001f16",
"state": false,
"supportedDeviceRoles": [
"Light",
"Drencher",
"Pin",
"NightLamp",
"Kettle",
"Bracket",
"AirConditioner",
"AlarmAlarm",
"Coffee",
"GardenLamp",
"TvSet",
"CeilingFan",
"Toaster",
"Radio",
"RoofWindow",
"Other",
"AlarmState",
"AlarmArm",
"VideoGateBell",
"VideoGateOpen",
"Valve"
],
"useTemplate": true,
"userDescription": "",
"value": false
},
"actions": {
"reconfigure": 0,
"toggle": 0,
"turnOff": 0,
"turnOn": 0
},
"created": 1650223230,
"modified": 1717098148,
"sortOrder": 93
}
More logs
If you have any issues with this plugin, enable all logs in plugin config and the debug mode in the Homebridge settings and restart the Homebridge / child bridge. This will show additional information in log.
Fibaro HC2 Lite issues
- Update firmware to the newest version, at least 4.630
- Remove from the box (it overheats).
- Replace the battery.
- Disable remote access. The API works locally, so it will not affect the operation of the plugin, but the Fibaro application will not work when you are offline.
- If any of the above does not help, it may be necessary to call support or visit the service and replace some parts.
Feel free to create Issue or Pull Request
- This is not the official Fibaro plugin but it uses the official Fibaro API.
- Despite the efforts made, the operation of the plugin is without any guarantees.
- All actions are at your own risk.
- All product and company names are trademarks™ or registered® trademarks of their respective holders. Use of them does not imply any affiliation with or endorsement by them.
- Added support for radiator thermostatic valves ("com.fibaro.thermostatDanfoss", "com.fibaro.FGT001").
- Fix issues #520, #521, #522
- Dependencies updates.
- Fixed issues #507, #508, #509, #510
- Dependencies updates.