Awesome Open Source
Awesome Open Source

Control Sonoff Devices from Home Assistant

hacs_badge Donate Donate

Home Assistant custom component for control Sonoff devices with eWeLink (original) firmware over LAN and/or Cloud.

Table of Contents

Main Info

New features in version 2.0:

  • can manage both local and cloud control at the same time!
  • support old devices wih 2.7 firmware (only cloud connection)
  • support new device types: color lights, sensors, covers
  • support eWeLink cameras with PTZ (read more)
  • support unavailable device state for both local and cloud connection
  • support refresh interval for Sonoff TH and Sonoff Pow (read more)
  • support sensors for Sonoff RF Bridge 433 (read more)
  • support ZigBee Bridge and Devices
  • added new debug mode for troubleshooting (read more)

Breaking changes 2.0: by default, both local and cloud modes will start working together. If you do not want this - enable the mode: local setting. But I recommend using the new mode, it works great.

If your internet breaks down - local management will continue to work.
If you have problems with multicast on the local network - cloud management will work.
If you want only local or only cloud control - this can also be configured.


  • work with original eWeLink / Sonoff firmware, no need to flash devices
  • work over Local Network and / or Cloud Server (read more)
  • work with devices without DIY-mode
  • work with devices in DIY-mode (read more)
  • support single and multi-channel devices
  • support TH and Pow device attributes (read more)
  • support Sonoff RF Bridge 433 for receive and send commands (read more)
  • support Sonoff GK-200MP2-B Camera (read more)
  • instant device state update with Local Multicast or Cloud Websocket connection
  • load devices list from eWeLink Servers (with names, apikey/devicekey and device_class) and save it locally
  • (optional) change device type from switch to light (read more)
  • (optional) config force refresh interval for TH and Pow (read more)

Component review from DrZzs

Sonoffs can work with Home Assistant without changing the Firmware!

There is another great component by @peterbuga, that works with cloud servers.

Thanks to @beveradb and @mattsaxon for researching the local Sonoff protocol.
Thanks to @michthom and @EpicLPer for researching the local Sonoff Camera protocol.

Tested Devices

Tested (only LAN)

Maybe other eWeLink cameras also work, I don’t know.

Tested (LAN and Cloud)

These devices work both on a local network and through the cloud.

Tested (only Cloud)

These devices only work through the cloud!

Tested ZigBee (only Cloud)

  • Sonoff ZigBee Bridge - turn on for pairing mode
  • SONOFF SNZB-01 - Zigbee Wireless Switch
  • SONOFF SNZB-02 - ZigBee Temperature and Humidity Sensor
  • SONOFF SNZB-03 - ZigBee Motion Sensor
  • SONOFF SNZB-04 - ZigBee Wireless door/window sensor

Install with HACS

Latest HACS require HA 0.110.0 or newer:


Or manually copy sonoff folder from latest release to custom_components folder in your config folder.

Config Examples

Cloud mode cannot work simultaneously with the 3rd version eWeLink mobile application. You need:

  • eWeLink application of the 4th version (Android only)
  • create a second account, share devices with it and use it in the component

Cloud mode cannot work simultaneously with two copies of component (example main and test Home Assistant). You need:

  • create a second account, share devices with it and use it in the second Home Assistant

Local only mode users fine.

Local mode with load device list - break authorization in a mobile application only at the start of Home Assistant.

Local and Cloud mode

Recommended for general user.

For devices on the 3rd firmware version in the same local network with a working multicast, it uses both local and cloud connections simultaneously.

In other cases, it uses only a cloud connection:

  • devices on the 2nd firmware version
  • devices on another LAN / VLAN
  • users with problems setting up multicast traffic
  • when the local connection freezes (yes it happens)
  username: [email protected]
  password: mypassword


  username: +910123456789  # important to use country code
  password: mypassword

If you have Sonoff Pow or Sonoff TH, you might want to use this kind of config:

  username: [email protected]
  password: mypassword
  force_update: [temperature, power]
  scan_interval: '00:05:00'  # (optional) default 5 minutes
  sensors: [temperature, humidity, power, current, voltage]

Read below what it means.

Cloud only mode

Recommended for users with a bad router, which may freeze due to multicast traffic.

  username: [email protected]
  password: mypassword
  mode: cloud

Local mode with load config from Cloud

Legacy mode. Only downloads a list of devices from Cloud Servers. Works with local protocol. Only works with devices on 3rd firmware.

  username: [email protected]
  password: mypassword
  mode: local
  reload: always  # update device list every time HA starts

