From 11c2c16835b3e8368be77ccc5b7ddf949021eccd Mon Sep 17 00:00:00 2001 From: Julien Dessaux Date: Sat, 3 Jul 2010 21:26:00 +0200 Subject: Moved files around as a preliminary for architectural changes. --- HsbotMaster/Hsbot/Message.hs | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 HsbotMaster/Hsbot/Message.hs (limited to 'HsbotMaster/Hsbot/Message.hs') diff --git a/HsbotMaster/Hsbot/Message.hs b/HsbotMaster/Hsbot/Message.hs new file mode 100644 index 0000000..933394b --- /dev/null +++ b/HsbotMaster/Hsbot/Message.hs @@ -0,0 +1,35 @@ +module Hsbot.Message + ( processInternalMessage + , processRebootMessage + , processExitMessage + ) where + +import Control.Monad.State +import qualified Data.Map as M + +import Hsbot.PluginUtils +import Hsbot.Types + +-- | Processes an internal message +processInternalMessage :: Msg -> Bot (BotStatus) +processInternalMessage msg + | msgTo msg == "CORE" = processCoreMessage msg + | otherwise = do + plugins <- gets botPlugins + case M.lookup (msgTo msg) plugins of + Just (plugin, _, _) -> sendToPlugin (IntMsg msg) plugin + Nothing -> return () + return BotContinue + +processCoreMessage :: Msg -> Bot (BotStatus) +processCoreMessage msg = do + case msgType msg of + "REBOOT" -> return BotReboot + _ -> return BotContinue + +processRebootMessage :: RebootMsg -> Bot (BotStatus) +processRebootMessage _ = return BotReboot -- TODO : check who is sending that to us + +processExitMessage :: ExitMsg -> Bot (BotStatus) +processExitMessage _ = return BotExit -- TODO : check who is sending that to us + -- cgit v1.2.3