blob: 0c1e282d9294110aa0033ac240c7832a3b13729f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
{-|
Direct API functions.
For API key (a.k.a appid) refer to <http://openweathermap.org/appid>.
-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE TypeOperators #-}
module Web.OpenWeatherMap.API (
weatherByName,
weatherByCoord
) where
import Data.Proxy (Proxy(..))
import Servant.API ((:>), (:<|>)(..), JSON, Get, QueryParam)
import Servant.Client (client)
import Servant.Common.Req (ClientM)
import Web.OpenWeatherMap.Types.CurrentWeather (CurrentWeather)
type GetCurrentWeather = AppId :> Get '[JSON] CurrentWeather
type AppId = QueryParam "appid" String
type API
= "weather" :> QueryParam "q" String :> GetCurrentWeather
:<|> "weather" :> QueryParam "lat" Double :> QueryParam "lon" Double
:> GetCurrentWeather
-- | Request current weather in the city.
weatherByName
:: Maybe String -- ^ City name, e. g. \"Moscow\" or \"Moscow,ru\".
-> Maybe String -- ^ API key.
-> ClientM CurrentWeather
-- | Request current weather at the geographic coordinates (in decimal degrees).
weatherByCoord
:: Maybe Double -- ^ Latitude, e. g. 55.7522200 for Moscow.
-> Maybe Double -- ^ Longitude, e. g. 37.6155600 for Moscow.
-> Maybe String -- ^ API key.
-> ClientM CurrentWeather
weatherByName :<|> weatherByCoord = client (Proxy :: Proxy API)
|