2016-01-11 08:25:26 +00:00
|
|
|
"""
|
2016-03-08 10:46:32 +00:00
|
|
|
Support for thr Free Mobile SMS platform.
|
2016-01-11 08:25:26 +00:00
|
|
|
|
|
|
|
For more details about this platform, please refer to the documentation at
|
2016-01-12 10:30:12 +00:00
|
|
|
https://home-assistant.io/components/notify.free_mobile/
|
2016-01-11 08:25:26 +00:00
|
|
|
"""
|
|
|
|
import logging
|
2016-02-19 05:27:50 +00:00
|
|
|
|
|
|
|
from homeassistant.components.notify import DOMAIN, BaseNotificationService
|
|
|
|
from homeassistant.const import CONF_ACCESS_TOKEN, CONF_USERNAME
|
2016-01-11 08:25:26 +00:00
|
|
|
from homeassistant.helpers import validate_config
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
REQUIREMENTS = ['freesms==0.1.0']
|
|
|
|
|
|
|
|
|
|
|
|
def get_service(hass, config):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Get the Free Mobile SMS notification service."""
|
2016-01-11 08:25:26 +00:00
|
|
|
if not validate_config({DOMAIN: config},
|
|
|
|
{DOMAIN: [CONF_USERNAME,
|
|
|
|
CONF_ACCESS_TOKEN]},
|
|
|
|
_LOGGER):
|
|
|
|
return None
|
|
|
|
|
|
|
|
return FreeSMSNotificationService(config[CONF_USERNAME],
|
|
|
|
config[CONF_ACCESS_TOKEN])
|
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=too-few-public-methods
|
|
|
|
class FreeSMSNotificationService(BaseNotificationService):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Implement a notification service for the Free Mobile SMS service."""
|
2016-01-11 08:25:26 +00:00
|
|
|
|
|
|
|
def __init__(self, username, access_token):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Initialize the service."""
|
2016-01-11 08:25:26 +00:00
|
|
|
from freesms import FreeClient
|
|
|
|
self.free_client = FreeClient(username, access_token)
|
|
|
|
|
|
|
|
def send_message(self, message="", **kwargs):
|
2016-03-08 10:46:32 +00:00
|
|
|
"""Send a message to the Free Mobile user cell."""
|
2016-01-11 08:25:26 +00:00
|
|
|
resp = self.free_client.send_sms(message)
|
|
|
|
|
|
|
|
if resp.status_code == 400:
|
|
|
|
_LOGGER.error("At least one parameter is missing")
|
|
|
|
elif resp.status_code == 402:
|
2016-01-12 10:30:12 +00:00
|
|
|
_LOGGER.error("Too much SMS send in a few time")
|
2016-01-11 08:25:26 +00:00
|
|
|
elif resp.status_code == 403:
|
|
|
|
_LOGGER.error("Wrong Username/Password")
|
|
|
|
elif resp.status_code == 500:
|
|
|
|
_LOGGER.error("Server error, try later")
|