gameServer/HWProtoCore.hs
author unc0rr
Fri, 27 Mar 2009 20:36:50 +0000
changeset 1928 9bf8f4f30d6b
parent 1879 bb114339eb4e
child 1929 7e6cc8da1c58
permissions -rw-r--r--
- Implement ping timeout - It triggers bug with kicking room creator
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     1
module HWProtoCore where
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     2
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     3
import qualified Data.IntMap as IntMap
1862
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
     4
import Data.Foldable
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
     5
import Maybe
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     6
--------------------------------------
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     7
import CoreTypes
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     8
import Actions
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
     9
import Utils
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    10
import HWProtoNEState
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    11
import HWProtoLobbyState
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    12
import HWProtoInRoomState
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    13
1862
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    14
handleCmd, handleCmd_loggedin :: CmdHandler
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    15
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    16
handleCmd clID _ _ ["PING"] = [AnswerThisClient ["PONG"]]
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    17
1814
e5391d901cff - Remove client teams on exit
unc0rr
parents: 1811
diff changeset
    18
handleCmd clID clients rooms ("QUIT" : xs) =
1879
bb114339eb4e Implement kick from room
unc0rr
parents: 1862
diff changeset
    19
	(if isMaster client then [RemoveRoom] else [RemoveClientTeams clID])
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    20
	++ [ByeClient msg]
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    21
	where
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    22
		client = clients IntMap.! clID
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    23
		clientNick = nick client
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    24
		msg = if not $ null xs then head xs else ""
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    25
1862
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    26
1928
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    27
handleCmd clID clients _ ["PONG"] =
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    28
	if pingsQueue client == 0 then
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    29
		[ProtocolError "Protocol violation"]
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    30
	else
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    31
		[ModifyClient (\cl -> cl{pingsQueue = pingsQueue cl - 1})]
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    32
	where
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    33
		client = clients IntMap.! clID
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    34
9bf8f4f30d6b - Implement ping timeout
unc0rr
parents: 1879
diff changeset
    35
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    36
handleCmd clID clients rooms cmd =
1841
fba7210b438b Retrieve client password from web database and ask for it
unc0rr
parents: 1814
diff changeset
    37
	if not $ logonPassed client then
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    38
		handleCmd_NotEntered clID clients rooms cmd
1862
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    39
	else
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    40
		handleCmd_loggedin clID clients rooms cmd
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    41
	where
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    42
		client = clients IntMap.! clID
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    43
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    44
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    45
handleCmd_loggedin clID clients rooms ["INFO", asknick] =
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    46
	if noSuchClient then
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    47
		[]
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    48
	else
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    49
		[AnswerThisClient
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    50
			["INFO",
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    51
			nick client,
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    52
			"[" ++ host client ++ "]",
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    53
			protoNumber2ver $ clientProto client,
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    54
			roomInfo]]
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    55
	where
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    56
		maybeClient = find (\cl -> asknick == nick cl) clients
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    57
		noSuchClient = isNothing maybeClient
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    58
		client = fromJust maybeClient
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    59
		room = rooms IntMap.! roomID client
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    60
		roomInfo = if roomID client /= 0 then "room " ++ (name room) else "lobby"
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    61
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    62
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    63
handleCmd_loggedin clID clients rooms cmd =
7f303aa066da Implement kick from server by administrator
unc0rr
parents: 1841
diff changeset
    64
	if roomID client == 0 then
1804
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    65
		handleCmd_lobby clID clients rooms cmd
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    66
	else
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    67
		handleCmd_inRoom clID clients rooms cmd
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    68
	where
4e78ad846fb6 New game server:
unc0rr
parents:
diff changeset
    69
		client = clients IntMap.! clID