Fork of the espurna firmware for `mhsw` switches
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

157 lines
10 KiB

8 years ago
8 years ago
7 years ago
8 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
8 years ago
8 years ago
8 years ago
8 years ago
7 years ago
  1. # ESPurna Firmware
  2. ESPurna ("spark" in Catalan) is a custom firmware for ESP8266 based smart switches.
  3. It was originally developed with the **[IteadStudio Sonoff](https://www.itead.cc/sonoff-wifi-wireless-switch.html)** in mind but now it supports a growing number of ESP8266-based boards.
  4. It uses the Arduino Core for ESP8266 framework and a number of 3rd party libraries.
  5. > **Current Release Version is 1.11.0**, read the [changelog](https://bitbucket.org/xoseperez/espurna/src/master/CHANGELOG.md).
  6. > **NOTICE**: Default flash layout changed in 1.8.3, as an unpredicted consequence devices will not be able to persist/retrieve configuration if flashed with 1.8.3 via **OTA** from **PlatformIO**. Please check issue #187.
  7. > **NOTICE**: since version 1.9.0 the default **MQTT topics for commands have changed**. They all now end with "/set". This means you will have to change your controller software (Node-RED or alike) to send messages to -for instance- "/home/living/light/relay/0/set". The device will publish its state in "/home/living/light/relay/0" like before.
  8. ## Features
  9. * *KRACK* vulnerability free (when built against Arduino Core 2.4.0 RC2)
  10. * Support for **multiple ESP8266-based boards** ([check list](https://bitbucket.org/xoseperez/espurna/wiki/Hardware))
  11. * Power saving options
  12. * Wifi **AP Mode** or **STA mode**
  13. * Up to 5 different networks can be defined
  14. * Supports static IP
  15. * Scans for strongest network if more than one defined
  16. * Defaults to AP mode (also available after double clicking the main button)
  17. * Network visibility
  18. * Supports mDNS (service reporting and metadata)
  19. * Supports NetBIOS, LLMNR and Netbios (when built against Arduino Core 2.4.0 RC2) and SSDP (experimental)
  20. * Switch management
  21. * Support for **push buttons** and **toggle switches**
  22. * Configurable **status on boot** per switch (always ON, always OFF, same as before or toggle)
  23. * Support for **pulse mode** per switch (normally ON or normally OFF) with configurable time
  24. * Support for **relay synchronization** (all equal, only one ON, one and only on ON)
  25. * Support for **MQTT groups** to sync switches between devices
  26. * Support for **delayed ON/OFF**
  27. * **MQTT** enabled
  28. * **SSL/TLS support** (not on regular builds, see #64)
  29. * Switch on/off and toggle relays, group topics (sync relays between different devices)
  30. * Report button event notifications
  31. * Enable/disable pulse mode
  32. * Change LED notification mode
  33. * Remote reset the board
  34. * **Alexa** integration using the [FauxmoESP Library](https://bitbucket.org/xoseperez/fauxmoesp)
  35. * [**Google Assistant**](http://tinkerman.cat/using-google-assistant-control-your-esp8266-devices/) integration using IFTTT and Webhooks (Google Home, Allo)
  36. * [**Domoticz**](https://domoticz.com/) integration via MQTT
  37. * [**Home Assistant**](https://home-assistant.io/) integration via MQTT
  38. * Support for switches (on/off)
  39. * Support for lights (color, brightness, on/off state)
  40. * Supports MQTT auto-discover feature (both switches and lights)
  41. * [**InfluxDB**](https://www.influxdata.com/) integration via HTTP API
  42. * Support for different **sensors**
  43. * Environment
  44. * **DHT11 / DHT22 / DHT21 / AM2301 / Itead's SI7021** (supports celsius & fahrenheit reporting)
  45. * **BMP280** and **BME280** temperature, humidity (BME280) and pressure sensor by Bosch
  46. * **SI7021** temperature and humidity sensor
  47. * **SHT2X** temperature and humidity sensor over I2C (Wemos shield)
  48. * **Dallas OneWire sensors** like the DS18B20 (supports celsius & fahrenheit reporting)
  49. * **MHZ19** CO2 sensor
  50. * **PMSX003** dust sensor
  51. * Power monitoring
  52. * **HLW8012** using the [HLW8012 Library](https://bitbucket.org/xoseperez/hlw8012) (Sonoff POW)
  53. * Non-invasive **current sensor** using **internal ADC** or **ADC121** or **ADS1115**
  54. * **ECH1560** power monitor chip
  55. * **V9261F** power monitor chip
  56. * Raw analog and digital sensors
  57. * Simple pulse counter
  58. * Support for LED lights
  59. * MY92XX-based light bulbs and PWM LED strips (dimmers) up to 5 channels (RGB, cold white and warm white, for instance)
  60. * RGB and HSV color codes supported
  61. * Manage channels individually
  62. * Temperature color supported (in mired and kelvin) via MQTT / REST API
  63. * Flicker-free PWM management
  64. * Soft color transitions
  65. * Fast asynchronous **HTTP Server**
  66. * Configurable port
  67. * Basic authentication
  68. * Web-based configuration
  69. * Relay switching and sensor data from the web interface
  70. * Handle color, brightness, and white/warm channels for lights
  71. * Websockets-based communication between the device and the browser
  72. * Backup and restore settings option
  73. * Upgrade firmware from the web interface
  74. * Works great behind a [secured reverse proxy](http://tinkerman.cat/secure-remote-access-to-your-iot-devices/)
  75. * **REST API** (enable/disable from web interface)
  76. * GET and PUT relay status
  77. * Change light color (for supported hardware)
  78. * GET sensor data (power, current, voltage, temperature and humidity) depending on the available hardware
  79. * Works great behind a secured reverse proxy
  80. * **RPC API** (enable/disable from web interface)
  81. * Remote reset the board
  82. * **Over-The-Air** (OTA) updates even for 1Mb boards
  83. * Manually from PlatformIO or Arduino IDE
  84. * Automatic updates through the [NoFUSS Library](https://bitbucket.org/xoseperez/nofuss)
  85. * Update from web interface using pre-built images
  86. * **Command line configuration**
  87. * Change configuration
  88. * Run special commands
  89. * **Telnet support**
  90. * Enable/disable via the web UI
  91. * Show debug info and allows to run terminal commands
  92. * **Unstable system check**
  93. * Detects unstable system (crashes on boot continuously) and defaults to a stable system
  94. * Only WiFi AP, OTA and Telnet available if system is flagged as unstable
  95. * Button interface
  96. * Click to toggle relays
  97. * Double click to enter AP mode (only main button)
  98. * Long click (>1 second) to reboot device (only main button)
  99. * Extra long click (>10 seconds) to go back to factory settings (only main button)
  100. ## Documentation
  101. For more information please refer to the [ESPurna Wiki](https://bitbucket.org/xoseperez/espurna/wiki/Home).
  102. ## Supported hardware
  103. Here is the list of supported hardware. For more information please refer to the [ESPurna Wiki Hardware page](https://bitbucket.org/xoseperez/espurna/wiki/Hardware).
  104. ||||
  105. |---|---|---|
  106. |![Tinkerman Espurna H](images/devices/tinkerman-espurna-h.jpg)|![IteadStudio Sonoff RF Bridge](images/devices/itead-sonoff-rfbridge.jpg)||
  107. |**Tinkerman ESPurna H**|**IteadStudio Sonoff RF Bridge**||
  108. |![IteadStudio Sonoff Basic](images/devices/itead-sonoff-basic.jpg)|![IteadStudio Sonoff RF](images/devices/itead-sonoff-rf.jpg)|![Electrodragon WiFi IOT](images/devices/electrodragon-wifi-iot.jpg)|
  109. |**IteadStudio Sonoff Basic**|**IteadStudio Sonoff RF**|**Electrodragon WiFi IOT**|
  110. |![IteadStudio Sonoff Dual](images/devices/itead-sonoff-dual.jpg)|![IteadStudio Sonoff POW](images/devices/itead-sonoff-pow.jpg)|![IteadStudio Sonoff TH10/TH16](images/devices/itead-sonoff-th.jpg)|
  111. |**IteadStudio Sonoff Dual**|**IteadStudio Sonoff POW**|**IteadStudio Sonoff TH10/TH16**|
  112. |![IteadStudio Sonoff 4CH](images/devices/itead-sonoff-4ch.jpg)|![IteadStudio Sonoff 4CH Pro](images/devices/itead-sonoff-4ch-pro.jpg)|![OpenEnergyMonitor WiFi MQTT Relay / Thermostat](images/devices/openenergymonitor-mqtt-relay.jpg)|
  113. |**IteadStudio Sonoff 4CH**|**IteadStudio Sonoff 4CH Pro**|**OpenEnergyMonitor WiFi MQTT Relay / Thermostat**|
  114. |![IteadStudio S20](images/devices/itead-s20.jpg)|![WorkChoice EcoPlug](images/devices/workchoice-ecoplug.jpg)|![Power meters based on V9261F and ECH1560](images/devices/generic-v9261f.jpg)|
  115. |**IteadStudio S20**|**WorkChoice EcoPlug**|**Power meters based on V9261F and ECH1560**|
  116. |![IteadStudio Sonoff Touch](images/devices/itead-sonoff-touch.jpg)|![IteadStudio Sonoff T1](images/devices/itead-sonoff-t1.jpg)||
  117. |**IteadStudio Sonoff Touch**|**IteadStudio Sonoff T1**||
  118. |![IteadStudio Slampher](images/devices/itead-slampher.jpg)|![AI-Thinker Wifi Light / Noduino OpenLight](images/devices/aithinker-ai-light.jpg)|![Itead Sonoff B1](images/devices/itead-sonoff-b1.jpg)|
  119. |**IteadStudio Slampher**|**AI-Thinker Wifi Light / Noduino OpenLight**|**IteadStudio Sonoff B1**|
  120. |![MagicHome LED Controller (1.0 and 2.0)](images/devices/magichome-led-controller.jpg)|![Huacanxing H801](images/devices/huacanxing-h801.jpg)|![Itead BN-SZ01](images/devices/itead-bn-sz01.jpg)|
  121. |**MagicHome LED Controller (1.0 and 2.0)**|**Huacanxing H801**|**Itead BN-SZ01**|
  122. |![IteadStudio Sonoff SV](images/devices/itead-sonoff-sv.jpg)|![IteadStudio 1CH Inching](images/devices/itead-1ch-inching.jpg)|![IteadStudio Motor Clockwise/Anticlockwise](images/devices/itead-motor.jpg)|
  123. |**IteadStudio Sonoff SV**|**IteadStudio 1CH Inching**|**IteadStudio Motor Clockwise/Anticlockwise**|
  124. |![Wemos D1 Mini Relay Shield](images/devices/wemos-d1-mini-relayshield.jpg)|![Jan Goedeke Wifi Relay (NO/NC)](images/devices/jangoe-wifi-relay.png)|![Jorge García Wifi + Relays Board Kit](images/devices/jorgegarcia-wifi-relays.jpg)|
  125. |**Wemos D1 Mini Relay Shield**|**Jan Goedeke Wifi Relay (NO/NC)**|**Jorge García Wifi + Relays Board Kit**|
  126. |![EXS Wifi Relay v3.1](images/devices/exs-wifi-relay-v31.jpg)|||
  127. |**EXS Wifi Relay v3.1**|||
  128. **Other supported boards:** Itead Sonoff LED, Itead Sonoff Dual R2, Huacanxing H802, WiOn 50055, ManCaveMade ESP-Live, InterMitTech QuinLED 2.6, Arilux AL-LC06, Arilux E27 light bulb, Xenon SM-PW702U, Authometion LYT8266, YJZK 2-gang switch.
  129. ## License
  130. Copyright (C) 2016-2017 by Xose Pérez (@xoseperez)
  131. This program is free software: you can redistribute it and/or modify
  132. it under the terms of the GNU General Public License as published by
  133. the Free Software Foundation, either version 3 of the License, or
  134. (at your option) any later version.
  135. This program is distributed in the hope that it will be useful,
  136. but WITHOUT ANY WARRANTY; without even the implied warranty of
  137. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  138. GNU General Public License for more details.
  139. You should have received a copy of the GNU General Public License
  140. along with this program. If not, see <http://www.gnu.org/licenses/>.