Here it is! Home Assistant 0.103 is released, which is the last major release
for this year. For the final stretch of this year, we’ve focussed on
cleaning things up. This release contains many things that were still
in progress (e.g., due to Hacktoberfest), lots of bugfixes; mainly
things that help to improve the stability and experience of Home Assistant.
We wish you happy holidays! As always, we skip a release cycle at the end
of the year, making this the final, major release of 2019. This gives all of
us time to enjoy the holidays with our families as well.
The first release of 2020, will be on 15 January.
Furthermore, we’d like to take the opportunity to thank all of our contributors,
no matter how small or big the contribution; code, documentation,
issue reporting, beta testing, supporters in our
forum and chat.
We salute and thank you and wish you the best for the new decade,
as we are entering 2020! ❤️
Service’s have been moved to their respective integration namespaces
For 0.103, an extensive cleanup has been taken place around the names of the
services. We realize this affects many users; therefore, we made sure all these
changes are in this release.
This change was driven by @raman325, who did an excellent job of completing
this in time for 0.103.
We used to have services that were placed inside other domains,
which wasn’t always the case, and therefore inconsistent.
So, for example, the service to add an item to Todoist was actually a service
call under the
This release, all services that were not placed correctly, are moved into their
respective integration domain. So, for the above example of
calendar.todoist_new_task, has been renamed to
We hope this brings a more streamlined experience to the use of services,
for now, and in the future. For a complete list of old vs. new service names,
a table as been added to the release notes, below.
Moving imports of Python packages
Internally, Home Assistant uses a lot of Python packages, that our integrations
are using. In the past weeks, the locations where all those imports take
place, was changed. This does not directly resonate with your system
and is mainly an internal cleanup.
A big shout out to the following contributors that together are responsible
for making hundreds of contributions the past weeks to help us out:
[@Bouni], @briglx, @djpremier, @exxamalte, @javicalle, @Michsior14,
[@Misiu], @mnigbur, [@Quentame], @springstan, @thaohtp, @tulindo
Thank you so much!
Python 3.6 support is deprecated
Since version 0.101, support for Python 3.6 has been deprecated. We are
currently working on Python 3.8 support, which is expected soon.
Therefore, this release marks the last release, which supports Python 3.6.
If you haven’t upgraded your system to Python 3.7 yet, it is recommended to
do so, to ensure you can keep using Home Assistant in the future.
If you are using Docker or Hass.io, you don’t have to worry about this, since
we provide a matching and working Python version for you.
Frenck Joins Nabu Casa
As announced during the State of the Union 2019,
Frenck has joined Nabu Casa.
We gave some love and attention to the automation editor,
fixing some bugs and adding some useful features.
Natural language improvements
We add area support for automations that you create with natural language,
and we try to pick the right area or device for you if you mentioned the name.
So you can now say: “Turn the lights on in the living room”, and it adds all
the light devices of your living room to the automation.
Choose individual devices, you can add or remove devices.
Screenshot of the result of the above query.
You can now edit every individual trigger, condition or action as YAML.
This makes it possible even to do very complicated automations in the
automation editor and allows you to copy parts of your automation quickly.
Screenshot of the automation YAML editor.
We also added the ability to rearrange your actions, so you don’t have to start
all over when you want to add a delay between 2 service calls.
Talking about the service call action, that has now an entity picker
to help you search for the right one.
Screenshot of automation actions.
In other news
The following integrations are added in this release:
The following platforms have been added to existing integrations:
If you are an existing user, make sure to read the this section before upgrading,
this helps you understand the changes and avoids having issues during an upgrade.
Updated Service Names
All services for use in Home Assistant are moved to their integration naming space.
The list below shows service calls and platforms which have been moved to their own integrations - @raman325
Other Breaking Changes
Mobile App - Loading the Mobile App no longer causes the Cloud integration to be loaded. If you relied on this, add
cloud: to your configuration.yaml. - (@balloob - #29373) (mobile_app docs)
Samsung TV - The behavior for next and previous track commands for Samsung TVs has changed. Before the change, the Samsung TV integration reacted to the two above commands sending the KEY_FF and KEY_REWIND commands. While watching TV programs, those two commands do nothing. After the change, the entity sends the KEY_CHUP and KEY_CHDOWN commands instead, thus allowing the user to change the channel using the media player standard Lovelace interface. The user doesn’t need to change anything in the configuration. - (@tulindo - #28213) (samsungtv docs)
Wake on LAN - The configuration key
mac_address: was renamed to
mac: to be in sync with the service. (@fabaff - #28830) (wake_on_lan docs)
PulseAudio Loopback Switch - The default port was incorrectly set to 4712, however, the official documentation states that the default port is 4713. Therefore, the port has been changed and all previously configured switches now need to listen to port 4713. - (@springstan - #28857) (pulseaudio_loopback docs)
Z-Wave - This changes the primary command class for z-wave thermostats in discovery schemas from
COMMAND_CLASS_THERMOSTAT_MODE. This will cause a typical dual setpoint thermostat to be correctly represented as a single entity. - (@oandrew - #27040) (zwave docs)
Transmission - Added host field to
add_torrent service in order to support multiple Transmission instances. (@engrbm87 - #28653) (transmission docs)
Opentherm Gateway - Adds device support. This change breaks enabled
binary_sensor entities, which are now disabled by default and can be re-enabled through the Devices panel. It also breaks
entity_id of the climate entity in some configurations. The
entity_id is now based on the
gateway_id rather than the configured
name to guarantee uniqueness. - (@mvn23 - #28722) (opentherm_gw docs)
Intent - If you use the built-in intents for shopping list, cover or light, you need to add
intent: to your
configuration.yaml. - (@balloob - #29280) (conversation docs) (cover docs) (light docs) (shopping_list docs)
Emulated Hue - As previous
entityid were not Hue compliant,
emulated_hue_ids.json will need to be cleared out and devices re-discovered and configured in Alexa / Google Home. This is a necessary growing pain to move the integration forward in a Hue-compliant fashion. - ([@NobleKangaroo] - #28317) (emulated_hue docs)
Miflora - Values for an unresponsive device aren’t reported any more as if they were valid, so it’s possible to send an alert. - (@ferbar - #29276) (miflora docs)
Example configuration YAML:
- id: plant_unreachable
alias: plant unreachable
- entity_id: sensor.plant_moisture
Entity ID - It is no longer possible to target all entities by not passing both
area_id to your service data. This feature was previously deprecated and has been printing warnings. The correct way to target all entities is to set
entity_id: all - (@balloob - #29178)
Heatmiser Thermostat - The Heatmiser integration has been updated to the latest version of the heatmiserV3 library, meaning less code inside HA, and more leverage on the library. The current version of the Heatmiser integration went out of date with the introduction of voluptuous. This has now been fixed, but it breaks the old config syntax slightly. See the updated docs for the new config format. - (@andylockran - #29006) (heatmiser docs)
Release 0.103.1 - December 18
Release 0.103.2 - December 19
- Fix dependency installation recursinog (@balloob)
Release 0.103.3 - December 20
Release 0.103.4 - December 22
Release 0.103.5 - December 28
Release 0.103.6 - January 6
If you need help…
…don’t hesitate to use our very active forums or join us for a little chat.
Experiencing issues introduced by this release? Please report them in our issue tracker. Make sure to fill in all fields of the issue template.
Read on →