diff options
author | Aki <please@ignore.pl> | 2022-09-26 00:37:39 +0200 |
---|---|---|
committer | Aki <please@ignore.pl> | 2022-09-26 00:37:39 +0200 |
commit | 78086bf15a335a9c40b5a58c2e563c0159870ed3 (patch) | |
tree | 3c3f4a24b41cd10ccd8990b7d6b78d5a5f22e731 /windy | |
parent | a9e99607ec03e13bb2e819557174e0120b001255 (diff) | |
download | windy-78086bf15a335a9c40b5a58c2e563c0159870ed3.zip windy-78086bf15a335a9c40b5a58c2e563c0159870ed3.tar.gz windy-78086bf15a335a9c40b5a58c2e563c0159870ed3.tar.bz2 |
Made a proper package out of the module
Diffstat (limited to 'windy')
-rw-r--r-- | windy/__init__.py | 1 | ||||
-rw-r--r-- | windy/point_forecast.py | 68 |
2 files changed, 69 insertions, 0 deletions
diff --git a/windy/__init__.py b/windy/__init__.py new file mode 100644 index 0000000..ba397a9 --- /dev/null +++ b/windy/__init__.py @@ -0,0 +1 @@ +from . import point_forecast diff --git a/windy/point_forecast.py b/windy/point_forecast.py new file mode 100644 index 0000000..2d5cab6 --- /dev/null +++ b/windy/point_forecast.py @@ -0,0 +1,68 @@ +from dataclasses import dataclass +from enum import Enum + +import requests + + +class _StrEnum(Enum): + def __str__(self): + return self.value + + +class Model(_StrEnum): + AROME = "arome" + GEOS5 = "geos5" + GFS = "gfs" + GFSWAVE = "gfsWave" + ICONEU = "iconEu" + NAMALASKA = "namAlaska" + NAMCONUS = "namConus" + NAMHAWAII = "namHawaii" + + +class Level(_StrEnum): + SURFACE = "surface" + H1000 = "1000h" + H950 = "950h" + H925 = "925h" + H900 = "900h" + H850 = "850h" + H800 = "800h" + H700 = "700h" + H600 = "600h" + H500 = "500h" + H400 = "400h" + H300 = "300h" + H200 = "200h" + H150 = "150h" + + +@dataclass +class Config: + key: str + api: str = "https://api.windy.com/api" + + +@dataclass +class Request: + lat: float + lon: float + model: Model + parameters: list = None + levels: list = None + endpoint: str = "/point-forecast/v2" + + def json(self): + body = { + 'lat': self.lat, + 'lon': self.lon, + 'model': str(self.model), + 'parameters': self.parameters or [], + } + if self.levels: + body['levels'] = [str(x) for x in self.levels] + return body + + +def point_forecast(request: Request, config: Config): + return requests.post(config.api + request.endpoint, json=request.json()) |