diff --git a/esphomeyaml/changelog/v1.10.0.rst b/esphomeyaml/changelog/v1.10.0.rst index c73697e7f..e16d3ebd8 100644 --- a/esphomeyaml/changelog/v1.10.0.rst +++ b/esphomeyaml/changelog/v1.10.0.rst @@ -7,7 +7,88 @@ Changelog - Version 1.9.0 :author: Otto Winter :author_twitter: @OttoWinter_ -TODO: Write Changelog, create seo image +Native API +---------- + +This release brings with it lots of goodies, but most important is the :doc:`native API `. +MQTT has been the only way this project communicated with Home Assistant for a while now. And MQTT is a great protocol +to get started, but it always had problems: + +- Another service to install - Users would need to install an MQTT broker in order to get started. +- MQTT Discovery - Home Assistant's MQTT discovery has been great, but always had problems like retained messages etc. +- Inefficient - A typical MQTT message for sending a binary sensor state is about 70 bytes long, and the MQTT library + we used was quite inefficient with runtime memory allocation too. + +So I decided to do something against that: ESPHome now features a native protocol (based on TCP+protocol buffers) +that addresses these issues and has a +`component on the Home Assistant `__ +side too. + +**Does this mean MQTT will be removed?** + +No! MQTT is an awesome protocol with easy integration for many tools like Node-RED and custom MQTT clients. +This native API is only for replacing communications with Home Assistant, so *if* anything gets removed it's +MQTT auto discovery for Home Assistant. Of course both can be used together at the same time too. + +**Should I switch to the native API immediately?** + +You definitely can, but a word of warning first: The MQTT implementation has seen tons of fixes for small quirks +in how the ESP SDK works. From my own testing, the native API seems to be quite stable - but I'm sure it'll take a bit +of time to find+fix some final bugs. + +**How do I migrate from MQTT?** + +First, make sure you run at least Home Assistant 0.85.0. Then, go through the +:ref:`migration guide here `. + +Python 3 Comparability +---------------------- + +PlatformIO has finally implemented `python 3 support `__ +after some quick changes, ESPHome is now also compatible with python 3.5+. So with this new release +you can try ESPHome with Python 3 already. Just make sure to install the development version of platformio first: + +.. code-block:: bash + + pip3 install -U https://github.com/platformio/platformio-core/archive/develop.zip + +I don't particularly like python 2, and in a year's time support for it will officially be ended. So the plan for +ESPHome is to drop python 2 as soon as possible. Once platformio releases version 4.0 (with python 3 support), I +will go through and check everything still works. Maybe ESPHome will support python 2 for 1 or 2 releases after that +but really I want to drop support for python 2 as soon as possible. + +Dashboard & Hass.io Addon Updates +--------------------------------- + +The dashboard and Hass.io addon have seen a lot of ❤️ in this release: The dashboard has seen tons of small +changes to make the user experience better and the Hass.io addon has been completely re-written with the +`Hass.io Community Addon Images `__ as the base. + +- The dashboard now features a built-in YAML editor. +- Configuration wizard now shows a list of boards directly, so you just have to choose them from a dropdown. +- Hass.io Addon: You can log in using your Home Assistant credentials now. +- And many more changes (colored logs, auto-scroll, node status, update notifications, ...) + +Rename: esphome{lib, yaml} -> ESPHome +------------------------------------- + +The name esphomelib and esphomeyaml were too technical, and this project has changed a lot since the first +published release (the yaml part didn't even exist back then). So ... the project is being re-branded slightly: + +- esphomeyaml -> ESPHome +- esphomelib -> ESPHome Core +- esphomedocs -> ESPHome Docs + +As you see, the yaml project is now getting the "fancy" name, because that's by far the best way to use this framework. +As part of this change, using the _core_ framework directly from code (without YAML) is being deprecated, the API docs +have long been inaccurate now and users should really switch over to ESPHome through YAML + +Of course that doesn't mean you won't be able to write custom code. In fact, this release also contains lots of +new guides and changes to make creating custom components much easier. The goal is to have a project where users +can use YAML for the boring boilerplate code but can completely customize everything with custom components. + +This migration is of course huge - almost every single file in the code+docs base has esphome{lib, yaml} somewhere +in it, so it will take time until the next release for this to be finished. All changes ----------- diff --git a/esphomeyaml/components/api.rst b/esphomeyaml/components/api.rst index eb750bd16..cf9ee4b75 100644 --- a/esphomeyaml/components/api.rst +++ b/esphomeyaml/components/api.rst @@ -32,8 +32,8 @@ Configuration variables: .. _api-mqtt_to_native: -Converting from MQTT to Native API Setup in Home Assistant ----------------------------------------------------------- +Migrating from MQTT to Native API Setup in Home Assistant +--------------------------------------------------------- The native API is the best way to use esphomelib together with Home Assistant - it's fast, highly efficient and requires almost zero setup (whereas MQTT requires you to set up an MQTT broker first). diff --git a/esphomeyaml/components/binary_sensor/index.rst b/esphomeyaml/components/binary_sensor/index.rst index 39a196011..43afba1d0 100644 --- a/esphomeyaml/components/binary_sensor/index.rst +++ b/esphomeyaml/components/binary_sensor/index.rst @@ -39,6 +39,8 @@ Automations: when the button is pressed. See :ref:`binary_sensor-on_press`. - **on_release** (*Optional*, :ref:`Automation `): An automation to perform when the button is released. See :ref:`binary_sensor-on_release`. +- **on_state** (*Optional*, :ref:`Automation `): An automation to perform + when a state is published. See :ref:`binary_sensor-on_state`. - **on_click** (*Optional*, :ref:`Automation `): An automation to perform when the button is held down for a specified period of time. See :ref:`binary_sensor-on_click`. diff --git a/esphomeyaml/components/i2c.rst b/esphomeyaml/components/i2c.rst index f4e92d7ca..d04fe436f 100644 --- a/esphomeyaml/components/i2c.rst +++ b/esphomeyaml/components/i2c.rst @@ -9,7 +9,9 @@ I²C Bus :keywords: i2c, iic, bus This component sets up the i²c bus for your ESP32 or ESP8266. In order for those components -to work correctly, you need to define the i²c bus in your configuration. +to work correctly, you need to define the i²c bus in your configuration. Please note the ESP +will enable its internal 10kΩ pullup resistors for these pins, so you usually don't need to +put on external ones. .. code-block:: yaml diff --git a/esphomeyaml/components/sensor/dht12.rst b/esphomeyaml/components/sensor/dht12.rst index 415f9a9ea..c6b03638a 100644 --- a/esphomeyaml/components/sensor/dht12.rst +++ b/esphomeyaml/components/sensor/dht12.rst @@ -8,7 +8,7 @@ DHT12 Temperature+Humidity Sensor The ``dht12`` Temperature+Humidity sensor allows you to use your DHT12 (`datasheet `__, -`electrodragon`_) i2c-based sensor with esphomelib. +`electrodragon`_) i2c-based sensor with esphomelib. This sensor is also called AM2320 by some sellers. .. figure:: images/dht12-full.jpg :align: center diff --git a/esphomeyaml/devices/sonoff_4ch.yaml b/esphomeyaml/devices/sonoff_4ch.yaml index 74f9b32f0..6843c63b9 100644 --- a/esphomeyaml/devices/sonoff_4ch.yaml +++ b/esphomeyaml/devices/sonoff_4ch.yaml @@ -25,8 +25,7 @@ binary_sensor: inverted: True name: "Sonoff 4CH Button 1" on_press: - then: - switch.toggle: relay_1 + - switch.toggle: relay_1 - platform: gpio pin: number: GPIO9 @@ -34,8 +33,7 @@ binary_sensor: inverted: True name: "Sonoff 4CH Button 2" on_press: - then: - switch.toggle: relay_2 + - switch.toggle: relay_2 - platform: gpio pin: number: GPIO10 @@ -43,8 +41,7 @@ binary_sensor: inverted: True name: "Sonoff 4CH Button 3" on_press: - then: - switch.toggle: relay_3 + - switch.toggle: relay_3 - platform: gpio pin: number: GPIO14 @@ -52,8 +49,7 @@ binary_sensor: inverted: True name: "Sonoff 4CH Button 4" on_press: - then: - switch.toggle: relay_4 + - switch.toggle: relay_4 - platform: status name: "Sonoff 4CH Status" diff --git a/esphomeyaml/devices/sonoff_basic.rst b/esphomeyaml/devices/sonoff_basic.rst index 34130188f..a3c0f72af 100644 --- a/esphomeyaml/devices/sonoff_basic.rst +++ b/esphomeyaml/devices/sonoff_basic.rst @@ -85,13 +85,14 @@ exposes all of the basic functions. mode: INPUT_PULLUP inverted: True name: "Sonoff Basic Button" - - platform: status - name: "Sonoff Basic Status" + on_press: + - switch.toggle: relay switch: - platform: gpio name: "Sonoff Basic Relay" pin: GPIO12 + id: relay output: - platform: esp8266_pwm diff --git a/esphomeyaml/devices/sonoff_s20.yaml b/esphomeyaml/devices/sonoff_s20.yaml index 2a3b32cd9..057d35de6 100644 --- a/esphomeyaml/devices/sonoff_s20.yaml +++ b/esphomeyaml/devices/sonoff_s20.yaml @@ -25,7 +25,6 @@ binary_sensor: inverted: True name: "Sonoff S20 Button" on_press: - then: - switch.toggle: relay - platform: status name: "Sonoff S20 Status" diff --git a/esphomeyaml/guides/automations.rst b/esphomeyaml/guides/automations.rst index 88e84aa38..8a1637109 100644 --- a/esphomeyaml/guides/automations.rst +++ b/esphomeyaml/guides/automations.rst @@ -33,8 +33,8 @@ decided to also install a simple push button next to the dehumidifier on pin GPI A simple push on this button should toggle the state of the dehumidifier. You *could* write an automation to do this task in Home Assistant's automation engine, but -ideally the IoT should work without an internet connection and should not break without -the MQTT server being online. +ideally the IoT should work without an internet connection and should not break with +the MQTT server being offline. That's why, starting with esphomelib 1.7.0, there's a new automation engine. With it, you can write some basic (and also some more advanced) automations using a syntax that is