TapHome

Shelly Flood

Packet Parser → MQTT
Submitted by
Last updated: 03. 2026
Shelly Flood

The Shelly Flood is a battery-powered (CR123A) Wi-Fi water leak sensor. TapHome communicates with the device over MQTT — the recommended protocol for battery-operated Shelly devices, since the sensor sleeps most of the time and publishes data only on wake-up events.

The template supports up to 5 Shelly Flood sensors per module. Each sensor instance is distinguished by a sensorN_topic custom variable pointing to the device’s MQTT Client ID.

Configuration

Device ID

Each Shelly Flood sensor has a unique MQTT Device ID in the format shellyflood-<MAC6>, where <MAC6> is the last 6 characters of the MAC address in lowercase hex (e.g., shellyflood-112233).

The Device ID can be found:

  • On the device label (MAC address)
  • In the Shelly web UI: SettingsDevice Info
  • Via API: GET http://<device-ip>/settingsmqtt.id field

This device supports mDNS discovery. You can use the hostname shellyflood-{MAC}.local instead of an IP address when configuring TapHome. Replace {MAC} with the last 6 characters of the device’s MAC address in lowercase hex (e.g., shellyflood-112233.local). Using a hostname prevents connectivity issues when the device’s IP address changes.

Template setup

After importing the template in TapHome:

  1. Open the Shelly Flood MQTT module
  2. Set the MQTT Broker IP and Port (default 1883)
  3. For each sensor instance, set the sensorN_topic custom variable to the Device ID of the corresponding Shelly Flood (e.g., shellyflood-112233)

The module subscribes to shellies/# and the listener scripts filter messages by the configured topic prefix.

Only configure the sensor slots you actually use. Unconfigured slots (with the default shellyflood-deviceid value) will show an error message prompting you to set the correct topic.

Device capabilities

Water leak detection

Each sensor instance is mapped as a Reed Contact device in TapHome. The flood state is read from the shellies/<id>/sensor/flood topic:

  • trueAlarm (water detected)
  • falseOK (dry)

The sensor wakes up and publishes its state when water is detected or gone, and also during periodic reporting intervals.

Battery and temperature monitoring

Each sensor instance exposes two service attributes:

  • Battery — battery level percentage read from shellies/<id>/sensor/battery. A low battery warning is triggered when the level drops below 20%.
  • Temperature — ambient temperature in °C read from shellies/<id>/sensor/temperature.

Both attributes are read-only and update whenever the sensor wakes up and publishes data.

Additional capabilities

The Shelly Flood also publishes an online/offline status via the MQTT Last Will and Testament (LWT) topic, and a full JSON status message (firmware ≥1.8.0). A rain_sensor setting is available that inverts the flood detection logic for outdoor rain detection use. These capabilities can be added in a future template update.

Troubleshooting

Sensor not reporting data
  1. Verify the Shelly Flood is connected to Wi-Fi and MQTT is enabled in the device settings
  2. Check that the sensorN_topic custom variable matches the Device ID exactly (e.g., shellyflood-112233)
  3. If the MQTT broker address changed, try using the mDNS hostname (shellyflood-AABBCCDDEE.local) to verify the sensor is reachable on the network
  4. Use an MQTT client (e.g., MQTT Explorer) to subscribe to shellies/# and verify the sensor publishes messages on wake-up
Flood alarm not triggering
  1. Confirm the sensor contacts on the bottom of the device are clean and not obstructed
  2. Test by placing the sensor on a wet surface — the device should publish true on the /sensor/flood topic within seconds
  3. Check TapHome for the Reed Contact device state — 1 = alarm, 0 = OK
Battery draining quickly
  1. Shelly Flood is designed for long battery life (CR123A, typically 1–2 years depending on reporting frequency)
  2. Frequent wake-ups (e.g., due to unstable Wi-Fi requiring repeated reconnection) can drain the battery faster
  3. Ensure strong Wi-Fi signal at the sensor location

Gen1 Shelly devices do not support MQTT over TLS. Communication between the sensor and the MQTT broker is unencrypted (plain MQTT, port 1883). Ensure the MQTT broker is on a trusted local network.

How to install in TapHome