Component loads list of devices from eWeLink Servers and save it in the file /config/.sonoff.json (hidden file).

The list will be loaded only once. At the next start, the list will be loaded from the local file. When you have new eWeLink devices - manually delete the file and reboot the HA.

With reload: always in the config - the list will be loaded from servers at each start.

The list will be loaded from the local file even if you remove username and password from the settings.

Local only mode (manual get devicekey)

I don’t understand who needs it, but you never know. You must manually get devicekey for each device. Only works with devices on 3rd firmware.

      devicekey: f9765c85-463a-4623-9cbe-8d59266cb2e4

Local only mode (DIY devices)

Recommended for users who do not trust Cloud Servers for some reason. Only works with devices in DIY mode.


Custom device_class for any mode

You can convert all switches into light by default:

  default_class: light  # (optional), default switch

You can convert specific switches into lights or fans:

      device_class: light
      name: Sonoff Basic
      device_class: fan
      name: Sonoff Mini

You can convert multi-channel devices (e.g. Sonoff T1 2C):

      device_class: [light, fan]
      name: Sonoff T1 2C
      device_class: [light, light]
      name: MiniTiger 2CH

You can convert multi-channel device (e.g. Sonoff T1 3C) into single light with brightness control:

        - light: [1, 2, 3]
      name: Sonoff T1 3C

You can control multiple light zones with single multi-channel device (e.g. Sonoff 4CH Pow):

        - light  # zone 1 (channel 1)
        - light  # zone 2 (channel 2)
        - light: [3, 4]  # zone 3 (channels 3 and 4)
      name: Sonoff 4CH Pow

You can change device_class for Door Sensor:

      device_class: window

You can skip importing any cloud devices:

      device_class: exclude

Refresh interval for TH and Pow

You can config forced updating of TH and Pow attributes (read more).

Force update device by attribute

It is not necessary to list all the attributes of each device (e.g. temperature and humidity). Only one is enough.

  force_update: [temperature, power]
  scan_interval: '00:05:00'  # (optional) default 5 minutes

Force update device by deviceid

  scan_interval: '00:05:00'  # (optional) default 5 minutes
      name: Sonoff TH
      force_update: True
      name: Sonoff Pow
      force_update: True

Sensors from device attributes

Temperature and power sensors are not created by default!
You can list all the attributes you want to see as sensors.

  sensors: [temperature, humidity, power, current, voltage, rssi]

Sonoff RF Bridge 433

Video HOWTO from @KPeyanski

Automatic Calls and Messages from Home Assistant, Sonoff RF Bridge and Smoke Detectors

Video HOWTO from me in Demo section.

RF Bridge Sensors

You can config sensors for your RF Bridge.

The PIR sensor sends a signal if it detects motion. The door / window sensor sends a signal when open. You can set the time after which the sensor goes into off state. Default 120 seconds.

If you has door sensor with two states (for open and for closed state) like this one, you can config payload_off as in the example below. Also disable the timeout if you do not need it in this case (with timeout: 0 option).

You can use any device_class that is supported in Binary Sensor.

PIR Sensor

    PIR Sensor 1:  # sensor name in eWeLink application
      device_class: motion
      timeout: 60  # optional (default 120), timeout in seconds for auto turn off
    PIR Sensor 2:  # sensor name in eWeLink application
      device_class: motion
      timeout: 60  # optional (default 120), timeout in seconds for auto turn off

Single State Sensor

    Door Sensor 1:  # sensor name in eWeLink application
      name: Door Sensor # optional, you can change sensor name
      device_class: door  # e.g. door, window
      timeout: 5
    Door Sensor 2:
      name: Door Sensor
      device_class: door
      timeout: 5

Dual State Sensor

    Button1:  # button name in eWeLink application (open signal)
      name: Window Sensor  # optional, you can change sensor name
      device_class: window  # e.g. door, window
      timeout: 0  # disable auto close timeout
      payload_off: Button2  # button name in eWeLink application (close signal)
      name: Window Sensor
      device_class: window
      timeout: 0
      payload_off: Button4

RF Bridge Commands and Events

Component will create only one entity per RF Bridge - remote.sonoff_1000abcdefg.

You can receive signals from RF Buttons and RF Sensors through an event sonoff.remote. And send signals using the service remote.send_command.

Although the component supports training, it is recommended to train RF Buttons through the eWeLink application.

When a command is received, the event sonoff.remote is generated with a button number and response time (in UTC, sends the device).

