{- * Hedgewars, a free turn based strategy game * Copyright (c) 2004-2014 Andrey Korotaev <unC0Rr@gmail.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. \-}module HandlerUtils whereimport Control.Monad.Readerimport qualified Data.ByteString.Char8 as Bimport Data.Listimport RoomsAndClientsimport CoreTypestype CmdHandler = [B.ByteString] -> Reader (ClientIndex, IRnC) [Action]thisClient :: Reader (ClientIndex, IRnC) ClientInfothisClient = do (ci, rnc) <- ask return $ rnc `client` cithisRoom :: Reader (ClientIndex, IRnC) RoomInfothisRoom = do (ci, rnc) <- ask let ri = clientRoom rnc ci return $ rnc `room` riclientNick :: Reader (ClientIndex, IRnC) B.ByteStringclientNick = liftM nick thisClientroomOthersChans :: Reader (ClientIndex, IRnC) [ClientChan]roomOthersChans = do (ci, rnc) <- ask let ri = clientRoom rnc ci return $ map (sendChan . client rnc) $ filter (/= ci) (roomClients rnc ri)roomSameClanChans :: Reader (ClientIndex, IRnC) [ClientChan]roomSameClanChans = do (ci, rnc) <- ask let ri = clientRoom rnc ci let otherRoomClients = map (client rnc) . filter (/= ci) $ roomClients rnc ri let cl = rnc `client` ci let sameClanClients = Prelude.filter (\c -> clientClan c == clientClan cl) otherRoomClients return $ map sendChan sameClanClientsroomClientsChans :: Reader (ClientIndex, IRnC) [ClientChan]roomClientsChans = do (ci, rnc) <- ask let ri = clientRoom rnc ci return $ map (sendChan . client rnc) (roomClients rnc ri)thisClientChans :: Reader (ClientIndex, IRnC) [ClientChan]thisClientChans = do (ci, rnc) <- ask return [sendChan (rnc `client` ci)]sameProtoChans :: Reader (ClientIndex, IRnC) [ClientChan]sameProtoChans = do (ci, rnc) <- ask let p = clientProto (rnc `client` ci) return . map sendChan . filter (\c -> clientProto c == p) . map (client rnc) $ allClients rncanswerClient :: [B.ByteString] -> Reader (ClientIndex, IRnC) [Action]answerClient msg = liftM ((: []) . flip AnswerClients msg) thisClientChansallRoomInfos :: Reader (a, IRnC) [RoomInfo]allRoomInfos = liftM ((\irnc -> map (room irnc) $ allRooms irnc) . snd) askclientByNick :: B.ByteString -> Reader (ClientIndex, IRnC) (Maybe ClientIndex)clientByNick n = do (_, rnc) <- ask let allClientIDs = allClients rnc return $ find (\clId -> let cl = client rnc clId in n == nick cl && not (isChecker cl)) allClientIDsroomAdminOnly :: Reader (ClientIndex, IRnC) [Action] -> Reader (ClientIndex, IRnC) [Action]roomAdminOnly h = thisClient >>= \cl -> if isMaster cl then h else return []serverAdminOnly :: Reader (ClientIndex, IRnC) [Action] -> Reader (ClientIndex, IRnC) [Action]serverAdminOnly h = thisClient >>= \cl -> if isAdministrator cl then h else return []