-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGetJsonExamples.hs
executable file
·68 lines (56 loc) · 2.08 KB
/
GetJsonExamples.hs
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/usr/bin/env stack
-- stack --resolver lts-12.16 script
module Main where
import qualified Network.Wreq as Wreq (get)
import Network.Wreq (responseBody)
import Control.Lens ((.~), (^.))
import qualified Data.ByteString.Lazy as BSL
import Data.String.Utils (strip)
import Control.Monad.State
import Control.Monad (forM_)
import Control.Monad.IO.Class (liftIO)
inc = get >>= \i->put (i+1) :: StateT Int IO ()
resetCounter = put 1 :: StateT Int IO ()
done = return () :: StateT Int IO ()
readKey = strip <$> (liftIO.readFile) "owm.key" :: StateT Int IO String
wget url = liftIO $ Wreq.get url >>= (\r->return $ r ^. responseBody)
save :: FilePath -> BSL.ByteString -> StateT Int IO ()
save f b = do
i <- get
let path = f ++ show i ++ ".json"
liftIO $ BSL.writeFile path b
liftIO $ putStrLn $ "Saved " ++ path
inc
baseurl25 = "http://api.openweathermap.org/data/2.5/"
baseurl30 = "http://api.openweathermap.org/data/3.0/"
queries = [
"q=Altendorf,CH&units=metric&lang=de",
"q=London,gb&units=metric&lang=en",
"q=Paris,gb&units=metric&lang=fr",
"q=Moscow,gb&units=metric&lang=ru",
"q=Mayer,us&units=metric&lang=en",
"q=München,DE",
"lat=35&lon=139&units=metric",
"lat=90&lon=0&lang=no&units=metric",
"lat=-90&lon=180&lang=es&units=metric",
"zip=60606,us&units=imperial",
"id=524901"
]
main :: IO ((), Int)
main = (flip runStateT) 1 $ do
key <- readKey
-- weather
resetCounter
forM_ queries $ \q -> save "json/Weather" =<< wget (baseurl25 ++ "weather?" ++ q ++ "&APPID=" ++ key)
-- Forecast
resetCounter
forM_ queries $ \q -> save "json/Forecast" =<< wget (baseurl25 ++ "forecast?" ++ q ++ "&APPID=" ++ key)
-- ForecastDaily
resetCounter
forM_ queries $ \q -> save "json/ForecastDaily" =<< wget (baseurl25 ++ "forecast/daily?cnt=5&" ++ q ++ "&APPID=" ++ key)
{-
-- History: Need paid subscription
resetCounter
forM_ queries $ \q -> save "json/History" =<< wget (baseurl25 ++ "history/city?type=hour&" ++ q ++ "&APPID=" ++ key)
-}
done