Skip to main content

Shelly

HSYCO integrates Allterco's Shelly devices, a comprehensive range of WiFi-enabled smart home devices operating on 2.4GHz with IPv4 support. Each device offers a documented API.

HSYCO independently manages these devices without relying on the Allterco Shelly Cloud (which, in fact, can be disabled). It operates alongside the Shelly App for smartphones, Shelly Device Web UI, Shelly Cloud and MQTT.

HSYCO's primary functions include reporting device status and enabling device control. Initial setup and configuration of devices must be conducted using the Shelly Apps (either through the Web UI or Smartphone App).

Communication

HSYCO communicates with Shelly devices through UDP, enabling it when discovering or adding new devices. You should configure only one I/O Server for each LAN. Support for multiple local networks is achieved by configuring one I/O Server for each network.

HSYCO Configuration

Add a Shelly I/O Server in the I/O Servers section of the Settings and set its parameters:

Communication

  • IP Address: broadcast IP address of the LAN (e.g. 192.168.1.255)
  • IP Port: TCP/IP port to use, leave blank to use default port 50752.

High Availability

  • Shutdown when inactive: defaults to false.

Options

IDDefaultValuesDescription
listening_port532921 ... 65535Devices listening port for incoming UDP traffic from HSYCO
disableverbosedumptruetruewhen verbose log is enabled, don’t write UDP packets dump to the log files
falsewhen verbose log is enabled, all decoded UDP packets are written to the log files

Shelly Utility

The Shelly Utility provides a graphical interface to discover, edit and delete devices, and update their firmware to the latest stable version available.

Devices

The following Shelly devices are supported:

  • Generation 2 + 3: Plus / Pro series of devices
  • Shelly Plus Mini: Shelly Plus devices in compact format (Gen 2 + 3)
ModelVendor ID
Shelly Plus 1 MiniSNSW-001X8EU
Shelly Plus 1 PM MiniSNSW-001P8EU
Shelly Plus 2 PMSNSW-002P16EU / SNSW-102P16EU
Shelly Plus I4SNSN-0024X
Shelly Plus Plug ITSNPL-00110IT
Shelly Plus Plug S V2SNPL-10112EU / SNPL-00112EU / SNPL-0112EU
Shelly Plus Plug UKSNPL-00112UK
Shelly Plus Plug USSNPL-00116US
Shelly Plus H&TSNSN-0013A
Shelly Plus SmokeSNSN-0031Z
Shelly Plus WallDimmerSNDM-0013US
Shelly Plus 0-10V DimmerSNDM-00100WW
Shelly Plus PM MiniSNPM-001PCEU16
Shelly Plus UniSNSN-0043X
Shelly Pro 1SPSW-201XE16EU / SPSW-001XE16EU
Shelly Pro 1 PMSPSW-001PE16EU / SPSW-201PE16EU
Shelly Pro 2SPSW-002XE16EU / SPSW-202XE16EU
Shelly Pro 2 PMSPSW-002PE16EU / SPSW-202PE16EU
Shelly Pro 3SPSW-003XE16EU
Shelly Pro 4 PMSPSW-004PE16EU / SPSW-104PE16E
Shelly Pro Dual Cover PMSPSH-002PE16EU
Shelly Pro EMSPEM-002CEBEU50
Shelly Pro 3 EM (400)SPEM-003CEBEU120
Shelly Pro Dimmer 1 PMSPDM-001PE01EU
Shelly Pro Dimmer 2 PMSPDM-002PE01EU
Shelly Pro Dimmer 0/1-10V PMSPCC-001PE10EU
Shelly BLU GatewayGWF-KZ01
Shelly 1S3SW-001X16EU
Shelly 1 PMS3SW-001P16EU
Shelly 2 PMS3SW-002P16EU
Shelly I4S3SN-0024X
Shelly 1 MiniS3SW-001X8EU
Shelly 1 PM MiniS3SW-001P8EU
Shelly PM MiniS3PM-001PCEU16
Shelly Plug SS3PL-00112EU
Shelly Dimmer 0/1-10V PMS3DM-0010WW
Shelly Dali DimmerS3DM-0A1WW
Shelly H&TS3SN-0U12A
Shelly EMS3EM-002CXCEU
Shelly BLU Gateway Gen3S3GW-1DBT001

Discovery

For discovery to work, devices generally need to be active. Battery-powered devices require waking up by pressing the button (so that they enter setup mode); they remain active for about a minute, providing enough time to initiate discovery.

Discovery is performed via mDNS, with devices periodically broadcasting their presence. HSYCO uses this to locate them on the local network. In some cases, you may need to run manual discovery multiple times to ensure all devices are detected.

