mirror of
https://github.com/esphome/esphome-docs.git
synced 2025-01-15 20:31:55 +01:00
Update changelog
This commit is contained in:
parent
8c7a814213
commit
243457c582
@ -7,7 +7,88 @@ Changelog - Version 1.9.0
|
|||||||
:author: Otto Winter
|
:author: Otto Winter
|
||||||
:author_twitter: @OttoWinter_
|
: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 </esphomeyaml/components/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 <https://rc--home-assistant-docs.netlify.com/components/esphome/>`__
|
||||||
|
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 <api-mqtt_to_native>`.
|
||||||
|
|
||||||
|
Python 3 Comparability
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
PlatformIO has finally implemented `python 3 support <https://github.com/platformio/platformio-core/issues/895>`__
|
||||||
|
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 <https://github.com/hassio-addons>`__ 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.
|
||||||
|
|
||||||
Past Changelogs
|
Past Changelogs
|
||||||
---------------
|
---------------
|
||||||
|
@ -32,8 +32,8 @@ Configuration variables:
|
|||||||
|
|
||||||
.. _api-mqtt_to_native:
|
.. _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,
|
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).
|
highly efficient and requires almost zero setup (whereas MQTT requires you to set up an MQTT broker first).
|
||||||
|
@ -39,6 +39,8 @@ Automations:
|
|||||||
when the button is pressed. See :ref:`binary_sensor-on_press`.
|
when the button is pressed. See :ref:`binary_sensor-on_press`.
|
||||||
- **on_release** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
- **on_release** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
when the button is released. See :ref:`binary_sensor-on_release`.
|
when the button is released. See :ref:`binary_sensor-on_release`.
|
||||||
|
- **on_state** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when a state is published. See :ref:`binary_sensor-on_state`.
|
||||||
- **on_click** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
- **on_click** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
when the button is held down for a specified period of time.
|
when the button is held down for a specified period of time.
|
||||||
See :ref:`binary_sensor-on_click`.
|
See :ref:`binary_sensor-on_click`.
|
||||||
|
@ -9,7 +9,9 @@ I²C Bus
|
|||||||
:keywords: i2c, iic, bus
|
:keywords: i2c, iic, bus
|
||||||
|
|
||||||
This component sets up the i²c bus for your ESP32 or ESP8266. In order for those components
|
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
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ DHT12 Temperature+Humidity Sensor
|
|||||||
|
|
||||||
The ``dht12`` Temperature+Humidity sensor allows you to use your DHT12
|
The ``dht12`` Temperature+Humidity sensor allows you to use your DHT12
|
||||||
(`datasheet <http://www.robototehnika.ru/file/DHT12.pdf>`__,
|
(`datasheet <http://www.robototehnika.ru/file/DHT12.pdf>`__,
|
||||||
`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
|
.. figure:: images/dht12-full.jpg
|
||||||
:align: center
|
:align: center
|
||||||
|
@ -25,8 +25,7 @@ binary_sensor:
|
|||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff 4CH Button 1"
|
name: "Sonoff 4CH Button 1"
|
||||||
on_press:
|
on_press:
|
||||||
then:
|
- switch.toggle: relay_1
|
||||||
switch.toggle: relay_1
|
|
||||||
- platform: gpio
|
- platform: gpio
|
||||||
pin:
|
pin:
|
||||||
number: GPIO9
|
number: GPIO9
|
||||||
@ -34,8 +33,7 @@ binary_sensor:
|
|||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff 4CH Button 2"
|
name: "Sonoff 4CH Button 2"
|
||||||
on_press:
|
on_press:
|
||||||
then:
|
- switch.toggle: relay_2
|
||||||
switch.toggle: relay_2
|
|
||||||
- platform: gpio
|
- platform: gpio
|
||||||
pin:
|
pin:
|
||||||
number: GPIO10
|
number: GPIO10
|
||||||
@ -43,8 +41,7 @@ binary_sensor:
|
|||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff 4CH Button 3"
|
name: "Sonoff 4CH Button 3"
|
||||||
on_press:
|
on_press:
|
||||||
then:
|
- switch.toggle: relay_3
|
||||||
switch.toggle: relay_3
|
|
||||||
- platform: gpio
|
- platform: gpio
|
||||||
pin:
|
pin:
|
||||||
number: GPIO14
|
number: GPIO14
|
||||||
@ -52,8 +49,7 @@ binary_sensor:
|
|||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff 4CH Button 4"
|
name: "Sonoff 4CH Button 4"
|
||||||
on_press:
|
on_press:
|
||||||
then:
|
- switch.toggle: relay_4
|
||||||
switch.toggle: relay_4
|
|
||||||
- platform: status
|
- platform: status
|
||||||
name: "Sonoff 4CH Status"
|
name: "Sonoff 4CH Status"
|
||||||
|
|
||||||
|
@ -85,13 +85,14 @@ exposes all of the basic functions.
|
|||||||
mode: INPUT_PULLUP
|
mode: INPUT_PULLUP
|
||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff Basic Button"
|
name: "Sonoff Basic Button"
|
||||||
- platform: status
|
on_press:
|
||||||
name: "Sonoff Basic Status"
|
- switch.toggle: relay
|
||||||
|
|
||||||
switch:
|
switch:
|
||||||
- platform: gpio
|
- platform: gpio
|
||||||
name: "Sonoff Basic Relay"
|
name: "Sonoff Basic Relay"
|
||||||
pin: GPIO12
|
pin: GPIO12
|
||||||
|
id: relay
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
|
@ -25,7 +25,6 @@ binary_sensor:
|
|||||||
inverted: True
|
inverted: True
|
||||||
name: "Sonoff S20 Button"
|
name: "Sonoff S20 Button"
|
||||||
on_press:
|
on_press:
|
||||||
then:
|
|
||||||
- switch.toggle: relay
|
- switch.toggle: relay
|
||||||
- platform: status
|
- platform: status
|
||||||
name: "Sonoff S20 Status"
|
name: "Sonoff S20 Status"
|
||||||
|
@ -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.
|
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
|
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
|
ideally the IoT should work without an internet connection and should not break with
|
||||||
the MQTT server being online.
|
the MQTT server being offline.
|
||||||
|
|
||||||
That's why, starting with esphomelib 1.7.0, there's a new automation engine. With it, you
|
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
|
can write some basic (and also some more advanced) automations using a syntax that is
|
||||||
|
Loading…
Reference in New Issue
Block a user