From 3d3163a1028e99e5073fd39adc9aee5d76a5e5a2 Mon Sep 17 00:00:00 2001 From: Jacques Comeaux Date: Fri, 27 May 2022 21:07:43 -0500 Subject: Initial Commit --- app/Main.hs | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 app/Main.hs (limited to 'app/Main.hs') diff --git a/app/Main.hs b/app/Main.hs new file mode 100644 index 0000000..bdbef74 --- /dev/null +++ b/app/Main.hs @@ -0,0 +1,73 @@ +module Main + ( main + ) where + +import RIO + +import Network.HTTP.Req + ( jsonResponse + , req + , (=:) + , NoReqBody (..) + , (/:) + , GET (..) + , https + , responseBody + , Req + , defaultHttpConfig + , runReq + ) + +import Data.Tomato (Tomato) +import Tomato.Post (postTomato) + +import qualified Data.Aeson.Types as Ae + + +data App = App + { appLogFunc :: !LogFunc + , appName :: !Utf8Builder + , appToken :: !Text + } + +instance HasLogFunc App where + logFuncL = lens appLogFunc (\x y -> x { appLogFunc = y }) + +runApp :: RIO App a -> IO a +runApp inner = do + logOptions' <- logOptionsHandle stderr False + -- let logOptions = setLogUseTime True $ setLogUseLoc True logOptions' + let logOptions = logOptions' + withLogFunc logOptions $ \logFunc -> do + let app = App + { appLogFunc = logFunc + , appName = "Tomato Bot" + , appToken = "placeholder" + } + runRIO app inner + +randomTomato :: Req Tomato +randomTomato = do + let url = https "api.unsplash.com" /: "photos" /: "random" + js <- req GET url NoReqBody jsonResponse $ + "query" =: ("tomato" :: Text) <> + "client_id" =: ("FbzqI-oR7277JwL1ZGsyUw7yG1F5U0U3WhQ3kOW71Do" :: Text) + tomato <- case Ae.fromJSON (responseBody js) of + Ae.Success r -> pure r + Ae.Error _s -> error "deal with this later" + return tomato + +tomatoBot :: RIO App () +tomatoBot = do + name <- view $ to appName + logInfo $ "Hello, " <> name + logInfo $ "Fetching tomato" + -- tomato <- runReq defaultHttpConfig randomTomato + -- logInfo $ displayShow tomato + -- url <- runReq defaultHttpConfig postTomato + runReq defaultHttpConfig postTomato + -- logInfo $ displayShow url + logInfo $ "All done" + +main :: IO () +main = runApp tomatoBot -- cgit v1.2.3