Dynamic Channel Creation

The Shelly device series includes various combinations of relays, meters (in different versions), sensors, and more. HSYCO dynamically creates channels based on the status information received from the device during initialization.

note

If a device's configuration changes after discovery, all packets coming from that device wil be discarded. In order to receive and process again packets from these devices, restart the I/O server so that HSYCO polls the devices to obtain their new configuration.

Polling

Devices are polled every two minutes to update their full components status and their basic information, like uptime, available updates or whether a restart is required.

The Device Configuration Database

The systemtopo.txt file contains the list of all virtual devices that should be directly associated to graphic objects in the Web-based user interface.

This file can be filled manually or automatically by HSYCO at start-up. To enable automatic discovery and automatic generation of devices’ information in the systemtopo.txt file, use the discovery option in Settings.

This is an example of an automatically generated systemtopo.txt file:

(devices)
shelly.mini1g3_1.switch.0.switch : LIGHT ; LIGHT ; Mini1G3
shelly.plugsg3_1.switch.0.switch : LIGHT ; LIGHT ; PlugSG3
shelly.plus10v_1.light.0.light : LIGHT ; DIMMER ; Plus10V
shelly.plus2pm_1.cover.0.cover : AUTOM ; VSHUT ; Plus2PM
shelly.pro2_1.switch.0.switch : LIGHT ; LIGHT ; Pro2
shelly.pro2_1.switch.1.switch : LIGHT ; LIGHT ; Pro2
...
...

The description of the Devices is initialized to their short name, and it can be changed from the Utility, as well as their name.

Datapoints

The Shelly I/O Server creates datapoints based on each device's channels, and they all begin with the same format:

<device_name>.<channel_name>.<channel_id>.<property_name>

where:

  • <device_name> is the name of the device, automatically assigned by HSYCO at discovery and manually editable
  • <channel_name> is the name of the channel, like 'switch', 'light', 'input', ...
  • <channel_id> is the ID of the channel
  • <property_name> is the name of the property, like 'state', 'current', 'switch', ...

For example this datapoint

pro2_1.switch.0.state

represents the output value of the switch with ID 0 of device "pro2_1".

Datapoints Table

INPUT channel

IDValueR/WDescription
<device_name>.input.<channel_id>.state0 / 1R(only for type switch, button) State of the input
<device_name>.input.<channel_id>.percent<value>R(only for type analog) Analog value in percent
<device_name>.input.<channel_id>.xpercent<value>R(only for type analog) Percent transformed with config.xpercent.expr
<device_name>.input.<channel_id>.counts.total<value>R(only for type count) Total pulses counted
<device_name>.input.<channel_id>.counts.xtotal<value>R(only for type count) Total transformed with config.xcounts.expr
<device_name>.input.<channel_id>.freq<value>R(only for type count) Measured frequency in Hz
<device_name>.input.<channel_id>.xfreq<value>R(only for type count) Freq transformed with config.xfreq.expr
<device_name>.input.<channel_id>.errors<value>RShown only if at least one error is present. May contain out_of_range, read

SWITCH channel

IDValueR/WDescription
<device_name>.switch.<channel_id>.state0 / 1ROutput channel state
<device_name>.switch.<channel_id>.state0WChannel output off
<device_name>.switch.<channel_id>.stateoffWChannel output off
<device_name>.switch.<channel_id>.state1WChannel output on
<device_name>.switch.<channel_id>.stateonWChannel output on
<device_name>.switch.<channel_id>.apower<value>RLast measured instantaneous active power (in Watts) delivered to the attached load
<device_name>.switch.<channel_id>.voltage<value>RLast measured voltage in Volts
<device_name>.switch.<channel_id>.current<value>RLast measured current in Amperes
<device_name>.switch.<channel_id>.pf<value>RLast measured power factor
<device_name>.switch.<channel_id>.freq<value>RLast measured network frequency in Hz
<device_name>.switch.<channel_id>.aenergy.total<value>RTotal energy consumed in Watt-hours
<device_name>.switch.<channel_id>.ret_aenergy.total<value>RTotal returned energy consumed in Watt-hours
<device_name>.switch.<channel_id>.temperature.tC<value>RTemperature in Celsius
<device_name>.switch.<channel_id>.temperature.tF<value>RTemperature in Fahrenheit
<device_name>.switch.<channel_id>.errors<value>RError conditions occurred. May contain overtemp, overpower, overvoltage, undervoltage

LIGHT channel

