aboutsummaryrefslogtreecommitdiff
path: root/src/Tomato
diff options
context:
space:
mode:
authorJacques Comeaux <jacquesrcomeaux@gmail.com>2022-05-28 12:37:26 -0500
committerJacques Comeaux <jacquesrcomeaux@gmail.com>2022-05-28 12:37:26 -0500
commit399ab3ee1653bbc0da69e2cc299aa2a313e765b4 (patch)
treebc7545b5cd332990b5f68a0387d73dc036f530d8 /src/Tomato
parent38434153be8486e12203e0fb2c2b69e80644b7f0 (diff)
Implement tomato retrieval
Diffstat (limited to 'src/Tomato')
-rw-r--r--src/Tomato/Retrieve.hs58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/Tomato/Retrieve.hs b/src/Tomato/Retrieve.hs
new file mode 100644
index 0000000..80bdac6
--- /dev/null
+++ b/src/Tomato/Retrieve.hs
@@ -0,0 +1,58 @@
+module Tomato.Retrieve
+ ( randomTomato
+ , downloadTomato
+ , queryTomato
+ ) where
+
+import RIO
+
+import Network.HTTP.Req
+ ( jsonResponse
+ , bsResponse
+ , req
+ , NoReqBody (..)
+ , (/:)
+ , (=:)
+ , Req
+ , GET (..)
+ , https
+ , responseBody
+ )
+
+import Data.Tomato (Tomato (..), Links (..))
+
+import qualified Data.Aeson as Ae
+import qualified RIO.ByteString as B
+
+
+-- TODO global config reader monad
+tomatoFile :: FilePath
+tomatoFile = "tomato.png"
+
+clientId :: Text
+clientId = "FbzqI-oR7277JwL1ZGsyUw7yG1F5U0U3WhQ3kOW71Do"
+
+-- | Get a random tomato
+randomTomato :: Req ()
+randomTomato = queryTomato >>= downloadTomato
+
+-- | Ask for a tomato
+queryTomato :: Req Tomato
+queryTomato = do
+ let url = https "api.unsplash.com" /: "photos" /: "random"
+ js <- req GET url NoReqBody jsonResponse $
+ "query" =: ("tomato" :: Text) <>
+ "client_id" =: clientId
+ tomato <- case Ae.fromJSON (responseBody js) of
+ Ae.Success r -> pure r
+ Ae.Error _s -> error "deal with this later"
+ return tomato
+
+-- | Download a specific tomato
+downloadTomato :: Tomato -> Req ()
+downloadTomato tom = do
+ let url = download (links tom)
+ bs <- req GET url NoReqBody bsResponse $
+ "query" =: ("tomato" :: Text) <>
+ "client_id" =: clientId
+ B.writeFile tomatoFile (responseBody bs)