2016-05-07 00:55:26 +00:00
|
|
|
"""
|
|
|
|
A component which allows you to send data to Dweet.io.
|
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/dweet/
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
from datetime import timedelta
|
2016-08-22 09:28:58 +00:00
|
|
|
|
2016-05-07 00:55:26 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2016-08-22 09:28:58 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_NAME, CONF_WHITELIST, EVENT_STATE_CHANGED, STATE_UNKNOWN)
|
2016-05-07 00:55:26 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
from homeassistant.helpers import state as state_helper
|
|
|
|
from homeassistant.util import Throttle
|
|
|
|
|
2017-05-11 20:48:03 +00:00
|
|
|
REQUIREMENTS = ['dweepy==0.3.0']
|
2016-05-07 00:55:26 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2016-08-22 09:28:58 +00:00
|
|
|
DOMAIN = 'dweet'
|
2016-05-07 00:55:26 +00:00
|
|
|
|
|
|
|
MIN_TIME_BETWEEN_UPDATES = timedelta(seconds=1)
|
|
|
|
|
|
|
|
CONFIG_SCHEMA = vol.Schema({
|
|
|
|
DOMAIN: vol.Schema({
|
|
|
|
vol.Required(CONF_NAME): cv.string,
|
2016-08-22 09:28:58 +00:00
|
|
|
vol.Required(CONF_WHITELIST, default=[]):
|
|
|
|
vol.All(cv.ensure_list, [cv.entity_id]),
|
2016-05-07 00:55:26 +00:00
|
|
|
}),
|
2016-08-22 12:19:19 +00:00
|
|
|
}, extra=vol.ALLOW_EXTRA)
|
2016-05-07 00:55:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
def setup(hass, config):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Set up the Dweet.io component."""
|
2016-05-07 00:55:26 +00:00
|
|
|
conf = config[DOMAIN]
|
2016-08-22 09:28:58 +00:00
|
|
|
name = conf.get(CONF_NAME)
|
|
|
|
whitelist = conf.get(CONF_WHITELIST)
|
2016-05-07 00:55:26 +00:00
|
|
|
json_body = {}
|
|
|
|
|
|
|
|
def dweet_event_listener(event):
|
|
|
|
"""Listen for new messages on the bus and sends them to Dweet.io."""
|
|
|
|
state = event.data.get('new_state')
|
|
|
|
if state is None or state.state in (STATE_UNKNOWN, '') \
|
|
|
|
or state.entity_id not in whitelist:
|
|
|
|
return
|
|
|
|
|
|
|
|
try:
|
|
|
|
_state = state_helper.state_as_number(state)
|
|
|
|
except ValueError:
|
|
|
|
_state = state.state
|
|
|
|
|
|
|
|
json_body[state.attributes.get('friendly_name')] = _state
|
|
|
|
|
|
|
|
send_data(name, json_body)
|
|
|
|
|
|
|
|
hass.bus.listen(EVENT_STATE_CHANGED, dweet_event_listener)
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
@Throttle(MIN_TIME_BETWEEN_UPDATES)
|
|
|
|
def send_data(name, msg):
|
|
|
|
"""Send the collected data to Dweet.io."""
|
|
|
|
import dweepy
|
|
|
|
try:
|
|
|
|
dweepy.dweet_for(name, msg)
|
|
|
|
except dweepy.DweepyError:
|
2017-05-11 20:48:03 +00:00
|
|
|
_LOGGER.error("Error saving data to Dweet.io: %s", msg)
|