mirror of
https://github.com/home-assistant/core.git
synced 2025-07-28 15:47:12 +00:00
Rework devolo Home Control config flow (#147121)
This commit is contained in:
parent
f7cc260336
commit
6920dec352
@ -7,45 +7,39 @@ from typing import Any
|
|||||||
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant.config_entries import (
|
from homeassistant.config_entries import SOURCE_REAUTH, ConfigFlow, ConfigFlowResult
|
||||||
SOURCE_REAUTH,
|
|
||||||
ConfigEntry,
|
|
||||||
ConfigFlow,
|
|
||||||
ConfigFlowResult,
|
|
||||||
)
|
|
||||||
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
||||||
from homeassistant.core import callback
|
|
||||||
from homeassistant.helpers.service_info.zeroconf import ZeroconfServiceInfo
|
from homeassistant.helpers.service_info.zeroconf import ZeroconfServiceInfo
|
||||||
|
|
||||||
from . import configure_mydevolo
|
from . import configure_mydevolo
|
||||||
from .const import DOMAIN, SUPPORTED_MODEL_TYPES
|
from .const import DOMAIN, SUPPORTED_MODEL_TYPES
|
||||||
from .exceptions import CredentialsInvalid, UuidChanged
|
from .exceptions import CredentialsInvalid, UuidChanged
|
||||||
|
|
||||||
|
DATA_SCHEMA = vol.Schema(
|
||||||
|
{vol.Required(CONF_USERNAME): str, vol.Required(CONF_PASSWORD): str}
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class DevoloHomeControlFlowHandler(ConfigFlow, domain=DOMAIN):
|
class DevoloHomeControlFlowHandler(ConfigFlow, domain=DOMAIN):
|
||||||
"""Handle a devolo HomeControl config flow."""
|
"""Handle a devolo HomeControl config flow."""
|
||||||
|
|
||||||
VERSION = 1
|
VERSION = 1
|
||||||
|
|
||||||
_reauth_entry: ConfigEntry
|
|
||||||
|
|
||||||
def __init__(self) -> None:
|
|
||||||
"""Initialize devolo Home Control flow."""
|
|
||||||
self.data_schema = {
|
|
||||||
vol.Required(CONF_USERNAME): str,
|
|
||||||
vol.Required(CONF_PASSWORD): str,
|
|
||||||
}
|
|
||||||
|
|
||||||
async def async_step_user(
|
async def async_step_user(
|
||||||
self, user_input: dict[str, Any] | None = None
|
self, user_input: dict[str, Any] | None = None
|
||||||
) -> ConfigFlowResult:
|
) -> ConfigFlowResult:
|
||||||
"""Handle a flow initiated by the user."""
|
"""Handle a flow initiated by the user."""
|
||||||
if user_input is None:
|
errors: dict[str, str] = {}
|
||||||
return self._show_form(step_id="user")
|
|
||||||
try:
|
if user_input is not None:
|
||||||
return await self._connect_mydevolo(user_input)
|
try:
|
||||||
except CredentialsInvalid:
|
return await self._connect_mydevolo(user_input)
|
||||||
return self._show_form(step_id="user", errors={"base": "invalid_auth"})
|
except CredentialsInvalid:
|
||||||
|
errors["base"] = "invalid_auth"
|
||||||
|
|
||||||
|
return self.async_show_form(
|
||||||
|
step_id="user", data_schema=DATA_SCHEMA, errors=errors
|
||||||
|
)
|
||||||
|
|
||||||
async def async_step_zeroconf(
|
async def async_step_zeroconf(
|
||||||
self, discovery_info: ZeroconfServiceInfo
|
self, discovery_info: ZeroconfServiceInfo
|
||||||
@ -61,42 +55,47 @@ class DevoloHomeControlFlowHandler(ConfigFlow, domain=DOMAIN):
|
|||||||
self, user_input: dict[str, Any] | None = None
|
self, user_input: dict[str, Any] | None = None
|
||||||
) -> ConfigFlowResult:
|
) -> ConfigFlowResult:
|
||||||
"""Handle a flow initiated by zeroconf."""
|
"""Handle a flow initiated by zeroconf."""
|
||||||
if user_input is None:
|
errors: dict[str, str] = {}
|
||||||
return self._show_form(step_id="zeroconf_confirm")
|
|
||||||
try:
|
if user_input is not None:
|
||||||
return await self._connect_mydevolo(user_input)
|
try:
|
||||||
except CredentialsInvalid:
|
return await self._connect_mydevolo(user_input)
|
||||||
return self._show_form(
|
except CredentialsInvalid:
|
||||||
step_id="zeroconf_confirm", errors={"base": "invalid_auth"}
|
errors["base"] = "invalid_auth"
|
||||||
)
|
|
||||||
|
return self.async_show_form(
|
||||||
|
step_id="zeroconf_confirm", data_schema=DATA_SCHEMA, errors=errors
|
||||||
|
)
|
||||||
|
|
||||||
async def async_step_reauth(
|
async def async_step_reauth(
|
||||||
self, entry_data: Mapping[str, Any]
|
self, entry_data: Mapping[str, Any]
|
||||||
) -> ConfigFlowResult:
|
) -> ConfigFlowResult:
|
||||||
"""Handle reauthentication."""
|
"""Handle reauthentication."""
|
||||||
self._reauth_entry = self._get_reauth_entry()
|
|
||||||
self.data_schema = {
|
|
||||||
vol.Required(CONF_USERNAME, default=entry_data[CONF_USERNAME]): str,
|
|
||||||
vol.Required(CONF_PASSWORD): str,
|
|
||||||
}
|
|
||||||
return await self.async_step_reauth_confirm()
|
return await self.async_step_reauth_confirm()
|
||||||
|
|
||||||
async def async_step_reauth_confirm(
|
async def async_step_reauth_confirm(
|
||||||
self, user_input: dict[str, Any] | None = None
|
self, user_input: dict[str, Any] | None = None
|
||||||
) -> ConfigFlowResult:
|
) -> ConfigFlowResult:
|
||||||
"""Handle a flow initiated by reauthentication."""
|
"""Handle a flow initiated by reauthentication."""
|
||||||
if user_input is None:
|
errors: dict[str, str] = {}
|
||||||
return self._show_form(step_id="reauth_confirm")
|
data_schema = vol.Schema(
|
||||||
try:
|
{
|
||||||
return await self._connect_mydevolo(user_input)
|
vol.Required(CONF_USERNAME, default=self.init_data[CONF_USERNAME]): str,
|
||||||
except CredentialsInvalid:
|
vol.Required(CONF_PASSWORD): str,
|
||||||
return self._show_form(
|
}
|
||||||
step_id="reauth_confirm", errors={"base": "invalid_auth"}
|
)
|
||||||
)
|
|
||||||
except UuidChanged:
|
if user_input is not None:
|
||||||
return self._show_form(
|
try:
|
||||||
step_id="reauth_confirm", errors={"base": "reauth_failed"}
|
return await self._connect_mydevolo(user_input)
|
||||||
)
|
except CredentialsInvalid:
|
||||||
|
errors["base"] = "invalid_auth"
|
||||||
|
except UuidChanged:
|
||||||
|
errors["base"] = "reauth_failed"
|
||||||
|
|
||||||
|
return self.async_show_form(
|
||||||
|
step_id="reauth_confirm", data_schema=data_schema, errors=errors
|
||||||
|
)
|
||||||
|
|
||||||
async def _connect_mydevolo(self, user_input: dict[str, Any]) -> ConfigFlowResult:
|
async def _connect_mydevolo(self, user_input: dict[str, Any]) -> ConfigFlowResult:
|
||||||
"""Connect to mydevolo."""
|
"""Connect to mydevolo."""
|
||||||
@ -119,21 +118,11 @@ class DevoloHomeControlFlowHandler(ConfigFlow, domain=DOMAIN):
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
if self._reauth_entry.unique_id != uuid:
|
if self.unique_id != uuid:
|
||||||
# The old user and the new user are not the same. This could mess-up everything as all unique IDs might change.
|
# The old user and the new user are not the same. This could mess-up everything as all unique IDs might change.
|
||||||
raise UuidChanged
|
raise UuidChanged
|
||||||
|
|
||||||
|
reauth_entry = self._get_reauth_entry()
|
||||||
return self.async_update_reload_and_abort(
|
return self.async_update_reload_and_abort(
|
||||||
self._reauth_entry, data=user_input, unique_id=uuid
|
reauth_entry, data=user_input, unique_id=uuid
|
||||||
)
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _show_form(
|
|
||||||
self, step_id: str, errors: dict[str, str] | None = None
|
|
||||||
) -> ConfigFlowResult:
|
|
||||||
"""Show the form to the user."""
|
|
||||||
return self.async_show_form(
|
|
||||||
step_id=step_id,
|
|
||||||
data_schema=vol.Schema(self.data_schema),
|
|
||||||
errors=errors if errors else {},
|
|
||||||
)
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user