Created
February 1, 2018 01:12
-
-
Save dgomes/643a0f912fcb2d42bdf88c4ddb8ba34b to your computer and use it in GitHub Desktop.
Home Assistant SQL Sensor
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
""" | |
Sensor from an SQL Query. | |
Example usage: | |
sensor: | |
- platform: sql | |
db_url: mysql://user:password@localhost/ | |
queries: | |
- name: DB size | |
query: 'SELECT table_schema "database", Round(Sum(data_length + index_length) / 1024 / 1024, 1) "value" FROM information_schema.tables WHERE table_schema="hass" GROUP BY table_schema;' | |
column: 'value' | |
unit_of_measurement: MB | |
""" | |
import logging | |
import voluptuous as vol | |
from homeassistant.components.sensor import PLATFORM_SCHEMA | |
from homeassistant.const import ( | |
CONF_NAME, CONF_UNIT_OF_MEASUREMENT, CONF_VALUE_TEMPLATE, | |
STATE_UNKNOWN) | |
import homeassistant.helpers.config_validation as cv | |
from homeassistant.helpers.entity import Entity | |
_LOGGER = logging.getLogger(__name__) | |
REQUIREMENTS = ['sqlalchemy==1.2.1'] | |
DEFAULT_URL = 'sqlite:///{hass_config_path}/home-assistant_v2.db' | |
DEFAULT_NAME = 'Sql_sensor' | |
CONF_QUERIES = 'queries' | |
CONF_QUERY = 'query' | |
CONF_COLUMN_NAME = 'column' | |
CONF_DB_URL = 'db_url' | |
_QUERY_SCHEME = vol.Schema({ | |
vol.Required(CONF_NAME): cv.string, | |
vol.Required(CONF_QUERY): cv.string, | |
vol.Required(CONF_COLUMN_NAME): cv.string, | |
vol.Optional(CONF_UNIT_OF_MEASUREMENT): cv.string, | |
vol.Optional(CONF_VALUE_TEMPLATE): cv.template, | |
}) | |
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({ | |
vol.Required(CONF_QUERIES): [_QUERY_SCHEME], | |
vol.Optional(CONF_DB_URL, default=DEFAULT_URL): cv.string, | |
}) | |
def setup_platform(hass, config, add_devices, discovery_info=None): | |
db_url = config.get(CONF_DB_URL) | |
s = [] | |
for q in config.get(CONF_QUERIES): | |
name = q.get(CONF_NAME) | |
query = q.get(CONF_QUERY) | |
unit = q.get(CONF_UNIT_OF_MEASUREMENT) | |
value_template = q.get(CONF_VALUE_TEMPLATE) | |
column_name = q.get(CONF_COLUMN_NAME) | |
if value_template is not None: | |
value_template.hass = hass | |
sensor = SQLSensor(name, db_url, query, column_name, unit, value_template) | |
s.append(sensor) | |
add_devices(s, True) | |
class SQLSensor(Entity): | |
"""An SQL sensor.""" | |
def __init__(self, name, db_url, query, column_name, unit_of_measurement, value_template): | |
"""Initialize SQL sensor""" | |
self._name = name | |
self._query = query | |
self._unit_of_measurement = unit_of_measurement | |
self._value_template = value_template | |
self._column_name = column_name | |
import sqlalchemy | |
from sqlalchemy.orm import sessionmaker, scoped_session | |
engine = sqlalchemy.create_engine(db_url) | |
self.Session = scoped_session(sessionmaker(bind=engine)) | |
self._state = STATE_UNKNOWN | |
self._attributes = None | |
@property | |
def name(self): | |
"""Return the name of the query.""" | |
return self._name | |
@property | |
def state(self): | |
"""Return the query's current state.""" | |
return self._state | |
@property | |
def unit_of_measurement(self): | |
"""Return the unit of measurement.""" | |
return self._unit_of_measurement | |
@property | |
def device_state_attributes(self): | |
"""Return the state attributes.""" | |
return self._attributes | |
def update(self): | |
"""Retrieve sensor data from the query.""" | |
s = self.Session() | |
result = s.execute(self._query) | |
for r in result: | |
_LOGGER.debug(r.items()) | |
data = r[self._column_name] | |
self._attributes = {attr: str(column) for attr, column in r.items()} | |
if self._value_template is not None: | |
self._state = self._value_template.async_render_with_possible_json_value( | |
data, None) | |
else: | |
self._state = data | |
s.close() |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This custom component has been superseded by: https://www.home-assistant.io/components/sensor.sql/