# Advanced Users

This section provides information for advanced use cases.

# Additional Resources

There are additional resources available providing more information on Shelly devices and how to integrate those into openHAB:

and the openHAB Community thread specifically for the binding (opens new window) - any feedback welcome here. You could also report a bug or request a feature (opens new window) for the Shelly Binding.

# Firmware Upgrade

The Shelly App usually displays the installed firmware and also provide the function to upgrade the device with new firmware. However, if this doesn't work (sometimes there are issues) you could use the Shelly Firmware Archi Link Generator (opens new window), which provides download links to current, but also archived firmware files for all devices.

Version Notes
1.5.7 Minimum supported version. Older versions work in general, but have impacts to functionality (e.g. no events for battery powered devices). The binding displays a WARNING in the log if the firmware is older.
1.6.x First stable CoIoT implementation. AutoCoIoT is enabled when firmware version >= 1.6 is detected.
1.7.x Add additional status update values, fixes various issues
1.8.0 Brings CoIoT version 2, which fixes a lot issues and gaps of version 1.
1.9.2 Various improvements, roller favorites, CoAP fixes

There are 3 options available to perform the upgrade

# Using Shelly Web UI or Smartphone App

The Apps usually detect when a new version becomes available and offers to do the upgrade to the latest release or beta version.

# Trigger device update

The Shelly Firmware Archive Link Generator (opens new window) is provided by the community (not official, but works like charm). This can be used to generate the update link, which could be easily used to perform the upgrade on the cli-level having an Internet connection on that terminal (Shelly device doesn't require an Internet access).

You specify the device's IP and device model SHSW-25 and the page will generate you the link for the firmware download using the OTA of the device.

Then you run

curl -s [-u user:password] <generated link>

from the command line.

This should show a JSON result, make sure that it shows "status:updating". Wait 15sec and access the device's Web UI, go to Settings:Firmware Upgrade and make sure than the new version was installed successful.

# Manual download and installation of the firmware

  • Manually pick the download link from the Shelly Firmware Repository (opens new window) and get the release or beta link.
  • Once you downloaded the file you need to copy it to an http server.
  • Open the following url http://<shelly ip>/ota?url=http://<web server>/<path>/<zip-file>
  • Again, make sure that the file is downloaded and installed properly.

# Trouble Shooting

# Network Settings

Shelly devices do only support IPv4. This implies that the openHAB host system has IPv4 bound to the network interface. The binding is only able to discover devices on the local subnet. Add things manually with the given IP if you have a routed network in between or using a VPN connection.

The binding enables CoIoT protocol by default if the device is running firmware 1.6 or newer. CoIoT is based on CoAP and uses a UDP based signaling using IP Multicast (224.0.1.187, port 5683). Again if the device is not on the same local IP subnet you need special router/switch configurations to utilized CoAP via IP Multicast. Otherwise disable the Auto-CoIoT feature in the binding config (not the thing config), disable CoIoT events in the thing configuration and enable sensors events (http callback). Nevertheless in this setup the binding can communicate the device, but you are loosing the benefits of CoIoT.

Refer to openHAB's general documentation when running openHAB in a docker container. Enabling mDNS discovery has additional setup requirements.

# Re-discover when IP address has changed

Important: The IP address should not be changed after the device is added to openHAB.

This can be achieved by

  • assigning a static IP address (recommended for battery powered devices) or
  • using DHCP and setup the router to always assign the same IP address to the device

When the IP address changes for a device you need to delete the Thing and then re-discover the device. In this case channel linkage gets lost and you need to re-link the channels/items.

# Log optimization

The binding provides channels (e.g. heartBeat, currentWatts), which might cause a lot of log output, especially when having multiple dozen Shellys. openHAB has an integrated feature to filter the event log. This mechanism doesn't filter the event, but the output is not written to the log file (items still receive the updates).

The configuration has to be added to the log configuration file, which is different to openHAB 2.5.x and 3.x (see below).

The example filters events for items heartBeat, lastUpdate, LetzteAktualisierung, Uptime, Laufzeit, ZuletztGesehen Replace those strings with the items you want to filter. Use a list of items to reduce logging.

Please note: Once events are filtered they are not show anymore in the logfile, you can’t find them later.

  • openHAB 2.5.x A configuration is added as a new section to openhab2-userdata/etc/org.ops4j.pax.logging.cfg
# custom filtering rules
log4j2.appender.event.filter.uselessevents.type = RegexFilter
log4j2.appender.event.filter.uselessevents.regex = .*(heartBeat|LastUpdate|lastUpdate|LetzteAktualisierung|Uptime|Laufzeit|ZuletztGesehen).*
log4j2.appender.event.filter.uselessevents.onMatch = DENY
log4j2.appender.event.filter.uselessevents.onMisMatch = NEUTRAL
  • openHAB 3.0

The configuration format of openHAB 3.0 is in xml format.

  • Open the file userdata/etc/log4j2.xml
  • Search for tag RollingFile
  • and add a tag <RegexF,ilter>...</RegExFilter>

The attribute regex of this tag defines the regular expression, onMatch="DENY" the the logger to discard those lines

Example:

...
        <!-- Rolling file appender -->
        <RollingFile fileName="${sys:openhab.logdir}/openhab.log" filePattern="${sys:openhab.logdir}/openhab.log.%i" name="LOGFILE">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5.5p] [%-36.36c] - %m%n"/>
            <RegexFilter regex=".*(heartBeat|LastUpdate|lastUpdate|LetzteAktualisierung|Uptime|Laufzeit|ZuletztGesehen).*" onMatch="DENY" onMismatch="ACCEPT"/>
            <Policies>
                <SizeBasedTriggeringPolicy size="16 MB"/>
            </Policies>
        </RollingFile>
...