aboutsummaryrefslogtreecommitdiff
path: root/src/Tomato/Post.hs
diff options
context:
space:
mode:
authorJacques Comeaux <jacquesrcomeaux@gmail.com>2022-05-27 21:07:43 -0500
committerJacques Comeaux <jacquesrcomeaux@gmail.com>2022-05-27 21:07:43 -0500
commit3d3163a1028e99e5073fd39adc9aee5d76a5e5a2 (patch)
treed1cff9ed00418183d3ed8de412d0fdccd7666eaf /src/Tomato/Post.hs
Initial Commit
Diffstat (limited to 'src/Tomato/Post.hs')
-rw-r--r--src/Tomato/Post.hs65
1 files changed, 65 insertions, 0 deletions
diff --git a/src/Tomato/Post.hs b/src/Tomato/Post.hs
new file mode 100644
index 0000000..1e97782
--- /dev/null
+++ b/src/Tomato/Post.hs
@@ -0,0 +1,65 @@
+module Tomato.Post
+ ( postTomato
+ , uploadTomato
+ , postMessage
+ ) where
+
+import RIO
+
+import Network.HTTP.Req
+ ( jsonResponse
+ , ignoreResponse
+ , req
+ , ReqBodyFile (..)
+ , ReqBodyJson (..)
+ , (/:)
+ , POST (..)
+ , Req
+ , https
+ , header
+ , responseBody
+ )
+
+import Data.Message (GMIUrl (..), OutMessage (..))
+
+import qualified Data.Aeson as Ae
+import qualified Data.Aeson.KeyMap as Ae
+
+-- TODO global config reader monad
+tomatoFile :: FilePath
+tomatoFile = "tomato.png"
+
+accessToken :: ByteString
+accessToken = "nj8X8tB3TC0MoZdMLhIUA4G89r9IlQfVej97Mhg3"
+
+botId :: Text
+botId = "713bcb4a4604006c944804552c"
+
+-- | Post the current tomato
+postTomato :: Req ()
+postTomato = do
+ url <- uploadTomato
+ postMessage $ OutMessage url
+
+-- | Upload the current tomato to the GroupMe image server
+uploadTomato :: Req GMIUrl
+uploadTomato = do
+ let url = https "image.groupme.com" /: "pictures"
+ js <- req POST url (ReqBodyFile tomatoFile) jsonResponse $
+ header "X-Access-Token" accessToken <>
+ header "Content-Type" "image/png"
+ gmURL <- case Ae.fromJSON (responseBody js) of
+ Ae.Success r -> pure r
+ Ae.Error _s -> error "deal with this later" -- TODO error monad
+ return gmURL
+
+-- | Post a message to the group with image as attachment
+postMessage :: OutMessage -> Req ()
+postMessage outMes = do
+ let url = https "api.groupme.com" /: "v3" /: "bots" /: "post"
+ outMes' = case Ae.toJSON outMes of
+ Ae.Object o -> Ae.Object $ Ae.insert "bot_id" (Ae.toJSON botId) o
+ _ -> error "exceptional"
+ req POST url (ReqBodyJson outMes') ignoreResponse $
+ header "X-Access-Token" accessToken
+ return ()