IDValueR/WDescription
<device_name>.light.<channel_id>.state0 / 1ROutput channel state
<device_name>.light.<channel_id>.state1...100ROutput channel brightess (when light is on)
<device_name>.light.<channel_id>.stateoffWChannel output off
<device_name>.light.<channel_id>.stateonWChannel output on
<device_name>.light.<channel_id>.state0...100%WChannel output brightness
<device_name>.light.<channel_id>.transition.target.output<value>RWhether the transition output channel is on
<device_name>.light.<channel_id>.transition.target.brightness<value>RTransition brightness level (in percent)
<device_name>.light.<channel_id>.transition.duration<value>RDuration of the transition in seconds
<device_name>.light.<channel_id>.temperature.tC<value>RTemperature in Celsius
<device_name>.light.<channel_id>.temperature.tF<value>RTemperature in Fahrenheit
<device_name>.light.<channel_id>.aenergy.total<value>RTotal energy consumed in Watt-hours
<device_name>.light.<channel_id>.apower<value>RLast measured instantaneous active power (in Watts) delivered to the attached load
<device_name>.light.<channel_id>.voltage<value>RLast measured voltage in Volts
<device_name>.light.<channel_id>.current<value>RLast measured current in Amperes
<device_name>.light.<channel_id>.calibration.progress<value>RInformation about the calibration process, only present when calibration is running
<device_name>.light.<channel_id>.errors<value>RError conditions occurred. May contain overtemp, overpower, overvoltage, undervoltage, overcurrent, unsupported_load, cal_abort:interrupted, cal_abort:power_read, cal_abort:no_load, cal_abort:non_dimmable, cal_abort:overpower, cal_abort:unsupported_load
<device_name>.light.<channel_id>.flags<value>RCommunicates present conditions. May contain no_load, uncalibrated

COVER channel

IDValueR/WDescription
<device_name>.cover.<channel_id>.stateopen / closed / opening / closing / stopped / calibratingRState of the cover
<device_name>.cover.<channel_id>.stateopenWOpen the cover
<device_name>.cover.<channel_id>.statecloseWClose the cover
<device_name>.cover.<channel_id>.statestopWStop the cover
<device_name>.cover.<channel_id>.state0...100%R/WMove the cover to the target position
<device_name>.cover.<channel_id>.apower<value>RActive power in Watts
<device_name>.cover.<channel_id>.voltage<value>RVolts
<device_name>.cover.<channel_id>.current<value>RAmperes
<device_name>.cover.<channel_id>.pf<value>Rpower factor
<device_name>.cover.<channel_id>.freq<value>Rnetwork frequency, Hz
<device_name>.cover.<channel_id>.aenergy.total<value>RTotal energy consumed in Watt-hours
<device_name>.cover.<channel_id>.current_pos<value>ROnly present if Cover is calibrated. Represents current position in percent from 0 (fully closed) to 100 (fully open)
<device_name>.cover.<channel_id>.target_pos<value>ROnly present if Cover is calibrated and is actively moving to a requested position in either open or closed directions. Represents the target position in percent from 0 (fully closed) to 100 (fully open)
<device_name>.cover.<channel_id>.move_timeout<value>RSeconds, only present if Cover is actively moving in either open or closed directions. Cover will automatically stop after the timeout expires
<device_name>.cover.<channel_id>.move_started_at<value>ROnly present if Cover is actively moving in either open or closed directions. Represents the time at which the movement has begun
<device_name>.cover.<channel_id>.pos_control<value>R0 if Cover is not calibrated and only discrete open/close is possible; 1 if Cover is calibrated and can be commanded to go to arbitrary positions between fully open and fully closed
<device_name>.cover.<channel_id>.last_direction<value>RDirection of the last movement: open/close or null when unknown
<device_name>.cover.<channel_id>.temperature.tC<value>RTemperature in Celsius
<device_name>.cover.<channel_id>.temperature.tF<value>RTemperature in Fahrenheit
<device_name>.cover.<channel_id>.slat_pos<value>ROnly present if slat control is supported and enabled. Represents current slat position in percent from 0 (fully closed) to 100 (fully open)
<device_name>.cover.<channel_id>.errors<value>ROnly present if an error condition has occurred. May contain overtemp, overpower, overvoltage, undervoltage, overcurrent, obstruction, safety_switch, bad_feedback:rotating_in_wrong_direction, bad_feedback:both_directions_active, bad_feedback:failed_to_halt, cal_abort:timeout_open, cal_abort:timeout_close, cal_abort:safety, cal_abort:ext_command, cal_abort:bad_feedback, cal_abort:implausible_time_to_fully_close, cal_abort:implausible_time_to_fully_open, cal_abort:implausible_power_consumption_in_close_dir, cal_abort:implausible_power_consumption_in_open_dir, cal_abort:too_many_steps_to_close, cal_abort:too_few_steps_to_close, cal_abort:implausible_time_to_fully_close_w_steps, cal_abort:implausible_step_duration_in_open_dir, cal_abort:too_many_steps_to_open, cal_abort:too_few_steps_to_open, cal_abort:implausible_time_to_fully_open_w_steps

