Blog
We Have Apps Now
I have been working on a new subsystem to complement Home Assistant’s Automation and Scripting components. AppDaemon
is a python daemon that consumes events from Home Assistant and feeds them to snippets of python code called “Apps”. An App is a Python class that is instantiated possibly multiple times from AppDaemon
and registers callbacks for various system events. It is also able to inspect and set state and call services. The API provides a rich environment suited to home automation tasks that can also leverage all the power of Python.
0.26: Foursquare, Fast.com, FFMPEG and GPSD
It’s time for 0.26 and it’s again full of new features and fixes. First I want to highlight that we are now having 500 000 monthly pageviews on the website. A big milestone for us! It’s been an amazing journey. Big thanks to the Home Assistant community for being such a delightful bunch.
This release includes code contributed by 31 different people. The biggest change in this release is a new unit system. Instead of picking Celsius or Fahrenheit you’ll have to pick imperial or metric now. This influences the units for your temperature, distance, and weight. This will simplify any platform or component that needs to know this information. Big thanks to @Teagan42
- Core: Introduce notion of unit system (deprecates temperature unit option) (@Teagan42
) - Front end: Speed improvements (@balloob
) - Front end: Improve layout of state dev tool (@balloob
) -
Proximity: Allow definition of unit of measurement (@Teagan42
) -
Flux: Add mired and kelvin mode (@HBDK
) - Thermostat - Proliphix: Support for cooling (@sdague
) - Media Player - LG Netcast TV: Show screenshot of what is currently playing (@shmuelzon
) - Z-Wave improvements (@jnewland
, @turbokongen ) - Thermostat - heat control: now also able to control an AC (@mtreinish
) - Thermostat - heat control: allow specifying a minimum duration before switching (@mtreinish
) -
InfluxDB: Whitelist entities option added (@tchellomello
) - Sensor: Serial particulate matters sensors now supported (@open-homeautomation
) - Sensor - Fitbit: Fix unit system (@tchellomello
) - Light - Flux LED: Add support for [color and brightness][color] (@Danielhiversen
) - Media Player - Plex: Now able to report on music (@abcminiuser
) - Alarm Control Panel - Verisure: Now able to see who changed the alarm (@persandtrom)
- Thermostat - Honeywell: Add option to read and control HVAC mode (@Teagan42
) -
Foursquare component to receive instant notifications of checkins (@robbiet480
) - Camera: New FFMPEG platform allows to stream anything through front end (@pvizeli
) - Manage secrets with new command line script (@kellerza
) - Notify - SMTP: Allow embedding of images (@partofthething
) - Sensor: OhmConnect is now supported (@robbiet480
) -
panel_custom component allows the registering of new panels (@balloob
) - Light: New mqtt_json platform for working with JSON payload (@corbanmailloux
) - Sensor: New Fast.com platform to measure network bandwidth performance (@nkgilley
) - New pilight component to control 433 Mz devices (@DavidLP
) - Sensor: GPSD now supported (@fabaff
)
Hotfix 0.26.1 - August 14
- Fix serial_pm config validation (@open-homeautomation
) - Check for existence of system mode on Honeywell thermostats (@mKeRix
) - Fix unknown unit of measurement for hvac and thermostat component (@turbokongen
)
Hotfix 0.26.2 - August 15
- Fix Wemo: have PyWemo play nicely with the latest Requests (@pavoni
)
Hotfix 0.26.3 - August 19
- Media Player cover art would not work when an API password was set. Thanks to @maddox
for reporting it and @balloob for the fix.
Backward-incompatible changes
- A new unit system has superseded the temperature unit option in the core configuration. For now it is backwards compatible, but you should update soon:
# Configuration.yaml example
homeassistant:
# 'metric' for the metric system, 'imperial' for the imperial system
unit_system: metric
Optimizing the Home Assistant mobile web app
This blog post will go into detail about the recent performance optimizations that went into the Home Assistant front end. For people not familiar with the app, check out the demo and the source
TL; DR: Don’t hack the framework, separate responsibilities, ship less, use service workers, use (future) web standards.
This year at Google I/O I saw Monica from the Polymer team talk about web components and performance. In her talk she mentions a mantra
Do less and be lazy. It sounds so obvious and it took a while before it started to dawn on me. I think most of the code I write is pretty fast, but I don’t often stop to take a harder look at how and when it runs in practice. When do we need the result, can it be postponed?
And thus started my journey to take a critical look at how the Home Assistant app was working and how to make things faster. Below is the list of the different things that I did to make it fast.
I hope this list can be useful to other people, as a guide for optimizing their own apps or for avoiding pitfalls when building a new one.
The first thing to do is to measure. The Home Assistant front end is a mobile web app, so we shouldn’t measure this on a machine with 8 cores and gigabytes of ram but instead measure on devices you expect a mobile web app to run: phones. Below are two timelines recorded with Home Assistant 0.18.2 (pre-optimizations) and Google Chrome 53. On my Mac the app starts in 1400 milliseconds and on my Nexus 5x in ~6500 milliseconds (~4.5 times slower!).
Although the app takes 6500 milliseconds to load on my phone, it would perform well afterwards. Still, that initial load is unacceptable. You expect to open an app on your phone and be able to use it, quickly. After I applied all the changes described below, I managed to reduce startup time to 900 milliseconds (-35%) on my Mac and 2400 milliseconds (-63%) on my Nexus 5x. Check out the demo here.
Read on →
Laundry Sensors with NodeMCU and Home Assistant
This is a guest post by Home Assistant user and contributor Nolan Gilley
Today I’ll show you how I used Home Assistant, a NodeMCU (ESP8266), and a couple of accelerometers to automate our laundry room. This is a rewrite of an old post where I did the same thing using a Moteino & Raspberry Pi. This version only requires a NodeMCU.
We have an older washer and dryer which doesn’t have any form of notification when cycles complete. Home Assistant was the obvious solution, I just needed to create sensors for the washer and dryer. I tried using sound sensors but found them unreliable. I ended up using an accelerometer attached to the back of each appliance. I also added magnetic reed switches on the doors of the washer and dryer to detect whether they’re open or closed. I connected the accelerometers and reed switches to an NodeMCU which will relay the data to my MQTT broker.
Block diagram of schematic
Read on →0.25: Custom frontend panels, Jupyter notebooks, DirecTV.
When Home Assistant started the focus has always been on making a great developer experience. Allowing anyone to add support for their favorite devices to Home Assistant easily. This focus has been a great success since we now have 339 components and platforms!
Starting with this release, we are extending our extensibility to the frontend. Starting this release, any component can add its own page to the frontend. Examples of this today are the map, logbook and history. We are looking forward to all the crazy panels you’ll come up with!
We have also seen an exciting trend of people starting to visualize their Internet of Things data using Jupyter
This release also includes a bunch of new integrations, among others three new media player platforms. This means that today Home Assistant can talk to 26 different media players!
The brand-new iFrame panel component allows you to add other websites as pages in the Home Assistant frontend. They will show up in the sidebar and can be used the same way as you open the frontend in your browser but all within one view.
I would like to do a shoutout to @fabianhjr
- Frontend: Support for iFrame panels to adding other sites to sidebar (@balloob
) - Allow components to register custom frontend panels (@balloob
) - Add example custom_component react_panel showing custom panels (@balloob
) - Light: MagicLight/Flux WiFi Color LED Light support (@Danielhiversen
) - Script: Specify a delay using templates (@Teagan42
) - Media player: Russound RNET integration (@laf
) - Remote: Option specifying custom timeout when calling Home Assistant API (@n8henrie
) - Thermostat: Integration of KNX thermostats (@open-homeautomation
) - Thermostat: Support for HVAC mode of Nest devices (@vladonemo
) - InfluxDB: Option to specify additional tags (@open-homeautomation
) - Input slider: Support for float value (@ngraziano
) - Template: New filters (
timestamp_local
andtimestamp_utc
) (@fabaff) - Binary sensor - Wink: Water leak sensor support added (@w1ll1am23
) - Sensor - Tellduslive: Support for luminance of Fibaro Motion Sensor (@PetitCircuitLab
) - Switch - RPi GPIO: Fix when inverted logic (@zeroDenial)
- Z-Wave: Rollershutter update (@turbokongen
) - RFXtrx: Fire events when receiving signals from sensors and tests added (@Danielhiversen
) - Core: Add type
checking using mypy to the core (@fabianhjr ) - Remote: Support for getting the Configuration through the Python API (@fabaff
) - Media player: Support for DirecTV (@cbulock
) - Use browser timezone for frontend logbook and history dates (@armills
) - Light: New support for X10 lights (@fotoetienne
) - Sensor: Support for observing IMAP accounts (@danieljkemp
) - Media Player: Integration for MPC-HC (Media Player Classic - Home Cinema) mediaplayer (@abcminiuser
) - Notify:
location
extension for Telegram and photo bug fixed (@keatontaylorand @pvizeli ) - Groups: Lock states will now be properly grouped (@jwl17330536
) - Media Player: Added tests for Sonos to improve code quality (@americanwookie
) - Device Tracker: iCloud stability fixes (@kellerza
) - Sensor: Speedtest with improved error handling and state restoring (@nkgilley
) - Recorder: Stability fixes (@kellerza
) - Qwikswitch: Stability fixes (@kellerza
) - Light: Hyperion keeps now track of active color (@schneefux
)
Hotfix 0.25.1 - August 1
- Light - Z-Wave: Bring back delayed value update behavior (@jnewland
) - Recorder: Properly close session after execute (@kellerza
) - Media Player - Kodi: No longer block startup if connecting to wrong port (@shoekstra
) - Downgrade voluptuous to 0.8.9 as it blocked the upgrade for some (@balloob
)
Hotfix 0.25.2 - August 2
- Hotfix to make sure Z-Wave locks work again. Thanks to @tobiebooth for the quick fix.
Backward-incompatible changes
- Google Voice SMS notification support was removed.
ESP8266 and MicroPython - Part 1
Until a couple of weeks ago, the pre-built MicroPython binary for the ESP8266 was only available to backers of the Kickstarter campaign. This has changed now and it is available to the public for download
IoT Data Exploration with Jupyter Notebooks
This is the first blog post by Anton Kireyeu. A new contributor to Home Assistant who will focus on exploring and visualizing Home Assistant data.
As we learned in the recent blog post by Fabian, all operational data of your Home Assistant application is stored locally and is available for exploration. Our first steps were querying data with the DB Browser for SQLite
This post will help you get set up using a few popular data scientist tools to allow you to locally process your data:
- Pandas
: an open source tool for data analysis for Python - matplotlib
: a Python plotting library - Jupyter notebook
: application for creation and sharing of documents containing live code, visualizations and explanatory text
One of the graphs created with this tutorial.
TL; DR: Use this Jupyter Notebook
Visualize your IoT data
The history component is tracking everything that is going on within Home Assistant. This means that you have access to all stored information about your home. Our history is not a full-fledged graphical processing and visualization component as you may know from systems and network monitoring tools. The current limitation is that you only can select a day for a visual output of your information and not a period. Also, there is no possibility to drill down on a specific entity.
This blog post will show you ways to export data for reporting, visualization, or further analysis of automation rules.
Read on →0.24: SQLAlchemy, KNX, Join by Joaoapps, and SimpliSafe.
It’s time for Home Assistant 0.24 and it’s full of new integration for your Home. It contains some structural changes to our history which requires action from your end, so please keep reading.
MapQuest
Roy Hooper
pip3 install SQLAlchemy
hass --script db_migrator --config /path/to/config
You can omit the --config
option if you use the default configuration directory. Run the script with --help
to get more options.
- Config: Improved support for storing secrets (@kellerza
) - Sensor: Support for Yahoo! Weather (@pvizeli
) - Add scripts to command line to expose advanced options (@balloob
) - Alarm: SimpliSafe is now supported (@w1ll1am23
) - Core: Switch to SQLAlchemy for the Recorder component (@rhooper
) - Support for Join by Joaoapps added incl. Join Notify (@nkgilley
) - Media Player: Plex will no longer spam the logs if server goes offline (@dale3h
) - Sensor: APCUPSd Sensor now supports names, icons and units (@dale3h
) - Lock: Verisure entities will now use name instead of serial number for entity id (@turbokongen
) -
StatsD can now also export attributes (@bah2830
) - Support for KNX added (@usul27
) - Switch: TPLink HS100/HS110 now supported (@GadgetReactor
) - Stability fixes for RFXtrx (@Danielhiversen
) - Tweaks to Z-Wave (@turbokongen
) - Light: Brightness now clamped to 0-255 (@keatontaylor
) - Thermostat: Radiotherm HVAC mode now supported (@danieljkemp
) - Sensor: Google Travel times can now use dynamic locations for start/end (@bah2830
) - Notify: Allow sending photos to Telegram (@pvizeli
) - Frontend: Improve loading times (@balloob
) - Frontend: Fix stream not reconnecting after standby (@balloob
) - Frontend: Wait up to two seconds for new state before resetting toggle after toggling state (@balloob
)
Hotfix 0.24.1 - July 21
Quick hot fix after we found a bug in the migrator where it wouldn’t work with a database in a non-standard location. Thanks to @n8henrie
Backward-incompatible changes
- Migrating existing databases (see above).
- The APCUPSd Sensor was updated. This will need that you modify your
configuration.yaml
file. - Entity IDs of Verisure locks will change. This is a one time change but should improve readability.