Files
koolnova-BMS-Integration/custom_components/koolnova_bms/__init__.py
2024-02-29 11:33:00 +01:00

56 lines
2.1 KiB
Python

""" Initialisation du package de l'intégration TestVBE_4 """
import logging
from homeassistant.core import HomeAssistant
from homeassistant.config_entries import ConfigEntry
from .koolnova.device import Koolnova
from .const import DOMAIN, PLATFORMS
from .coordinator import KoolnovaCoordinator
_LOGGER = logging.getLogger(__name__)
async def async_setup_entry(hass: HomeAssistant,
entry: ConfigEntry) -> bool: # pylint: disable=unused-argument
""" Creation des entités à partir d'une configEntry """
#hass.data.setdefault(DOMAIN, [])
hass.data.setdefault(DOMAIN, {})
name: str = entry.data['Name']
port: str = entry.data['Device']
addr: int = entry.data['Address']
baudrate: int = entry.data['Baudrate']
parity: str = entry.data['Parity'][0]
bytesize: int = entry.data['Sizebyte']
stopbits: int = entry.data['Stopbits']
timeout: int = entry.data['Timeout']
try:
device = Koolnova(name, port, addr, baudrate, parity, bytesize, stopbits, timeout)
# connect to modbus client
await device.async_connect()
# update attributes
await device.async_update()
# record each area in device
_LOGGER.debug("Koolnova areas: {}".format(entry.data['areas']))
for area in entry.data['areas']:
await device.async_add_manual_registered_area(name=area['Name'],
id_zone=area['Area_id'])
hass.data[DOMAIN]['device'] = device
coordinator = KoolnovaCoordinator(hass, device)
hass.data[DOMAIN]['coordinator'] = coordinator
except Exception as e:
_LOGGER.exception("Something went wrong ... {}".format(e))
# Propagation du configEntry à toutes les plateformes déclarées dans notre intégration
await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
return True
async def async_remove_entry(hass: HomeAssistant, entry: ConfigEntry) -> None:
""" Handle removal of an entry """
_LOGGER.debug("Appel de async_remove_entry - entry: {}".format(entry))