TEMPERATURE channel

IDValueR/WDescription
<device_name>.temperature.<channel_id>.tC<value>RTemperature in Celsius
<device_name>.temperature.<channel_id>.tF<value>RTemperature in Fahrenheit
<device_name>.temperature.<channel_id>.errors<value>RError conditions occurred. May contain out_of_range, read

HUMIDITY channel

IDValueR/WDescription
<device_name>.humidity.<channel_id>.rh<value>RRelative humidity in %
<device_name>.humidity.<channel_id>.errors<value>RShown only if at least one error is present. May contain out_of_range, read when there is problem reading sensor

DEVICEPOWER channel

IDValueR/WDescription
<device_name>.devicepower.<channel_id>.battery.V<value>RBattery voltage in Volts
<device_name>.devicepower.<channel_id>.battery.percent<value>RBattery charge level in %
<device_name>.devicepower.<channel_id>.external.present<value>RWhether external power source is connected

SMOKE channel

IDValueR/WDescription
<device_name>.smoke.<channel_id>.alarm<value>RWhether the alarm state is on
<device_name>.smoke.<channel_id>.mute<value>RWhether the mute state is on

VOLTMETER channel

IDValueR/WDescription
<device_name>.devicepower.<channel_id>.voltage<value>RVoltage in volts
<device_name>.devicepower.<channel_id>.xvoltage<value>Rvoltage transformed with config.xvoltage.expr
<device_name>.devicepower.<channel_id>.errors<value>RShown only if at least one error is present. May contain out_of_range, read when there is problem reading sensor

EM channel

IDValueR/WDescription
<device_name>.em.<channel_id>.a_current<value>RPhase A current measurement value, [A]
<device_name>.em.<channel_id>.a_voltage<value>RPhase A voltage measurement value, [V]
<device_name>.em.<channel_id>.a_act_power<value>RPhase A active power measurement value, [W]
<device_name>.em.<channel_id>.a_aprt_power<value>RPhase A apparent power measurement value, [VA]
<device_name>.em.<channel_id>.a_pf<value>RPhase A power factor measurement value
<device_name>.em.<channel_id>.a_freq<value>RPhase A network frequency measurement value
<device_name>.em.<channel_id>.a_errors<value>RPhase A error conditions occurred. May contain out_of_range:active_power, out_of_range:apparent_power, out_of_range:voltage, out_of_range:current
<device_name>.em.<channel_id>.b_current<value>RPhase B current measurement value, [A]
<device_name>.em.<channel_id>.b_voltage<value>RPhase B voltage measurement value, [V]
<device_name>.em.<channel_id>.b_act_power<value>RPhase B active power measurement value, [W]
<device_name>.em.<channel_id>.b_aprt_power<value>RPhase B apparent power measurement value, [VA]
<device_name>.em.<channel_id>.b_pf<value>RPhase B power factor measurement value
<device_name>.em.<channel_id>.b_freq<value>RPhase B network frequency measurement value
<device_name>.em.<channel_id>.b_errors<value>RPhase B error conditions occurred. May contain out_of_range:active_power, out_of_range:apparent_power, out_of_range:voltage, out_of_range:current
<device_name>.em.<channel_id>.c_current<value>RPhase C current measurement value, [A]
<device_name>.em.<channel_id>.c_voltage<value>RPhase C voltage measurement value, [V]
<device_name>.em.<channel_id>.c_act_power<value>RPhase C active power measurement value, [W]
<device_name>.em.<channel_id>.c_aprt_power<value>RPhase C apparent power measurement value, [VA]
<device_name>.em.<channel_id>.c_pf<value>RPhase C power factor measurement value
<device_name>.em.<channel_id>.c_freq<value>RPhase C network frequency measurement value
<device_name>.em.<channel_id>.c_errors<value>RPhase C error conditions occurred. May contain out_of_range:active_power, out_of_range:apparent_power, out_of_range:voltage, out_of_range:current
<device_name>.em.<channel_id>.n_current <value>RNeutral current measurement value, [A] (if supported)
<device_name>.em.<channel_id>.n_errors <value>RNeutral error conditions occurred. May contain out_of_range:current
<device_name>.em.<channel_id>.total_current<value>RSum of the current on all phases(excluding neutral readings if available)
<device_name>.em.<channel_id>.total_act_power<value>RSum of the active power on all phases
<device_name>.em.<channel_id>.total_aprt_power<value>RSum of the apparent power on all phases
<device_name>.em.<channel_id>.user_calibrated_phase <value>RIndicates which phase was user calibrated
<device_name>.em.<channel_id>.errors<value>REM component error conditions. May contain power_meter_failure, phase_sequence, ct_type_not_set

