41 lines
1.0 KiB
Python
Raw Normal View History

2022-11-17 00:13:43 +01:00
import os
from typing import Dict, Optional, Union
from gpxpy.gpx import GPXTrackPoint
from fittrackee import appLog
from .visual_crossing import VisualCrossing
class WeatherService:
"""
Available API:
- VisualCrossing
"""
def __init__(self) -> None:
self.weather_api = self._get_weather_api()
@staticmethod
def _get_weather_api() -> Union[VisualCrossing, None]:
2022-11-17 00:13:43 +01:00
weather_api_key: str = os.getenv('WEATHER_API_KEY', '')
weather_api_provider: str = os.getenv(
'WEATHER_API_PROVIDER', ''
).lower()
if not weather_api_key:
return None
if weather_api_provider == 'visualcrossing':
return VisualCrossing(weather_api_key)
return None
def get_weather(self, point: GPXTrackPoint) -> Optional[Dict]:
if not self.weather_api:
return None
try:
return self.weather_api.get_weather(point)
except Exception as e:
appLog.error(f'error when getting weather data: {e}')
2022-11-17 00:13:43 +01:00
return None