2016-01-21 02:02:32 +01:00
|
|
|
"""
|
2016-01-21 02:14:11 +01:00
|
|
|
homeassistant.components.notify.twitter
|
2016-01-27 07:52:46 +01:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2016-01-21 02:02:32 +01:00
|
|
|
Twitter platform for notify component.
|
|
|
|
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/notify.twitter/
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
from homeassistant.helpers import validate_config
|
|
|
|
from homeassistant.components.notify import (
|
|
|
|
DOMAIN, BaseNotificationService)
|
|
|
|
from homeassistant.const import CONF_ACCESS_TOKEN
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
REQUIREMENTS = ['TwitterAPI==2.3.6']
|
|
|
|
|
|
|
|
CONF_CONSUMER_KEY = "consumer_key"
|
|
|
|
CONF_CONSUMER_SECRET = "consumer_secret"
|
|
|
|
CONF_ACCESS_TOKEN_SECRET = "access_token_secret"
|
|
|
|
|
|
|
|
|
|
|
|
def get_service(hass, config):
|
|
|
|
""" Get the Twitter notification service. """
|
|
|
|
|
|
|
|
if not validate_config({DOMAIN: config},
|
|
|
|
{DOMAIN: [CONF_CONSUMER_KEY, CONF_CONSUMER_SECRET,
|
|
|
|
CONF_ACCESS_TOKEN,
|
|
|
|
CONF_ACCESS_TOKEN_SECRET]},
|
|
|
|
_LOGGER):
|
|
|
|
return None
|
|
|
|
|
|
|
|
return TwitterNotificationService(config[CONF_CONSUMER_KEY],
|
|
|
|
config[CONF_CONSUMER_SECRET],
|
|
|
|
config[CONF_ACCESS_TOKEN],
|
|
|
|
config[CONF_ACCESS_TOKEN_SECRET])
|
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=too-few-public-methods
|
|
|
|
class TwitterNotificationService(BaseNotificationService):
|
|
|
|
""" Implements notification service for the Twitter service. """
|
|
|
|
|
|
|
|
def __init__(self, consumer_key, consumer_secret, access_token_key,
|
|
|
|
access_token_secret):
|
|
|
|
from TwitterAPI import TwitterAPI
|
|
|
|
self.api = TwitterAPI(consumer_key, consumer_secret, access_token_key,
|
|
|
|
access_token_secret)
|
|
|
|
|
|
|
|
def send_message(self, message="", **kwargs):
|
|
|
|
""" Tweet some message. """
|
|
|
|
resp = self.api.request('statuses/update', {'status': message})
|
|
|
|
if resp.status_code != 200:
|
|
|
|
import json
|
|
|
|
obj = json.loads(resp.text)
|
|
|
|
error_message = obj['errors'][0]['message']
|
|
|
|
error_code = obj['errors'][0]['code']
|
|
|
|
_LOGGER.error("Error %s : %s (Code %s)", resp.status_code,
|
|
|
|
error_message,
|
|
|
|
error_code)
|