2016-02-07 14:20:52 -08:00

2.2 KiB

layout, title, description, date, sidebar, comments, sharing, footer, logo, ha_category
layout title description date sidebar comments sharing footer logo ha_category
page History Instructions how to enable history support for Home Assistant. 2015-03-23 19:59 true false true true home-assistant.png History

This component will track everything that is going on within Home Assistant and allows the user to browse through it.

To enable the history option in your installation, add the following to your configuration.yaml file:

# Example configuration.yaml entry
history:

Events are saved in a local database. Google Graphs is used to draw the graph. Drawing is happening 100% in your browser. No data is transferred to anyone at any time.

{% linkable_title Implementation details %}

The history is stored in a SQLite database home-assistant.db within your config directory.

  • events table is all events except time_changed that happened while recorder component was running.
  • states table contains all the new_state values of state_changed events.
  • Inside the states table you have:
    • entity_id: the entity_id of the entity
    • state: the state of the entity
    • attributes: JSON of the state attributes
    • last_changed: timestamp last time the state has changed. A state_changed event can happen when just attributes change.
    • last_updated: timestamp anything has changed (state, attributes)
    • created: timestamp this entry was inserted into the database

When the history component queries the states table it only selects states where the state has changed: WHERE last_changed=last_updated

{% linkable_title On dates %}

SQLite databases do not support native dates. That's why all the dates are saved in seconds since the UNIX epoch. Convert them manually using this site or in Python:

from datetime import datetime
datetime.fromtimestamp(1422830502)

{% linkable_title API %}

The history information are also available through the RESTful API.