core/homeassistant/components/notify/free_mobile.py

52 lines
1.7 KiB
Python
Raw Normal View History

"""
2016-03-08 10:46:32 +00:00
Support for thr Free Mobile SMS platform.
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/
"""
import logging
2016-02-19 05:27:50 +00:00
2016-09-06 19:33:11 +00:00
import voluptuous as vol
from homeassistant.components.notify import (
PLATFORM_SCHEMA, BaseNotificationService)
2016-02-19 05:27:50 +00:00
from homeassistant.const import CONF_ACCESS_TOKEN, CONF_USERNAME
2016-09-06 19:33:11 +00:00
import homeassistant.helpers.config_validation as cv
2016-11-21 16:32:05 +00:00
REQUIREMENTS = ['freesms==0.1.1']
_LOGGER = logging.getLogger(__name__)
2016-09-06 19:33:11 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_USERNAME): cv.string,
vol.Required(CONF_ACCESS_TOKEN): cv.string,
})
def get_service(hass, config, discovery_info=None):
2016-03-08 10:46:32 +00:00
"""Get the Free Mobile SMS notification service."""
return FreeSMSNotificationService(
config[CONF_USERNAME], config[CONF_ACCESS_TOKEN])
class FreeSMSNotificationService(BaseNotificationService):
2016-03-08 10:46:32 +00:00
"""Implement a notification service for the Free Mobile SMS service."""
def __init__(self, username, access_token):
2016-03-08 10:46:32 +00:00
"""Initialize the service."""
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."""
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")
elif resp.status_code == 403:
_LOGGER.error("Wrong Username/Password")
elif resp.status_code == 500:
_LOGGER.error("Server error, try later")