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,33 +45,63 @@ 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)
roomba = Roomba( if not await async_connect(hass, config_entry):
address=config_entry.data[CONF_HOST], return False
blid=config_entry.data[CONF_USERNAME],
password=config_entry.data[CONF_PASSWORD], for component in COMPONENTS:
cert_name=config_entry.options[CONF_CERT], hass.async_create_task(
continuous=config_entry.options[CONF_CONTINUOUS], hass.config_entries.async_forward_entry_setup(config_entry, component)
delay=config_entry.options[CONF_DELAY], )
)
hass.data[DOMAIN]["roomba"] = roomba
try:
with async_timeout.timeout(9):
await hass.async_add_job(roomba.connect)
except RoombaConnectionError:
_LOGGER.error("Error to connect to %s", config_entry.data[CONF_HOST])
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 return True
async def async_unload_entry(hass, config_entry): async def async_unload_entry(hass, config_entry):
"""Unload a config entry.""" """Unload a config entry."""
await hass.config_entries.async_forward_entry_unload(config_entry, "vacuum") for component in COMPONENTS:
hass.async_create_task(
hass.config_entries.async_forward_entry_unload(config_entry, component)
)
roomba = hass.data[DOMAIN]["roomba"] roomba = hass.data[DOMAIN]["roomba"]
await hass.async_add_job(roomba.disconnect) await hass.async_add_job(roomba.disconnect)
return True 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(
address=config_entry.data[CONF_HOST],
blid=config_entry.data[CONF_USERNAME],
password=config_entry.data[CONF_PASSWORD],
cert_name=config_entry.options[CONF_CERT],
continuous=config_entry.options[CONF_CONTINUOUS],
delay=config_entry.options[CONF_DELAY],
)
hass.data[DOMAIN]["roomba"] = roomba
try:
name = None
with async_timeout.timeout(9):
await hass.async_add_job(roomba.connect)
while not roomba.roomba_connected or name is None:
# 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 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"