core/homeassistant/components/daikin/config_flow.py

127 lines
4.1 KiB
Python
Raw Normal View History

"""Config flow for the Daikin platform."""
import asyncio
import logging
2020-05-06 11:59:07 +00:00
from uuid import uuid4
from aiohttp import ClientError, web_exceptions
from async_timeout import timeout
2020-05-06 11:59:07 +00:00
from pydaikin.daikin_base import Appliance
import voluptuous as vol
from homeassistant import config_entries
2020-05-06 11:59:07 +00:00
from homeassistant.const import CONF_HOST, CONF_PASSWORD
2020-05-06 11:59:07 +00:00
from .const import CONF_KEY, CONF_UUID, KEY_IP, KEY_MAC, TIMEOUT
_LOGGER = logging.getLogger(__name__)
2019-07-31 19:25:30 +00:00
@config_entries.HANDLERS.register("daikin")
class FlowHandler(config_entries.ConfigFlow):
"""Handle a config flow."""
VERSION = 1
CONNECTION_CLASS = config_entries.CONN_CLASS_LOCAL_POLL
2020-05-18 14:57:52 +00:00
def __init__(self):
"""Initialize the Daikin config flow."""
self.host = None
@property
def schema(self):
"""Return current schema."""
return vol.Schema(
{
vol.Required(CONF_HOST, default=self.host): str,
vol.Optional(CONF_KEY): str,
vol.Optional(CONF_PASSWORD): str,
}
)
async def _create_entry(self, host, mac, key=None, uuid=None, password=None):
"""Register new entry."""
# Check if mac already is registered
2020-05-18 14:57:52 +00:00
await self.async_set_unique_id(mac)
self._abort_if_unique_id_configured()
2020-05-06 11:59:07 +00:00
return self.async_create_entry(
title=host,
data={
CONF_HOST: host,
KEY_MAC: mac,
CONF_KEY: key,
CONF_UUID: uuid,
CONF_PASSWORD: password,
},
)
2020-05-06 11:59:07 +00:00
async def _create_device(self, host, key=None, password=None):
"""Create device."""
2020-05-06 11:59:07 +00:00
# BRP07Cxx devices needs uuid together with key
if key:
uuid = str(uuid4())
else:
uuid = None
key = None
if not password:
password = None
try:
with timeout(TIMEOUT):
2020-05-06 11:59:07 +00:00
device = await Appliance.factory(
host,
self.hass.helpers.aiohttp_client.async_get_clientsession(),
key=key,
uuid=uuid,
password=password,
)
except asyncio.TimeoutError:
return self.async_show_form(
step_id="user",
2020-05-18 14:57:52 +00:00
data_schema=self.schema,
errors={"base": "device_timeout"},
)
except web_exceptions.HTTPForbidden:
return self.async_show_form(
2020-05-18 14:57:52 +00:00
step_id="user", data_schema=self.schema, errors={"base": "forbidden"},
)
except ClientError:
_LOGGER.exception("ClientError")
return self.async_show_form(
2020-05-18 14:57:52 +00:00
step_id="user", data_schema=self.schema, errors={"base": "device_fail"},
)
except Exception: # pylint: disable=broad-except
_LOGGER.exception("Unexpected error creating device")
return self.async_show_form(
2020-05-18 14:57:52 +00:00
step_id="user", data_schema=self.schema, errors={"base": "device_fail"},
)
2020-05-06 11:59:07 +00:00
mac = device.mac
2020-05-18 14:57:52 +00:00
return await self._create_entry(host, mac, key, uuid, password)
async def async_step_user(self, user_input=None):
"""User initiated config flow."""
if user_input is None:
2020-05-18 14:57:52 +00:00
return self.async_show_form(step_id="user", data_schema=self.schema)
2020-05-06 11:59:07 +00:00
return await self._create_device(
user_input[CONF_HOST],
user_input.get(CONF_KEY),
user_input.get(CONF_PASSWORD),
)
async def async_step_import(self, user_input):
"""Import a config entry."""
host = user_input.get(CONF_HOST)
if not host:
return await self.async_step_user()
return await self._create_device(host)
2020-05-18 14:57:52 +00:00
async def async_step_discovery(self, discovery_info):
"""Initialize step from discovery."""
2020-05-18 14:57:52 +00:00
_LOGGER.debug("Discovered device: %s", discovery_info)
await self.async_set_unique_id(discovery_info[KEY_MAC])
self._abort_if_unique_id_configured()
self.host = discovery_info[KEY_IP]
return await self.async_step_user()