2019-02-16 23:25:23 +01:00
ESPHome Core Configuration
==========================
2018-05-13 11:37:02 +02:00
2018-11-14 22:12:27 +01:00
.. seo ::
2019-02-16 23:25:23 +01:00
:description: Instructions for setting up the core ESPHome configuration.
2021-11-16 03:19:33 +01:00
:image: cloud-circle.svg
2018-11-14 22:12:27 +01:00
2019-02-16 23:25:23 +01:00
Here you specify some core information that ESPHome needs to create
2018-05-13 11:37:02 +02:00
firmwares. Most importantly, this is the section of the configuration
2022-01-10 14:51:27 +01:00
where you specify the **name** of the node.
2018-05-13 11:37:02 +02:00
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-05-13 11:37:02 +02:00
# Example configuration entry
2019-02-16 23:25:23 +01:00
esphome:
2018-05-13 11:37:02 +02:00
name: livingroom
2019-10-14 11:27:41 +02:00
comment: Living room ESP32 controller
2022-02-10 23:10:43 +01:00
esp32:
2018-05-13 11:37:02 +02:00
board: nodemcu-32s
2021-06-08 01:56:31 +02:00
.. _esphome-configuration_variables:
2018-05-13 11:37:02 +02:00
Configuration variables:
2018-08-24 22:44:01 +02:00
------------------------
2018-05-13 11:37:02 +02:00
2018-06-01 18:10:00 +02:00
- **name** (**Required** , string): This is the name of the node. It
2021-05-20 16:00:53 +02:00
should always be unique in your ESPHome network. May only contain lowercase
2021-11-25 20:52:46 +01:00
characters, digits and hyphens, and can be at most 31 characters long.
See :ref: `esphome-changing_node_name` .
2018-06-13 22:38:49 +02:00
Advanced options:
2019-02-16 23:25:23 +01:00
- **build_path** (*Optional* , string): Customize where ESPHome will store the build files
2021-11-25 20:51:47 +01:00
for your node. By default, ESPHome puts the PlatformIO project it uses to build the
firmware in the `` .esphome/build/<NODE> `` directory, but you can customize this
behavior using this option.
2020-05-10 21:27:59 +02:00
- **platformio_options** (*Optional* , mapping): Additional options to pass over to PlatformIO in the
2019-02-16 23:25:23 +01:00
platformio.ini file. See :ref: `esphome-platformio_options` .
2021-09-13 22:15:14 +02:00
- **includes** (*Optional* , list of files): A list of C/C++ files to include in the main (auto-generated) sketch file
2018-11-26 16:50:50 +01:00
for custom components. The paths in this list are relative to the directory where the YAML configuration file
2022-01-10 14:51:27 +01:00
is in. See :ref: `esphome-includes` .
2021-11-25 20:52:30 +01:00
- **libraries** (*Optional* , list of libraries): A list of libraries to include in the project. See
2022-01-10 14:51:27 +01:00
:ref: `esphome-libraries` .
2019-10-14 11:27:41 +02:00
- **comment** (*Optional* , string): Additional text information about this node. Only for display in UI.
2021-11-03 20:00:26 +01:00
- **name_add_mac_suffix** (*Optional* , boolean): Appends the last 3 bytes of the mac address of the device to
2021-07-28 23:56:11 +02:00
the name in the form `` <name>-aabbcc `` . Defaults to `` false `` .
2021-03-17 21:45:31 +01:00
See :ref: `esphome-mac_suffix` .
2021-06-09 03:04:07 +02:00
- **project** (*Optional* ): ESPHome Creator's Project information. See :ref: `esphome-creators_project` .
- **name** (**Required** , string): Name of the project
- **version** (**Required** , string): Version of the project
2022-10-05 05:31:24 +02:00
- **min_version** (*Optional* , string): The minimum ESPHome version required to compile this configuration.
See :ref: `esphome-min_version` .
2022-10-27 01:17:26 +02:00
- **compile_process_limit** (*Optional* , int): The maximum number of simultaneous compile processes to run.
Defaults to the number of cores of the CPU which is also the maximum you can set.
2021-06-09 03:04:07 +02:00
2022-02-10 23:10:43 +01:00
Old-style platform options, which have been moved to the platform-specific :doc: `esp32 </components/esp32>` and
:doc: `esp8266 </components/esp8266>` sections but are still accepted here for compatibility reasons (usage not
2022-01-10 14:51:27 +01:00
recommended for new projects):
2021-10-19 23:08:37 +02:00
2022-01-10 14:51:27 +01:00
- **platform** (**Required** , string): The platform used, either `` esp8266 `` or `` esp32 `` .
- **board** (**Required** , string): The board used, see
2021-10-19 23:08:37 +02:00
:doc: `esp32 </components/esp32>` and :doc: `esp8266 </components/esp8266>` for more information.
2022-01-10 14:51:27 +01:00
- **arduino_version** (*Optional* , string): The version of the Arduino framework to compile the project against.
2021-10-19 23:08:37 +02:00
- **esp8266_restore_from_flash** (*Optional* , boolean): For ESP8266s, whether to store some persistent preferences in flash
memory.
2019-02-26 16:55:46 +01:00
2018-06-13 22:38:49 +02:00
Automations:
2018-06-07 17:07:02 +02:00
- **on_boot** (*Optional* , :ref: `Automation <automation>` ): An automation to perform
2019-02-16 23:25:23 +01:00
when the node starts. See :ref: `esphome-on_boot` .
2018-06-07 17:07:02 +02:00
- **on_shutdown** (*Optional* , :ref: `Automation <automation>` ): An automation to perform
2019-02-16 23:25:23 +01:00
right before the node shuts down. See :ref: `esphome-on_shutdown` .
2018-09-23 19:00:31 +02:00
- **on_loop** (*Optional* , :ref: `Automation <automation>` ): An automation to perform
2019-02-16 23:25:23 +01:00
on each `` loop() `` iteration. See :ref: `esphome-on_loop` .
2018-06-01 18:10:00 +02:00
2019-02-16 23:25:23 +01:00
.. _esphome-on_boot:
2018-06-07 17:07:02 +02:00
`` on_boot ``
2018-08-24 22:44:01 +02:00
-----------
2018-06-07 17:07:02 +02:00
This automation will be triggered when the ESP boots up. By default, it is executed after everything else
is already set up. You can however change this using the `` priority `` parameter.
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-07 17:07:02 +02:00
2019-02-16 23:25:23 +01:00
esphome:
2018-06-07 17:07:02 +02:00
# ...
on_boot:
2021-08-19 22:24:30 +02:00
priority: 600
2018-06-07 17:07:02 +02:00
# ...
then:
2018-11-10 14:31:27 +01:00
- switch.turn_off: switch_1
2018-06-07 17:07:02 +02:00
Configuration variables:
2019-06-02 10:56:04 +02:00
- **priority** (*Optional* , float): The priority to execute your custom initialization code. A higher value
2021-05-20 16:00:53 +02:00
means a high priority and thus also your code being executed earlier. Please note this is an ESPHome-internal
2021-08-19 22:24:30 +02:00
value and any change will not be marked as a breaking change. Defaults to `` 600 `` . Priorities (you can use any value between them too):
2018-06-07 17:07:02 +02:00
2019-06-02 10:56:04 +02:00
- `` 800.0 `` : This is where all hardware initialization of vital components is executed. For example setting switches
2018-06-07 17:07:02 +02:00
to their initial state.
2019-06-02 10:56:04 +02:00
- `` 600.0 `` : This is where most sensors are set up.
- `` 250.0 `` : At this priority, WiFi is initialized.
- `` 200.0 `` : Network connections like MQTT/native API are set up at this priority.
- `` -100.0 `` : At this priority, pretty much everything should already be initialized.
2018-06-07 17:07:02 +02:00
- See :ref: `Automation <automation>` .
2019-02-16 23:25:23 +01:00
.. _esphome-on_shutdown:
2018-06-07 17:07:02 +02:00
`` on_shutdown ``
2018-08-24 22:44:01 +02:00
---------------
2018-06-07 17:07:02 +02:00
This automation will be triggered when the ESP is about to shut down. Shutting down is usually caused by
too many WiFi/MQTT connection attempts, Over-The-Air updates being applied or through the :doc: `deep_sleep` .
.. note ::
It's not guaranteed that all components are in a connected state when this automation is triggered. For
2022-08-10 03:10:53 +02:00
example, the MQTT client may have already disconnected. For use-cases that require specific shutdown ordering, look at the `` priority `` parameter.
2018-06-07 17:07:02 +02:00
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-07 17:07:02 +02:00
2019-02-16 23:25:23 +01:00
esphome:
2018-06-07 17:07:02 +02:00
# ...
on_shutdown:
2022-08-10 03:10:53 +02:00
priority: 700
2018-06-07 17:07:02 +02:00
then:
2018-11-10 14:31:27 +01:00
- switch.turn_off: switch_1
2018-06-07 17:07:02 +02:00
2022-08-10 03:10:53 +02:00
Configuration variables:
- **priority** (*Optional* , float): The priority to execute your custom shutdown code. A higher value
2022-10-05 05:31:24 +02:00
means a high priority and in case of shutdown triggers that the code is executed **later** .
2022-08-10 03:10:53 +02:00
Priority is used primarily for the initialization order of components. Shutdowns for these components are handled in *reverse* order, such that e.g. sensors (600) are shutdown before the hardware components (800) they depend on.
2022-10-05 05:31:24 +02:00
Please note this is an ESPHome-internal value and any change will not be marked as a breaking change.
2022-08-10 03:10:53 +02:00
Defaults to `` 600 `` . For priority values refer to the list in the :ref: `esphome-on_boot` section.
2022-10-05 05:31:24 +02:00
2022-08-10 03:10:53 +02:00
- See :ref: `Automation <automation>` .
2018-06-07 17:07:02 +02:00
2019-02-16 23:25:23 +01:00
.. _esphome-on_loop:
2018-09-23 19:00:31 +02:00
`` on_loop ``
-----------
This automation will be triggered on every `` loop() `` iteration (usually around every 16 milliseconds).
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-09-23 19:00:31 +02:00
2019-02-16 23:25:23 +01:00
esphome:
2018-09-23 19:00:31 +02:00
# ...
on_loop:
then:
# do something
2019-02-16 23:25:23 +01:00
.. _esphome-platformio_options:
2019-01-06 18:56:14 +01:00
`` platformio_options ``
----------------------
2020-05-10 21:27:59 +02:00
PlatformIO supports a number of options in its `` platformio.ini `` file. With the `` platformio_options ``
parameter you can tell ESPHome what options to pass into the `` env `` section of the PlatformIO file
2022-01-10 14:51:27 +01:00
(note you can also do this by editing the `` platformio.ini `` file manually).
2019-01-06 18:56:14 +01:00
2020-05-10 21:27:59 +02:00
You can view a full list of PlatformIO options here: https://docs.platformio.org/en/latest/projectconf/section_env.html
2019-01-06 18:56:14 +01:00
.. code-block :: yaml
# Example configuration entry
2019-02-16 23:25:23 +01:00
esphome:
2019-01-06 18:56:14 +01:00
# ...
platformio_options:
upload_speed: 115200
board_build.f_flash: 80000000L
2019-05-29 19:28:30 +02:00
.. _esphome-includes:
`` includes ``
------------
2020-05-10 21:27:59 +02:00
With `` includes `` you can include source files in the generated PlatformIO project.
2019-05-29 19:28:30 +02:00
All files declared with this option are copied to the project each time it is compiled.
2021-11-25 20:51:47 +01:00
You can always look at the generated PlatformIO project (`` .esphome/build/<NODE> `` ) to see what
2019-05-29 19:28:30 +02:00
is happening - and if you want you can even copy the include files directly into the `` src/ `` folder.
The `` includes `` option is only a helper option that does that for you.
.. code-block :: yaml
# Example configuration entry
esphome:
# ...
includes:
- my_switch.h
This option behaves differently depending on what the included file is pointing at:
2021-09-13 22:15:14 +02:00
- If the include string is pointing at a directory, the entire directory tree is copied into the
src/ folder.
- If the include string points to a header file (.h, .hpp, .tcc), it is copied in the src/ folder
AND included in the `` main.cpp `` file. This way the lambda code can access it.
- If the include string points to a regular source file (.c, .cpp), it is copied in the src/ folder
AND compiled into the binary. This way implementation of classes and functions in header files can
be provided.
2019-10-18 09:22:48 +02:00
2021-11-25 20:52:30 +01:00
.. _esphome-libraries:
`` libraries ``
-------------
With the `` libraries `` option it is possible to include libraries in the PlatformIO project. These libraries will then
be compiled into the resulting firmware, and can be used in code from :ref: `lambdas <config-lambda>` and from
custom components.
.. code-block :: yaml
# Example configuration entry
esphome:
# ...
libraries:
# a library from PlatformIO
- espressif/esp32-camera
# a library bundled with Arduino
- Wire
# use the git version of a library used by a component
- esphome/Improv=https://github.com/improv-wifi/sdk-cpp.git#v1.0.0
The most common usage of this option is to include third-party libraries that are available in the `PlatformIO registry
<https://platformio.org/lib> `__. They can be added by listing their name under this option. It is also possible to use
specific versions, or to fetch libraries from a file or git repository. ESPHome accepts the same syntax as the
`pio lib install <https://docs.platformio.org/en/latest/userguide/lib/cmd_install.html> `__ command.
Using `` <name>=<source> `` syntax, it is possible to override the version used for libraries that are automatically added
by one of ESPHome's components. This can be useful during development to make ESPHome use a custom fork of a library.
By default, ESPHome does not include any libraries into the project. This means that libraries that are bundled with
Arduino, such as `` Wire `` or `` EEPROM `` , aren't available. If you need to use them, you should list them manually under
this option. If they are used by another library, they should be listed before the library that uses them.
2021-10-13 05:34:24 +02:00
.. _preferences-flash_write_interval:
Adjusting flash writes
------------------------
.. code-block :: yaml
# Example configuration entry
preferences:
flash_write_interval: 1min
- **flash_write_interval** (*Optional* , :ref: `config-time` ): Customize the frequency in which data is
flushed to the flash. This setting helps to prevent rapid changes to a component from being quickly
written to the flash and wearing it out. Defaults to `` 1min `` .
As all devices have a limited number of flash write cycles, this setting helps to reduce the number of flash writes
due to quickly changing components. In the past, when components such as `` light `` , `` switch `` , `` fan `` and `` globals ``
were changed, the state was immediately committed to flash. The result of this was that the last state of these
components would always restore to its last state on power loss, however, this has the cost of potentially quickly
damaging the flash if these components are quickly changed.
A safety feature has thus been implemented to mitigate issues resulting from the limited number of flash write cycles,
the state is first stored in memory before being flushed to flash after the `` flash_write_interval `` has passed. This
results in fewer flash writes, preserving the flash health.
This behavior can be disabled by setting `` flash_write_interval `` to `` 0s `` to immediately commit the state to flash,
however, be aware that this may lead to increased flash wearing and a shortened device lifespan!
2021-10-19 23:08:37 +02:00
For :doc: `ESP8266 </components/esp8266>` , `` restore_from_flash `` must also be set to `` true `` for states to be written to flash.
2019-05-29 19:28:30 +02:00
2019-06-19 11:42:30 +02:00
.. _esphome-changing_node_name:
Changing ESPHome Node Name
--------------------------
Trying to change the name of a node or its address in the network?
You can do so with the `` use_address `` option of the :doc: `WiFi configuration <wifi>` .
Change the device name or address in your YAML to the new value and additionally
set `` use_address `` to point to the old address like so:
.. code-block :: yaml
# Step 1. Changing name from test8266 to kitchen
esphome:
name: kitchen
# ...
wifi:
# ...
use_address: test8266.local
Now upload the updated config to the device. As a second step, you now need to remove the
`` use_address `` option from your configuration again so that subsequent uploads will work again
(otherwise it will try to upload to the old address).
.. code-block :: yaml
# Step 2
esphome:
name: kitchen
# ...
wifi:
# ...
# Remove or comment out use_address
# use_address: test8266.local
The same procedure can be done for changing the static IP of a device.
2021-03-17 21:45:31 +01:00
.. _esphome-mac_suffix:
Adding the MAC address as a suffix to the device name
-----------------------------------------------------
Using `` name_add_mac_suffix `` allows the user to compile a single binary file to flash
many of the same device and they will all have unique names/hostnames.
Note that you will still need to create an individual YAML config file if you want to
OTA update the devices in the future.
2021-06-09 03:04:07 +02:00
.. _esphome-creators_project:
Project information
-------------------
This allows creators to add the project name and version to the compiled code. It is currently only
exposed via the logger, mDNS and the device_info response via the native API. The format of the name
2021-06-09 08:56:15 +02:00
should be `` author_name.project_name `` .
.. code-block :: yaml
# Example configuration
esphome:
...
project:
name: "jesse.leds_party"
version: "1.0.0"
2022-10-05 05:31:24 +02:00
.. _esphome-min_version:
Minimum ESPHome version
-----------------------
This allows YAML files to specify the minimum version of ESPHome required to compile.
This is useful in the case of packages where a published package might use features only
available in a newer version of ESPHome. This allows for a more friendly error message.
2021-06-09 03:04:07 +02:00
2018-06-03 12:50:44 +02:00
See Also
2018-08-24 22:44:01 +02:00
--------
2018-06-03 12:50:44 +02:00
2019-02-07 13:54:45 +01:00
- :ghedit: `Edit`