From 0a8b9157d4204115530f2981ff188d532c8426a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Roman=20Smr=C5=BE?= Date: Fri, 5 Jul 2024 22:11:47 +0200 Subject: Commands to list and create chatrooms --- main/Main.hs | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'main') diff --git a/main/Main.hs b/main/Main.hs index 0eb414c..091f076 100644 --- a/main/Main.hs +++ b/main/Main.hs @@ -37,6 +37,7 @@ import System.IO import Erebos.Attach import Erebos.Contact +import Erebos.Chatroom import Erebos.Conversation #ifdef ENABLE_ICE_SUPPORT import Erebos.Discovery @@ -425,6 +426,8 @@ commands = , ("attach", cmdAttach) , ("attach-accept", cmdAttachAccept) , ("attach-reject", cmdAttachReject) + , ("chatrooms", cmdChatrooms) + , ("chatroom-create-public", cmdChatroomCreatePublic) , ("contacts", cmdContacts) , ("contact-add", cmdContactAdd) , ("contact-accept", cmdContactAccept) @@ -530,6 +533,30 @@ cmdAttachAccept = attachAccept =<< getSelectedPeer cmdAttachReject :: Command cmdAttachReject = attachReject =<< getSelectedPeer +cmdChatrooms :: Command +cmdChatrooms = do + chatrooms <- listChatrooms + forM_ chatrooms $ \case + rstate | Just room <- roomStateRoom rstate -> do + liftIO $ T.putStrLn $ T.concat + [ fromMaybe (T.pack "") $ roomName room + ] + _ -> return () + +cmdChatroomCreatePublic :: Command +cmdChatroomCreatePublic = do + name <- asks ciLine >>= \case + line | not (null line) -> return $ T.pack line + _ -> liftIO $ do + T.putStr $ T.pack "Name: " + hFlush stdout + T.getLine + + void $ createChatroom + (if T.null name then Nothing else Just name) + Nothing + + cmdContacts :: Command cmdContacts = do args <- words <$> asks ciLine -- cgit v1.2.3