Fabian Affolter 6c71154f21 update icon
2015-06-17 09:15:29 +02:00

2.0 KiB

layout, title, description, date, sidebar, comments, sharing, footer
layout title description date sidebar comments sharing footer
page History support Instructions how to enable history support for Home Assistant. 2015-03-23 19:59 false false true true
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.

Implementation details

The history is stored in a SQLite databse 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

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)