hass-core/homeassistant/components/iskra/coordinator.py
Iskra kranj b557e9e826
Add Iskra integration (#121488)
* Add iskra integration

* iskra non resettable counters naming fix

* added iskra config_flow test

* fixed iskra integration according to code review

* changed iskra config flow test

* iskra integration, fixed codeowners

* Removed counters code & minor fixes

* added comment

* Update homeassistant/components/iskra/__init__.py

Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>

* Updated Iskra integration according to review

* Update homeassistant/components/iskra/strings.json

Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>

* Updated iskra integration according to review

* minor iskra integration change

* iskra integration changes according to review

* iskra integration changes according to review

* Changed iskra integration according to review

* added iskra config_flow range validation

* Fixed tests for iskra integration

* Update homeassistant/components/iskra/coordinator.py

* Update homeassistant/components/iskra/config_flow.py

Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>

* Fixed iskra integration according to review

* Changed voluptuous schema for iskra integration and added data_descriptions

* Iskra integration tests lint error fix

---------

Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>
2024-09-04 15:33:23 +02:00

57 lines
1.7 KiB
Python

"""Coordinator for Iskra integration."""
from datetime import timedelta
import logging
from pyiskra.devices import Device
from pyiskra.exceptions import (
DeviceConnectionError,
DeviceTimeoutError,
InvalidResponseCode,
NotAuthorised,
)
from homeassistant.core import HomeAssistant
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator, UpdateFailed
from .const import DOMAIN
_LOGGER = logging.getLogger(__name__)
class IskraDataUpdateCoordinator(DataUpdateCoordinator[None]):
"""Class to manage fetching Iskra data."""
def __init__(self, hass: HomeAssistant, device: Device) -> None:
"""Initialize."""
self.device = device
update_interval = timedelta(seconds=60)
super().__init__(
hass,
_LOGGER,
name=DOMAIN,
update_interval=update_interval,
)
async def _async_update_data(self) -> None:
"""Fetch data from Iskra device."""
try:
await self.device.update_status()
except DeviceTimeoutError as e:
raise UpdateFailed(
f"Timeout error occurred while updating data for device {self.device.serial}"
) from e
except DeviceConnectionError as e:
raise UpdateFailed(
f"Connection error occurred while updating data for device {self.device.serial}"
) from e
except NotAuthorised as e:
raise UpdateFailed(
f"Not authorised to fetch data from device {self.device.serial}"
) from e
except InvalidResponseCode as e:
raise UpdateFailed(
f"Invalid response code from device {self.device.serial}"
) from e