Add async_connect

This commit is contained in:
cyr-ius
2020-03-28 18:06:08 +01:00
parent 557ac4a856
commit 3978d0a1d0
2 changed files with 56 additions and 25 deletions

View File

@@ -1,13 +1,14 @@
"""The roomba component.""" """The roomba component."""
import asyncio
import logging import logging
import async_timeout import async_timeout
from roomba import Roomba, RoombaConnectionError from roomba import Roomba
from homeassistant import config_entries from homeassistant import config_entries
from homeassistant.const import CONF_HOST, CONF_NAME, CONF_PASSWORD, CONF_USERNAME from homeassistant.const import CONF_HOST, CONF_PASSWORD, CONF_USERNAME
from .const import CONF_CERT, CONF_CONTINUOUS, CONF_DELAY, DOMAIN from .const import COMPONENTS, CONF_CERT, CONF_CONTINUOUS, CONF_DELAY, DOMAIN
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@@ -44,7 +45,36 @@ async def async_setup_entry(hass, config_entry):
if DOMAIN not in hass.data: if DOMAIN not in hass.data:
hass.data[DOMAIN] = {} hass.data[DOMAIN] = {}
if "roomba" not in hass.data[DOMAIN]: config_entry.add_update_listener(async_connect)
if not await async_connect(hass, config_entry):
return False
for component in COMPONENTS:
hass.async_create_task(
hass.config_entries.async_forward_entry_setup(config_entry, component)
)
return True
async def async_unload_entry(hass, config_entry):
"""Unload a config entry."""
for component in COMPONENTS:
hass.async_create_task(
hass.config_entries.async_forward_entry_unload(config_entry, component)
)
roomba = hass.data[DOMAIN]["roomba"]
await hass.async_add_job(roomba.disconnect)
return True
async def async_connect(hass, config_entry):
"""Connect to vacuum."""
# Check if triggred listerner
if "roomba" in hass.data[DOMAIN]:
await hass.async_add_job(hass.data[DOMAIN]["roomba"].disconnect)
await asyncio.sleep(1)
roomba = Roomba( roomba = Roomba(
address=config_entry.data[CONF_HOST], address=config_entry.data[CONF_HOST],
blid=config_entry.data[CONF_USERNAME], blid=config_entry.data[CONF_USERNAME],
@@ -53,24 +83,25 @@ async def async_setup_entry(hass, config_entry):
continuous=config_entry.options[CONF_CONTINUOUS], continuous=config_entry.options[CONF_CONTINUOUS],
delay=config_entry.options[CONF_DELAY], delay=config_entry.options[CONF_DELAY],
) )
hass.data[DOMAIN]["roomba"] = roomba hass.data[DOMAIN]["roomba"] = roomba
try: try:
name = None
with async_timeout.timeout(9): with async_timeout.timeout(9):
await hass.async_add_job(roomba.connect) await hass.async_add_job(roomba.connect)
except RoombaConnectionError: while not roomba.roomba_connected or name is None:
_LOGGER.error("Error to connect to %s", config_entry.data[CONF_HOST]) # Waiting for connection and check datas ready
name = (
roomba.master_state.get("state", {})
.get("reported", {})
.get("name", None)
)
await asyncio.sleep(0.5)
except asyncio.TimeoutError:
# api looping if user or password incorrect and roomba exist
_LOGGER.error("Timeout exceeded")
await hass.async_add_job(roomba.disconnect)
return False return False
hass.data[DOMAIN]["name"] = config_entry.data[CONF_NAME]
hass.async_create_task(
hass.config_entries.async_forward_entry_setup(config_entry, "vacuum")
)
return True
async def async_unload_entry(hass, config_entry):
"""Unload a config entry."""
await hass.config_entries.async_forward_entry_unload(config_entry, "vacuum")
roomba = hass.data[DOMAIN]["roomba"]
await hass.async_add_job(roomba.disconnect)
return True return True

View File

@@ -1,9 +1,9 @@
"""The roomba constants.""" """The roomba constants."""
DOMAIN = "roomba" DOMAIN = "roomba"
COMPONENTS = ["sensor", "binary_sensor", "vacuum"]
CONF_CERT = "certificate" CONF_CERT = "certificate"
CONF_CONTINUOUS = "continuous" CONF_CONTINUOUS = "continuous"
CONF_DELAY = "delay" CONF_DELAY = "delay"
DEFAULT_CERT = "/etc/ssl/certs/ca-certificates.crt" DEFAULT_CERT = "/etc/ssl/certs/ca-certificates.crt"
DEFAULT_CONTINUOUS = True DEFAULT_CONTINUOUS = True
DEFAULT_DELAY = 1 DEFAULT_DELAY = 1
DEFAULT_NAME = "Roomba"