""" This component provides support for RainMachine sprinkler controllers. For more details about this component, please refer to the documentation at https://home-assistant.io/components/rainmachine/ """ import logging from datetime import timedelta import voluptuous as vol from homeassistant.helpers import config_validation as cv, discovery from homeassistant.const import ( CONF_IP_ADDRESS, CONF_PASSWORD, CONF_PORT, CONF_SSL, CONF_SWITCHES) REQUIREMENTS = ['regenmaschine==0.4.1'] _LOGGER = logging.getLogger(__name__) DATA_RAINMACHINE = 'data_rainmachine' DOMAIN = 'rainmachine' NOTIFICATION_ID = 'rainmachine_notification' NOTIFICATION_TITLE = 'RainMachine Component Setup' CONF_ZONE_RUN_TIME = 'zone_run_time' DEFAULT_ATTRIBUTION = 'Data provided by Green Electronics LLC' DEFAULT_PORT = 8080 DEFAULT_SSL = True MIN_SCAN_TIME = timedelta(seconds=1) MIN_SCAN_TIME_FORCED = timedelta(milliseconds=100) SWITCH_SCHEMA = vol.Schema({ vol.Optional(CONF_ZONE_RUN_TIME): cv.positive_int }) CONFIG_SCHEMA = vol.Schema( { DOMAIN: vol.Schema({ vol.Required(CONF_IP_ADDRESS): cv.string, vol.Required(CONF_PASSWORD): cv.string, vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port, vol.Optional(CONF_SSL, default=DEFAULT_SSL): cv.boolean, vol.Optional(CONF_SWITCHES): SWITCH_SCHEMA, }) }, extra=vol.ALLOW_EXTRA) def setup(hass, config): """Set up the RainMachine component.""" from regenmaschine import Authenticator, Client from regenmaschine.exceptions import HTTPError from requests.exceptions import ConnectTimeout conf = config[DOMAIN] ip_address = conf[CONF_IP_ADDRESS] password = conf[CONF_PASSWORD] port = conf[CONF_PORT] ssl = conf[CONF_SSL] _LOGGER.debug('Setting up RainMachine client') try: auth = Authenticator.create_local( ip_address, password, port=port, https=ssl) client = Client(auth) mac = client.provision.wifi()['macAddress'] hass.data[DATA_RAINMACHINE] = (client, mac) except (HTTPError, ConnectTimeout, UnboundLocalError) as exc_info: _LOGGER.error('An error occurred: %s', str(exc_info)) hass.components.persistent_notification.create( 'Error: {0}
' 'You will need to restart hass after fixing.' ''.format(exc_info), title=NOTIFICATION_TITLE, notification_id=NOTIFICATION_ID) return False _LOGGER.debug('Setting up switch platform') switch_config = conf.get(CONF_SWITCHES, {}) discovery.load_platform(hass, 'switch', DOMAIN, switch_config, config) _LOGGER.debug('Setup complete') return True