summaryrefslogtreecommitdiff
path: root/fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs
diff options
context:
space:
mode:
Diffstat (limited to 'fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs')
-rw-r--r--fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs36
1 files changed, 36 insertions, 0 deletions
diff --git a/fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs b/fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs
new file mode 100644
index 0000000..1a267f8
--- /dev/null
+++ b/fig-monitor-bullfrog/src/Fig/Monitor/Bullfrog.hs
@@ -0,0 +1,36 @@
+{-# Language QuasiQuotes #-}
+{-# Language RecordWildCards #-}
+{-# Language ApplicativeDo #-}
+
+module Fig.Monitor.Bullfrog
+ ( bullfrogClient
+ ) where
+
+import Fig.Prelude
+
+import qualified Data.Text as Text
+
+import qualified Wuss as WS
+import qualified Network.WebSockets.Connection as WS
+
+import Fig.Utils.SExpr
+import Fig.Bus.Client
+import Fig.Monitor.Bullfrog.Utils
+
+bullfrogClient :: Config -> (Text, Text) -> IO ()
+bullfrogClient cfg busAddr = do
+ WS.runSecureClient "colonq.computer" 443 ("/bullfrog/api/channel/broadcast?token=" <> Text.unpack cfg.authToken) \conn -> do
+ busClient busAddr
+ (\cmds -> do
+ log "Connected to bus and broadcast server"
+ cmds.subscribe [sexp|(monitor bullfrog broadcast)|]
+ )
+ (\_cmds d -> do
+ case d of
+ SExprList [ev, SExprString msg]
+ | ev == [sexp|(monitor bullfrog broadcast)|] -> do
+ log $ "Broadcasting message: " <> msg
+ WS.sendTextData conn msg
+ _ -> log $ "Invalid incoming message: " <> tshow d
+ )
+ (pure ())