core/homeassistant/components/life360/config_flow.py

109 lines
3.9 KiB
Python
Raw Normal View History

2019-06-06 23:07:15 +00:00
"""Config flow to configure Life360 integration."""
from collections import OrderedDict
import logging
from life360 import Life360Error, LoginError
2019-06-06 23:07:15 +00:00
import voluptuous as vol
from homeassistant import config_entries
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
from .const import CONF_AUTHORIZATION, DOMAIN
from .helpers import get_api
_LOGGER = logging.getLogger(__name__)
DOCS_URL = "https://www.home-assistant.io/integrations/life360"
2019-06-06 23:07:15 +00:00
class Life360ConfigFlow(config_entries.ConfigFlow, domain=DOMAIN):
2019-06-06 23:07:15 +00:00
"""Life360 integration config flow."""
VERSION = 1
def __init__(self):
"""Initialize."""
self._api = get_api()
self._username = vol.UNDEFINED
self._password = vol.UNDEFINED
@property
def configured_usernames(self):
"""Return tuple of configured usernames."""
entries = self._async_current_entries()
2019-06-06 23:07:15 +00:00
if entries:
return (entry.data[CONF_USERNAME] for entry in entries)
return ()
async def async_step_user(self, user_input=None):
"""Handle a user initiated config flow."""
errors = {}
if user_input is not None:
self._username = user_input[CONF_USERNAME]
self._password = user_input[CONF_PASSWORD]
try:
# pylint: disable=no-value-for-parameter
vol.Email()(self._username)
authorization = await self.hass.async_add_executor_job(
self._api.get_authorization, self._username, self._password
2019-07-31 19:25:30 +00:00
)
2019-06-06 23:07:15 +00:00
except vol.Invalid:
2019-07-31 19:25:30 +00:00
errors[CONF_USERNAME] = "invalid_username"
2019-06-06 23:07:15 +00:00
except LoginError:
errors["base"] = "invalid_auth"
except Life360Error as error:
_LOGGER.error(
"Unexpected error communicating with Life360 server: %s", error
)
errors["base"] = "unknown"
2019-06-06 23:07:15 +00:00
else:
if self._username in self.configured_usernames:
errors["base"] = "already_configured"
2019-06-06 23:07:15 +00:00
else:
return self.async_create_entry(
title=self._username,
data={
CONF_USERNAME: self._username,
CONF_PASSWORD: self._password,
2019-07-31 19:25:30 +00:00
CONF_AUTHORIZATION: authorization,
2019-06-06 23:07:15 +00:00
},
2019-07-31 19:25:30 +00:00
description_placeholders={"docs_url": DOCS_URL},
2019-06-06 23:07:15 +00:00
)
data_schema = OrderedDict()
data_schema[vol.Required(CONF_USERNAME, default=self._username)] = str
data_schema[vol.Required(CONF_PASSWORD, default=self._password)] = str
return self.async_show_form(
2019-07-31 19:25:30 +00:00
step_id="user",
2019-06-06 23:07:15 +00:00
data_schema=vol.Schema(data_schema),
errors=errors,
2019-07-31 19:25:30 +00:00
description_placeholders={"docs_url": DOCS_URL},
2019-06-06 23:07:15 +00:00
)
async def async_step_import(self, user_input):
"""Import a config flow from configuration."""
username = user_input[CONF_USERNAME]
password = user_input[CONF_PASSWORD]
try:
authorization = await self.hass.async_add_executor_job(
self._api.get_authorization, username, password
)
2019-06-06 23:07:15 +00:00
except LoginError:
2019-07-31 19:25:30 +00:00
_LOGGER.error("Invalid credentials for %s", username)
return self.async_abort(reason="invalid_auth")
except Life360Error as error:
_LOGGER.error(
"Unexpected error communicating with Life360 server: %s", error
)
return self.async_abort(reason="unknown")
2019-06-06 23:07:15 +00:00
return self.async_create_entry(
title=f"{username} (from configuration)",
2019-06-06 23:07:15 +00:00
data={
CONF_USERNAME: username,
CONF_PASSWORD: password,
2019-07-31 19:25:30 +00:00
CONF_AUTHORIZATION: authorization,
},
2019-06-06 23:07:15 +00:00
)