From 839a64edd0671dc27764596299cd2b1e73cdfcd1 Mon Sep 17 00:00:00 2001 From: Eugen Freiter Date: Sat, 6 Mar 2021 10:28:19 +0100 Subject: [PATCH 1/2] make usage of mDNS configurable Signed-off-by: Eugen Freiter --- .../io/homekit/internal/HomekitImpl.java | 35 +++++++++++-------- .../io/homekit/internal/HomekitSettings.java | 3 ++ .../main/resources/OH-INF/config/config.xml | 14 ++++++-- 3 files changed, 34 insertions(+), 18 deletions(-) diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java index 25c39f6f388eb..c4d051234221c 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java @@ -145,7 +145,8 @@ protected synchronized void modified(Map config) { HomekitSettings oldSettings = settings; settings = processConfig(config); changeListener.updateSettings(settings); - if (!oldSettings.networkInterface.equals(settings.networkInterface) || oldSettings.port != settings.port) { + if (!oldSettings.networkInterface.equals(settings.networkInterface) || oldSettings.port != settings.port + || oldSettings.useOHmDNS != settings.useOHmDNS) { // the HomeKit server settings changed. we do a complete re-init stopHomekitServer(); startHomekitServer(); @@ -205,23 +206,27 @@ private void startBridge() throws IOException { private void startHomekitServer() throws IOException { if (homekitServer == null) { - if ((settings.networkInterface == null) || (settings.networkInterface.isEmpty())) { - logger.trace( - "No IP address configured in homekit settings. HomeKit will use the first configured address of openHAB"); - homekitServer = new HomekitServer(mdnsClient.getClientInstances().iterator().next(), settings.port); - } else { - networkInterface = InetAddress.getByName(settings.networkInterface); - for (JmDNS mdns : mdnsClient.getClientInstances()) { - if (mdns.getInetAddress().equals(networkInterface)) { - logger.trace("suitable mDNS client for IP {} found. Reusing it.", networkInterface); - homekitServer = new HomekitServer(mdns, settings.port); + if (settings.useOHmDNS) { + if ((settings.networkInterface == null) || (settings.networkInterface.isEmpty())) { + logger.trace( + "No IP address configured in HomeKit settings. HomeKit will use the first configured address of openHAB"); + homekitServer = new HomekitServer(mdnsClient.getClientInstances().iterator().next(), settings.port); + } else { + networkInterface = InetAddress.getByName(settings.networkInterface); + for (JmDNS mdns : mdnsClient.getClientInstances()) { + if (mdns.getInetAddress().equals(networkInterface)) { + logger.trace("Suitable mDNS client for IP {} found and will be used for HomeKit", networkInterface); + homekitServer = new HomekitServer(mdns, settings.port); + } } } - if (homekitServer == null) { - logger.trace("Not suitable mDNS client fpr IP {} found. Create new mDNS instance.", - networkInterface); - homekitServer = new HomekitServer(networkInterface, settings.port); + } + if (homekitServer == null) { + if (settings.useOHmDNS) { + logger.trace("Not suitable mDNS server for IP {} found", networkInterface); } + logger.trace("Create HomeKit server with dedicated mDNS server"); + homekitServer = new HomekitServer(networkInterface, settings.port); } startBridge(); } else { diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitSettings.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitSettings.java index 91c9d2f7564ff..5f040fa003f3b 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitSettings.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitSettings.java @@ -31,6 +31,7 @@ public class HomekitSettings { public String qrCode; public int startDelay = 30; public boolean useFahrenheitTemperature = false; + public boolean useOHmDNS = false; public String thermostatTargetModeHeat = "HeatOn"; public String thermostatTargetModeCool = "CoolOn"; public String thermostatTargetModeAuto = "Auto"; @@ -78,6 +79,8 @@ public boolean equals(Object obj) { if (other.pin != null) { return false; } + } else if (!useOHmDNS != other.useOHmDNS) { + return false; } else if (!pin.equals(other.pin)) { return false; } else if (!setupId.equals(other.setupId)) { diff --git a/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml b/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml index 836d07aa8e213..8f166bd0f4b4a 100644 --- a/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml +++ b/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml @@ -14,6 +14,10 @@ General thermostat settings + + + General network settings + String values used by your thermostat to set different targetHeatingCooling modes @@ -30,7 +34,7 @@ Defines the port the HomeKit integration listens on. - 9124 + 9123 @@ -41,7 +45,7 @@ Setup ID used for pairing using QR Code. Alphanumeric code of length 4. - + Defines the IP address of the network interface to expose the HomeKit integration on. @@ -102,6 +106,10 @@ target temperature has been reached per the mode). Off - + + + Defines whether mDNS service of openHAB or a separate instance of mDNS should be used. + false + From 50dcd572190c880ae6a8a26887b91de81697e582 Mon Sep 17 00:00:00 2001 From: Eugen Freiter Date: Sat, 6 Mar 2021 11:11:51 +0100 Subject: [PATCH 2/2] fix README and make bridge name configurable Signed-off-by: Eugen Freiter --- bundles/org.openhab.io.homekit/README.md | 27 +++++++------------ .../io/homekit/internal/HomekitImpl.java | 3 ++- .../main/resources/OH-INF/config/config.xml | 5 ++++ 3 files changed, 16 insertions(+), 19 deletions(-) diff --git a/bundles/org.openhab.io.homekit/README.md b/bundles/org.openhab.io.homekit/README.md index d0e26324440ff..50bc0da43020e 100644 --- a/bundles/org.openhab.io.homekit/README.md +++ b/bundles/org.openhab.io.homekit/README.md @@ -40,7 +40,7 @@ HomeKit integration supports following accessory types: - add metadata to an existing item (see [UI based configuration](#UI-based-Configuration)) -- go to scan QR code from UI->Setting-HomeKit Integration +- scan QR code from UI->Settings->HomeKit Integration ![settings_qrcode.png](doc/settings_qrcode.png) @@ -70,18 +70,16 @@ Add metadata to more item or fine-tune your configuration using further settings ## Global Configuration -Your first step will be to create the `homekit.cfg` in your `$OPENHAB_CONF/services` folder. -At the very least, you will need to define a pin number for the bridge. -This will be used in iOS when pairing. The pin code is in the form "###-##-###". +You can define HomeKit settings either via mainUI or via `$OPENHAB_CONF/services/homekit.cfg`. +HomeKit works with default settings, but we recommend changing the pin for the bridge. +This will be used in iOS when pairing without QR Code. The pin code is in the form "###-##-###". Requirements beyond this are not clear, and Apple enforces limitations on eligible pins within iOS. At the very least, you cannot use repeating (111-11-111) or sequential (123-45-678) pin codes. -If your home network is secure, a good starting point is the pin code used in most sample applications: 031-45-154. -Check for typos in the pin-code if you encounter "Bad Client Credential" errors during pairing. -Other settings, such as using Fahrenheit temperatures, customizing the thermostat heat/cool/auto modes, and specifying the interface to advertise the HomeKit bridge (which can be edited in Paper UI standard mode) are also illustrated in the following sample: +Other settings, such as using Fahrenheit temperatures, customizing the thermostat heat/cool/auto modes, and specifying the interface to advertise the HomeKit bridge are also illustrated in the following sample: ``` -org.openhab.homekit:port=9124 +org.openhab.homekit:port=9123 org.openhab.homekit:pin=031-45-154 org.openhab.homekit:useFahrenheitTemperature=true org.openhab.homekit:thermostatTargetModeCool=CoolOn @@ -89,14 +87,8 @@ org.openhab.homekit:thermostatTargetModeHeat=HeatOn org.openhab.homekit:thermostatTargetModeAuto=Auto org.openhab.homekit:thermostatTargetModeOff=Off org.openhab.homekit:networkInterface=192.168.0.6 -``` - -The following additional settings can be added or edited in Paper UI after switching to expert mode: - -``` +org.openhab.homekit:useOHmDNS=false org.openhab.homekit:name=openHAB -org.openhab.homekit:minimumTemperature=-100 -org.openhab.homekit:maximumTemperature=100 ``` ### Overview of all settings @@ -105,6 +97,7 @@ org.openhab.homekit:maximumTemperature=100 |:-------------------------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:--------------| | networkInterface | IP address or domain name under which the HomeKit bridge can be reached. If no value is configured, the add-on uses the first network adapter address configured for openHAB. | (none) | | port | Port under which the HomeKit bridge can be reached. | 9123 | +| useOHmDNS | mDNS service is used to advertise openHAB as HomeKit bridge in the network so that HomeKit clients can find it. openHAB has already mDNS service running. This option defines whether the mDNS service of openHAB or a separate service should be used. | false | | pin | Pin code used for pairing with iOS devices. Apparently, pin codes are provided by Apple and represent specific device types, so they cannot be chosen freely. The pin code 031-45-154 is used in sample applications and known to work. | 031-45-154 | | startDelay | HomeKit start delay in seconds in case the number of accessories is lower than last time. This helps to avoid resetting home app in case not all items have been initialised properly before HomeKit integration start. | 30 | | useFahrenheitTemperature | Set to true to use Fahrenheit degrees, or false to use Celsius degrees. | false | @@ -112,8 +105,6 @@ org.openhab.homekit:maximumTemperature=100 | thermostatTargetModeHeat | Word used for activating the heating mode of the device (if applicable). It can be overwritten at item level. | HeatOn | | thermostatTargetModeAuto | Word used for activating the automatic mode of the device (if applicable). It can be overwritten at item level. | Auto | | thermostatTargetModeOff | Word used to set the thermostat mode of the device to off (if applicable). It can be overwritten at item level. | Off | -| minimumTemperature | Lower bound of possible temperatures, used in the user interface of the iOS device to display the allowed temperature range. Note that this setting applies to all devices in HomeKit. | -100 | -| maximumTemperature | Upper bound of possible temperatures, used in the user interface of the iOS device to display the allowed temperature range. Note that this setting applies to all devices in HomeKit. | 100 | | name | Name under which this HomeKit bridge is announced on the network. This is also the name displayed on the iOS device when searching for available bridges. | openHAB | ## Item Configuration @@ -586,7 +577,7 @@ or using UI | | | Name | String | Name of the switch | | Outlet | | | | An accessory that can be turned off and on. While similar to a lightbulb, this will be presented differently in the Siri grammar and iOS apps | | | OnState | | Switch | State of the outlet - ON/OFF | -| | InUseStatus | | Switch | indicates whether current flowing through the outlet | +| | InUseStatus | | Switch | Indicates whether the outlet has an appliance e.g., a floor lamp, physically plugged in. This characteristic is set to True even if the plugged-in appliance is off. | | | | Name | String | Name of the switch | | Lighting | | | | A lightbulb, can have further optional parameters for brightness, hue, etc | | | OnState | | Switch | State of the light - ON/OFF | diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java index c4d051234221c..a347c471f229a 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java @@ -215,7 +215,8 @@ private void startHomekitServer() throws IOException { networkInterface = InetAddress.getByName(settings.networkInterface); for (JmDNS mdns : mdnsClient.getClientInstances()) { if (mdns.getInetAddress().equals(networkInterface)) { - logger.trace("Suitable mDNS client for IP {} found and will be used for HomeKit", networkInterface); + logger.trace("Suitable mDNS client for IP {} found and will be used for HomeKit", + networkInterface); homekitServer = new HomekitServer(mdns, settings.port); } } diff --git a/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml b/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml index 8f166bd0f4b4a..b13659889eb7a 100644 --- a/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml +++ b/bundles/org.openhab.io.homekit/src/main/resources/OH-INF/config/config.xml @@ -26,6 +26,11 @@ String values used by your thermostat to set different targetHeatingCooling modes + + + Name of the HomeKit bridge + openHAB + qrcode