EMDATA channel

IDValueR/WDescription
<device_name>.emdata.<channel_id>.a_total_act_energy<value>RTotal active energy on phase A, Wh
<device_name>.emdata.<channel_id>.a_total_act_ret_energy<value>RTotal active returned energy on phase A, Wh
<device_name>.emdata.<channel_id>.b_total_act_energy<value>RTotal active energy on phase B, Wh
<device_name>.emdata.<channel_id>.b_total_act_ret_energy<value>RTotal active returned energy on phase B, Wh
<device_name>.emdata.<channel_id>.c_total_act_energy<value>RTotal active energy on phase C, Wh
<device_name>.emdata.<channel_id>.c_total_act_ret_energy<value>RTotal active returned energy on phase C, Wh
<device_name>.emdata.<channel_id>.total_act<value>RTotal active energy on all phases, Wh
<device_name>.emdata.<channel_id>.total_act_ret<value>RTotal active returned energy on all phases, Wh
<device_name>.emdata.<channel_id>.errors<value>RError condition occurred. May contain database_error, ct_type_not_set

EM1 channel

IDValueR/WDescription
<device_name>.em1.<channel_id>.current<value>RCurrent measurement value, [A]
<device_name>.em1.<channel_id>.voltage<value>RVoltage measurement value, [V]
<device_name>.em1.<channel_id>.act_power<value>RActive power measurement value, [W]
<device_name>.em1.<channel_id>.aprt_power<value>RApparent power measurement value, [VA]
<device_name>.em1.<channel_id>.pf<value>RPower factor measurement value
<device_name>.em1.<channel_id>.freq<value>RNetwork frequency measurement value
<device_name>.em1.<channel_id>.calibration<value>RIndicates factory calibration or which EM1:id is the source for calibration
<device_name>.em1.<channel_id>.errors<value>REM1 component error conditions. May contain power_meter_failure, out_of_range:act_power, out_of_range:aprt_power, out_of_range:voltage, out_of_range:current or ct_type_not_set
<device_name>.em1.<channel_id>.flags<value>RCommunicates present conditions. Depending on component capabilites may contain: count_disabled

EM1DATA channel

IDValueR/WDescription
<device_name>.em1data.<channel_id>.total_act_energy<value>RTotal active energy, Wh
<device_name>.em1data.<channel_id>.total_act_ret_energy<value>RTotal active returned energy, Wh
<device_name>.em1data.<channel_id>.errors<value>RError condition occurred. May contain database_error, ct_type_not_set

PM1 channel

IDValueR/WDescription
<device_name>.pm1.<channel_id>.voltage<value>RLast measured voltage in Volts
<device_name>.pm1.<channel_id>.current<value>RLast measured current in Amperes
<device_name>.pm1.<channel_id>.apower<value>RLast measured instantaneous active power (in Watts) delivered to the attached load
<device_name>.pm1.<channel_id>.aprtpower<value>RLast measured instantaneous apparent power (in Volt-Amperes) delivered to the attached load
<device_name>.pm1.<channel_id>.pf<value>RLast measured power factor
<device_name>.pm1.<channel_id>.freq<value>RLast measured network frequency
<device_name>.pm1.<channel_id>.aenergy.total<value>RTotal energy consumed in Watt-hours
<device_name>.pm1.<channel_id>.ret_aenergy.total<value>RTotal returned energy consumed in Watt-hours
<device_name>.pm1.<channel_id>.errors<value>RError conditions occurred. May contain power_meter_failure, out_of_range:voltage, out_of_range:current, out_of_range:aprtpower, out_of_range:apower

Examples

Settin devices' states

init : IO shelly.plus2pm_1.switch.0.state shelly.plus2pm_1.switch.1.state = 1
init : IO shelly.plus10v_1.light.0.state = 75%

The first line sets the two switch channels (IDs 0 and 1) of the device named 'plus2pm_1' to 1 or on. The second line sets the light's brightness of device 'plus10v_1' to 75.

Release Notes

4.0.0

  • initial release

SHELLY is a trademark of SHELLY GROUP SE