45 lines
1.3 KiB
Python
45 lines
1.3 KiB
Python
|
"""Helpers used for Met Office integration."""
|
||
|
|
||
|
import logging
|
||
|
|
||
|
import datapoint
|
||
|
|
||
|
from homeassistant.helpers.update_coordinator import UpdateFailed
|
||
|
from homeassistant.util import utcnow
|
||
|
|
||
|
from .data import MetOfficeData
|
||
|
|
||
|
_LOGGER = logging.getLogger(__name__)
|
||
|
|
||
|
|
||
|
def fetch_site(connection: datapoint.Manager, latitude, longitude):
|
||
|
"""Fetch site information from Datapoint API."""
|
||
|
try:
|
||
|
return connection.get_nearest_forecast_site(
|
||
|
latitude=latitude, longitude=longitude
|
||
|
)
|
||
|
except datapoint.exceptions.APIException as err:
|
||
|
_LOGGER.error("Received error from Met Office Datapoint: %s", err)
|
||
|
return None
|
||
|
|
||
|
|
||
|
def fetch_data(connection: datapoint.Manager, site, mode) -> MetOfficeData:
|
||
|
"""Fetch weather and forecast from Datapoint API."""
|
||
|
try:
|
||
|
forecast = connection.get_forecast_for_site(site.id, mode)
|
||
|
except (ValueError, datapoint.exceptions.APIException) as err:
|
||
|
_LOGGER.error("Check Met Office connection: %s", err.args)
|
||
|
raise UpdateFailed from err
|
||
|
else:
|
||
|
time_now = utcnow()
|
||
|
return MetOfficeData(
|
||
|
forecast.now(),
|
||
|
[
|
||
|
timestep
|
||
|
for day in forecast.days
|
||
|
for timestep in day.timesteps
|
||
|
if timestep.date > time_now
|
||
|
],
|
||
|
site,
|
||
|
)
|