The last command received can be seen in the Bridge attributes:

Example for receive all RF signal

- alias: Sonoff RF Receive
    platform: event
    event_type: sonoff.remote  # this is NOT entity_id, don't change it!
    service: persistent_notification.create
      title: Sonoff RF Receive
      message: |-
        Name: {{ }}
        Command: {{ }}
        Time: {{ }}

Example of reaction to the selected button

Instead of a name: Button1, you can use command: 0 number of the button in the eWeLink application (starts from zero).

- alias: Receive Button1
    platform: event
    event_type: sonoff.remote  # this is NOT entity_id, don't change it!
      name: Button1  # button/sensor name in eWeLink application
    service: persistent_notification.create
      message: My Remote button pressed

Example for send RF signal

    alias: Send RF Button1
    - service: remote.send_command
        entity_id: remote.sonoff_1000abcdef
        command: Button1  # button name in eWeLink application

Sonoff Pow Power Consumption

For update power consumption of all your Pow devices you can call sonoff.update_consumption service.

The device attributes will display data for the last 100 days. The first element is today's data. It's up to you how often to call updates and what to do with this data later.

Remember, without calling the service, there will be no values. Use automation.

- platform: template
      friendly_name: Today consumpion
      unit_of_measurement: kWh
      value_template: "{{ state_attr('switch.sonoff_1000abcdef', 'consumption').0 }}"
      friendly_name: 10 days consumpion
      unit_of_measurement: kWh
      value_template: "{% set p=state_attr('switch.sonoff_1000abcdef', 'consumption') %}{{ p[:10]|sum if p }}"

Sonoff GK-200MP2-B Camera

Currently only PTZ commands are supported. Camera entity is not created now.

You can send left, right, up, down commands with sonoff.send_command service:

      - service: sonoff.send_command
          device: '012345'  # use quotes, this is important
          cmd: left

device - this is the number from the camera ID EWLK-012345-XXXXX, exactly 6 digits (leading zeros - it is important).

Never ever tell anyone your camera ID!

In development: camera entity with still image and stream support.


Check other videos on my YouTube channel.

Sonoff RF Bridge automation via Node-RED

Sonoff RF Bridge automation via SonoffLAN, Home Assistan and Node-RED

Control Sonoff 4CH Pow R2 from HomeKit

Control Sonoff Devices with eWeLink firmware over LAN from Home Assistant Sonoff GK-200MP2-B Camera LAN Control

Change Name or Entity ID of any device:

Getting devicekey manually

  1. Put the device in setup mode
  2. Connect to the Wi-Fi network ITEAD-10000, password12345678
  3. Open in browser
  4. Copy deviceid and apikey (this is devicekey)
  5. Connect to your Wi-Fi network and setup Sonoff via the eWeLink app

Common problems in only LAN mode

Cloud users don't have these problems.

Devices are not displayed

  1. Only supported devices with firmware v3+
  2. Common problems with Multicast:
    • two routers
    • docker with port forwarding
    • virtual machine with port forwarding
      • you must use bridge virtual network mode (not NAT mode)
    • Oracle VM VirtualBox
    • linux firewall
    • linux network driver

The devices publish their data through Multicast DNS (mDNS/zeroconf), read more.

Devices unavailable after reboot

All devices unavailable after each Home Assistant restart. It does not depend on reload setting. Devices are automatically detected in the local network after each restart. Sometimes devices appear quickly. Sometimes after a few minutes. If this does not happen, there are some problems with the multicast / router.

Component Debug Mode

Component support debug mode. Shows only component logs and removes all private data automatically. The link to the logs is always random.

Control Sonoff Devices with eWeLink firmware over LAN from Home Assistant

  username: [email protected]
  password: mypassword
  debug: True  # you will get HA notification with a link to the logs page

You can filter multiple devices in the logs and enable auto refresh (in seconds).|1000abcde2&r=2

All unknown devices with command switch support will be added as switch.

All other unknown devices will be added as binary_sensor (always off). The full state of the device is displayed in its attributes.

The component adds the service sonoff.send_command to send low-level commands.

Example service params to single switch:

device: 1000123456
switch: 'on'

Example service params to multi-channel switch:

device: 1000123456
switches: [{outlet: 0, switch: 'off'}]

Example service params to dimmer:

device: 1000123456
cmd: dimmable
switch: 'on'
brightness: 50
mode: 0

Useful Links

Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
python (51,899
home-assistant (212
sonoff (24

Find Open Source By Browsing 7,000 Topics Across 59 Categories