mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 05:07:41 +00:00
Clean Airly config flow (#44352)
This commit is contained in:
parent
3ac9ead850
commit
ccbf857266
@ -15,11 +15,7 @@ from homeassistant.const import (
|
|||||||
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
|
|
||||||
from .const import ( # pylint:disable=unused-import
|
from .const import DOMAIN, NO_AIRLY_SENSORS # pylint:disable=unused-import
|
||||||
DEFAULT_NAME,
|
|
||||||
DOMAIN,
|
|
||||||
NO_AIRLY_SENSORS,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class AirlyFlowHandler(config_entries.ConfigFlow, domain=DOMAIN):
|
class AirlyFlowHandler(config_entries.ConfigFlow, domain=DOMAIN):
|
||||||
@ -28,13 +24,9 @@ class AirlyFlowHandler(config_entries.ConfigFlow, domain=DOMAIN):
|
|||||||
VERSION = 1
|
VERSION = 1
|
||||||
CONNECTION_CLASS = config_entries.CONN_CLASS_CLOUD_POLL
|
CONNECTION_CLASS = config_entries.CONN_CLASS_CLOUD_POLL
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
"""Initialize."""
|
|
||||||
self._errors = {}
|
|
||||||
|
|
||||||
async def async_step_user(self, user_input=None):
|
async def async_step_user(self, user_input=None):
|
||||||
"""Handle a flow initialized by the user."""
|
"""Handle a flow initialized by the user."""
|
||||||
self._errors = {}
|
errors = {}
|
||||||
|
|
||||||
websession = async_get_clientsession(self.hass)
|
websession = async_get_clientsession(self.hass)
|
||||||
|
|
||||||
@ -52,40 +44,33 @@ class AirlyFlowHandler(config_entries.ConfigFlow, domain=DOMAIN):
|
|||||||
)
|
)
|
||||||
except AirlyError as err:
|
except AirlyError as err:
|
||||||
if err.status_code == HTTP_UNAUTHORIZED:
|
if err.status_code == HTTP_UNAUTHORIZED:
|
||||||
self._errors["base"] = "invalid_api_key"
|
errors["base"] = "invalid_api_key"
|
||||||
else:
|
else:
|
||||||
if not location_valid:
|
if not location_valid:
|
||||||
self._errors["base"] = "wrong_location"
|
errors["base"] = "wrong_location"
|
||||||
|
|
||||||
if not self._errors:
|
if not errors:
|
||||||
return self.async_create_entry(
|
return self.async_create_entry(
|
||||||
title=user_input[CONF_NAME], data=user_input
|
title=user_input[CONF_NAME], data=user_input
|
||||||
)
|
)
|
||||||
|
|
||||||
return self._show_config_form(
|
|
||||||
name=DEFAULT_NAME,
|
|
||||||
api_key="",
|
|
||||||
latitude=self.hass.config.latitude,
|
|
||||||
longitude=self.hass.config.longitude,
|
|
||||||
)
|
|
||||||
|
|
||||||
def _show_config_form(self, name=None, api_key=None, latitude=None, longitude=None):
|
|
||||||
"""Show the configuration form to edit data."""
|
|
||||||
return self.async_show_form(
|
return self.async_show_form(
|
||||||
step_id="user",
|
step_id="user",
|
||||||
data_schema=vol.Schema(
|
data_schema=vol.Schema(
|
||||||
{
|
{
|
||||||
vol.Required(CONF_API_KEY, default=api_key): str,
|
vol.Required(CONF_API_KEY): str,
|
||||||
vol.Optional(
|
vol.Optional(
|
||||||
CONF_LATITUDE, default=self.hass.config.latitude
|
CONF_LATITUDE, default=self.hass.config.latitude
|
||||||
): cv.latitude,
|
): cv.latitude,
|
||||||
vol.Optional(
|
vol.Optional(
|
||||||
CONF_LONGITUDE, default=self.hass.config.longitude
|
CONF_LONGITUDE, default=self.hass.config.longitude
|
||||||
): cv.longitude,
|
): cv.longitude,
|
||||||
vol.Optional(CONF_NAME, default=name): str,
|
vol.Optional(
|
||||||
|
CONF_NAME, default=self.hass.config.location_name
|
||||||
|
): str,
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
errors=self._errors,
|
errors=errors,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user