2019-08-28 17:35:09 +00:00
|
|
|
"""Config flow for the Cert Expiry platform."""
|
2021-08-29 16:57:18 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2019-10-23 06:34:12 +00:00
|
|
|
import logging
|
2019-12-08 22:32:50 +00:00
|
|
|
|
2019-08-28 17:35:09 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant import config_entries
|
2020-03-02 13:44:24 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_PORT
|
2019-08-28 17:35:09 +00:00
|
|
|
|
2021-03-30 04:02:56 +00:00
|
|
|
from .const import DEFAULT_PORT, DOMAIN
|
2020-03-02 13:44:24 +00:00
|
|
|
from .errors import (
|
|
|
|
ConnectionRefused,
|
|
|
|
ConnectionTimeout,
|
|
|
|
ResolveFailed,
|
|
|
|
ValidationFailure,
|
|
|
|
)
|
2020-06-18 16:29:46 +00:00
|
|
|
from .helper import get_cert_expiry_timestamp
|
2019-08-28 17:35:09 +00:00
|
|
|
|
2019-10-23 06:34:12 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-08-28 17:35:09 +00:00
|
|
|
|
|
|
|
class CertexpiryConfigFlow(config_entries.ConfigFlow, domain=DOMAIN):
|
|
|
|
"""Handle a config flow."""
|
|
|
|
|
|
|
|
VERSION = 1
|
|
|
|
|
|
|
|
def __init__(self) -> None:
|
|
|
|
"""Initialize the config flow."""
|
2021-08-29 16:57:18 +00:00
|
|
|
self._errors: dict[str, str] = {}
|
2019-08-28 17:35:09 +00:00
|
|
|
|
2019-09-17 20:39:46 +00:00
|
|
|
async def _test_connection(self, user_input=None):
|
2020-03-02 13:44:24 +00:00
|
|
|
"""Test connection to the server and try to get the certificate."""
|
2019-08-28 17:35:09 +00:00
|
|
|
try:
|
2020-06-18 16:29:46 +00:00
|
|
|
await get_cert_expiry_timestamp(
|
2020-03-02 13:44:24 +00:00
|
|
|
self.hass,
|
|
|
|
user_input[CONF_HOST],
|
|
|
|
user_input.get(CONF_PORT, DEFAULT_PORT),
|
2019-09-17 20:39:46 +00:00
|
|
|
)
|
2019-08-28 17:35:09 +00:00
|
|
|
return True
|
2020-03-02 13:44:24 +00:00
|
|
|
except ResolveFailed:
|
2019-08-28 17:35:09 +00:00
|
|
|
self._errors[CONF_HOST] = "resolve_failed"
|
2020-03-02 13:44:24 +00:00
|
|
|
except ConnectionTimeout:
|
2019-08-28 17:35:09 +00:00
|
|
|
self._errors[CONF_HOST] = "connection_timeout"
|
2020-03-02 13:44:24 +00:00
|
|
|
except ConnectionRefused:
|
|
|
|
self._errors[CONF_HOST] = "connection_refused"
|
|
|
|
except ValidationFailure:
|
|
|
|
return True
|
2019-08-28 17:35:09 +00:00
|
|
|
return False
|
|
|
|
|
|
|
|
async def async_step_user(self, user_input=None):
|
2020-01-31 16:33:00 +00:00
|
|
|
"""Step when user initializes a integration."""
|
2019-08-28 17:35:09 +00:00
|
|
|
self._errors = {}
|
|
|
|
if user_input is not None:
|
2020-03-02 13:44:24 +00:00
|
|
|
host = user_input[CONF_HOST]
|
|
|
|
port = user_input.get(CONF_PORT, DEFAULT_PORT)
|
|
|
|
await self.async_set_unique_id(f"{host}:{port}")
|
|
|
|
self._abort_if_unique_id_configured()
|
|
|
|
|
|
|
|
if await self._test_connection(user_input):
|
|
|
|
title_port = f":{port}" if port != DEFAULT_PORT else ""
|
|
|
|
title = f"{host}{title_port}"
|
|
|
|
return self.async_create_entry(
|
2020-08-27 11:56:20 +00:00
|
|
|
title=title,
|
|
|
|
data={CONF_HOST: host, CONF_PORT: port},
|
2020-03-02 13:44:24 +00:00
|
|
|
)
|
2021-02-13 12:21:37 +00:00
|
|
|
if self.context["source"] == config_entries.SOURCE_IMPORT:
|
2020-03-02 13:44:24 +00:00
|
|
|
_LOGGER.error("Config import failed for %s", user_input[CONF_HOST])
|
|
|
|
return self.async_abort(reason="import_failed")
|
2019-08-28 17:35:09 +00:00
|
|
|
else:
|
|
|
|
user_input = {}
|
|
|
|
user_input[CONF_HOST] = ""
|
|
|
|
user_input[CONF_PORT] = DEFAULT_PORT
|
|
|
|
|
|
|
|
return self.async_show_form(
|
|
|
|
step_id="user",
|
|
|
|
data_schema=vol.Schema(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_HOST, default=user_input[CONF_HOST]): str,
|
|
|
|
vol.Required(
|
|
|
|
CONF_PORT, default=user_input.get(CONF_PORT, DEFAULT_PORT)
|
|
|
|
): int,
|
|
|
|
}
|
|
|
|
),
|
|
|
|
errors=self._errors,
|
|
|
|
)
|
|
|
|
|
|
|
|
async def async_step_import(self, user_input=None):
|
|
|
|
"""Import a config entry.
|
|
|
|
|
|
|
|
Only host was required in the yaml file all other fields are optional
|
|
|
|
"""
|
|
|
|
return await self.async_step_user(user_input)
|