Prerequisites

  • Shelly device connected to Wi-Fi (see HTTP connection guide if not done yet)
  • MQTT broker running on your local network (e.g., Mosquitto, Home Assistant, or TapHome built-in broker)
  • TapHome CCU on the same network as the broker

On Gen1 devices, enabling MQTT disables Shelly Cloud. Both cannot run simultaneously. On Gen2/Plus devices this limitation does not apply.

Step 1 — Enable MQTT on the Shelly device

Gen1 devices (Shelly 1, 1PM, 2.5, EM, 3EM, Plug S, RGBW2, Dimmer, TRV…)

  1. Open the Shelly web UI: http://<device-ip>/
  2. Navigate to Internet & SecurityAdvanced — MQTT
  3. Enable MQTT
  4. Set MQTT Server: <broker-ip>:<port> (e.g., 192.168.1.10:1883)
  5. Optionally set MQTT User and MQTT Password if your broker requires authentication
  6. Click Save — the device will reboot and connect to the broker

Gen2 / Plus devices (Shelly Plus 1, Plus 1PM, Plus 2PM, Plus Plug S, Plus H&T, Pro 3EM…)

  1. Open the Shelly web UI: http://<device-ip>/
  2. Navigate to SettingsMQTT
  3. Enable MQTT
  4. Set Server: <broker-ip>:<port> (e.g., 192.168.1.10:1883)
  5. The Client ID is pre-filled with the device ID (e.g., shellyplus1pm-AABBCCDDEE) — leave as-is unless you have a specific reason to change it
  6. Click Save and reboot the device

To verify MQTT is working, use an MQTT client (e.g., MQTT Explorer) and subscribe to shellies/# (Gen1) or <device-id>/# (Gen2). You should see status messages from the device.

Step 2 — Find the Device ID / MQTT Client ID

Some templates require a Device ID or MQTT Client ID parameter. This is the unique identifier used in MQTT topics.

  • Gen1: found on the label as MAC address (e.g., AABBCCDDEE). Device ID = shelly<model>-<mac>, e.g., shelly1pm-AABBCCDDEE
  • Gen2/Plus: found in the Shelly web UI under SettingsDevice InfoDevice ID, or on the device label

Step 3 — Configure in TapHome

  1. In TapHome, add a new Packet Parser (MQTT) module
  2. IP Address: enter the MQTT broker IP (e.g., 192.168.1.10)
  3. Port: 1883 (default; use 8883 for TLS)
  4. Device ID / MQTT Client ID: enter the value from Step 2 (if required by the template)
  5. Import the template — TapHome will subscribe to the device topics automatically

Available devices

Shelly Flood MQTT Module
Flood Sensor 1 Reed Contact Read-only

Water leak detection — reports alarm on water presence, OK when dry

boolean
Service Attributes
Battery
Temperature

Flood Sensor 1

Service Attributes
Battery
battery + "%"
Temperature
temp + "°C"
Flood Sensor 2 Reed Contact Read-only

Water leak detection — reports alarm on water presence, OK when dry

boolean
Service Attributes
Battery
Temperature

Flood Sensor 2

Service Attributes
Battery
battery + "%"
Temperature
temp + "°C"
Flood Sensor 3 Reed Contact Read-only

Water leak detection — reports alarm on water presence, OK when dry

boolean
Service Attributes
Battery
Temperature

Flood Sensor 3

Service Attributes
Battery
battery + "%"
Temperature
temp + "°C"
Flood Sensor 4 Reed Contact Read-only

Water leak detection — reports alarm on water presence, OK when dry

boolean
Service Attributes
Battery
Temperature

Flood Sensor 4

Service Attributes
Battery
battery + "%"
Temperature
temp + "°C"
Flood Sensor 5 Reed Contact Read-only

Water leak detection — reports alarm on water presence, OK when dry

boolean
Service Attributes
Battery
Temperature

Flood Sensor 5

Service Attributes
Battery
battery + "%"
Temperature
temp + "°C"
Connection: Packet Parser → MQTT
Possible improvements (2)
  • Connection Status — LWT topic — true on connect, false on disconnect. Could detect offline sensors.
  • Full Status JSON — Complete /status as JSON (fw ≥1.8.0). Could parse wifi_sta.rssi, battery, act_reasons.

Sources