2016-10-17 00:05:01 +00:00
|
|
|
"""
|
|
|
|
A component which allows you to send data to Emoncms.
|
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/emoncms_history/
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
from datetime import timedelta
|
|
|
|
|
|
|
|
import requests
|
2017-04-24 03:41:09 +00:00
|
|
|
import voluptuous as vol
|
2016-10-17 00:05:01 +00:00
|
|
|
|
2017-04-24 03:41:09 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2016-10-17 00:05:01 +00:00
|
|
|
from homeassistant.const import (
|
2016-10-30 08:58:34 +00:00
|
|
|
CONF_API_KEY, CONF_WHITELIST, CONF_URL, STATE_UNKNOWN, STATE_UNAVAILABLE,
|
2016-10-17 00:05:01 +00:00
|
|
|
CONF_SCAN_INTERVAL)
|
|
|
|
from homeassistant.helpers import state as state_helper
|
|
|
|
from homeassistant.helpers.event import track_point_in_time
|
|
|
|
from homeassistant.util import dt as dt_util
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2016-10-30 08:58:34 +00:00
|
|
|
DOMAIN = 'emoncms_history'
|
|
|
|
CONF_INPUTNODE = 'inputnode'
|
2016-10-17 00:05:01 +00:00
|
|
|
|
|
|
|
CONFIG_SCHEMA = vol.Schema({
|
|
|
|
DOMAIN: vol.Schema({
|
|
|
|
vol.Required(CONF_API_KEY): cv.string,
|
|
|
|
vol.Required(CONF_URL): cv.string,
|
|
|
|
vol.Required(CONF_INPUTNODE): cv.positive_int,
|
|
|
|
vol.Required(CONF_WHITELIST): cv.entity_ids,
|
|
|
|
vol.Optional(CONF_SCAN_INTERVAL, default=30): cv.positive_int,
|
|
|
|
}),
|
|
|
|
}, extra=vol.ALLOW_EXTRA)
|
|
|
|
|
|
|
|
|
|
|
|
def setup(hass, config):
|
2016-10-30 08:58:34 +00:00
|
|
|
"""Set up the Emoncms history component."""
|
2016-10-17 00:05:01 +00:00
|
|
|
conf = config[DOMAIN]
|
|
|
|
whitelist = conf.get(CONF_WHITELIST)
|
|
|
|
|
|
|
|
def send_data(url, apikey, node, payload):
|
2016-10-30 08:58:34 +00:00
|
|
|
"""Send payload data to Emoncms."""
|
2016-10-17 00:05:01 +00:00
|
|
|
try:
|
2016-10-30 08:58:34 +00:00
|
|
|
fullurl = '{}/input/post.json'.format(url)
|
|
|
|
data = {"apikey": apikey, "data": payload}
|
|
|
|
parameters = {"node": node}
|
|
|
|
req = requests.post(
|
|
|
|
fullurl, params=parameters, data=data, allow_redirects=True,
|
|
|
|
timeout=5)
|
2016-10-17 00:05:01 +00:00
|
|
|
|
|
|
|
except requests.exceptions.RequestException:
|
2017-04-24 03:41:09 +00:00
|
|
|
_LOGGER.error("Error saving data '%s' to '%s'", payload, fullurl)
|
2016-10-17 00:05:01 +00:00
|
|
|
|
|
|
|
else:
|
|
|
|
if req.status_code != 200:
|
2017-04-24 03:41:09 +00:00
|
|
|
_LOGGER.error(
|
|
|
|
"Error saving data %s to %s (http status code = %d)",
|
|
|
|
payload, fullurl, req.status_code)
|
2016-10-17 00:05:01 +00:00
|
|
|
|
|
|
|
def update_emoncms(time):
|
2018-01-27 19:58:27 +00:00
|
|
|
"""Send whitelisted entities states regularly to Emoncms."""
|
2016-10-17 00:05:01 +00:00
|
|
|
payload_dict = {}
|
|
|
|
|
|
|
|
for entity_id in whitelist:
|
|
|
|
state = hass.states.get(entity_id)
|
|
|
|
|
|
|
|
if state is None or state.state in (
|
2016-10-30 08:58:34 +00:00
|
|
|
STATE_UNKNOWN, '', STATE_UNAVAILABLE):
|
2016-10-17 00:05:01 +00:00
|
|
|
continue
|
|
|
|
|
|
|
|
try:
|
2017-04-24 03:41:09 +00:00
|
|
|
payload_dict[entity_id] = state_helper.state_as_number(state)
|
2016-10-17 00:05:01 +00:00
|
|
|
except ValueError:
|
|
|
|
continue
|
|
|
|
|
2017-04-24 03:41:09 +00:00
|
|
|
if payload_dict:
|
2016-10-17 00:05:01 +00:00
|
|
|
payload = "{%s}" % ",".join("{}:{}".format(key, val)
|
|
|
|
for key, val in
|
|
|
|
payload_dict.items())
|
|
|
|
|
|
|
|
send_data(conf.get(CONF_URL), conf.get(CONF_API_KEY),
|
|
|
|
str(conf.get(CONF_INPUTNODE)), payload)
|
|
|
|
|
|
|
|
track_point_in_time(hass, update_emoncms, time +
|
2016-10-30 08:58:34 +00:00
|
|
|
timedelta(seconds=conf.get(CONF_SCAN_INTERVAL)))
|
2016-10-17 00:05:01 +00:00
|
|
|
|
|
|
|
update_emoncms(dt_util.utcnow())
|
|
|
|
return True
|