2016-05-18 17:12:46 +00:00
|
|
|
from constants import clientPackets
|
|
|
|
from constants import serverPackets
|
|
|
|
from objects import glob
|
|
|
|
from constants import exceptions
|
2016-06-04 10:44:54 +00:00
|
|
|
from helpers import logHelper as log
|
2016-07-14 10:37:07 +00:00
|
|
|
from helpers import chatHelper as chat
|
2016-04-19 17:40:59 +00:00
|
|
|
|
|
|
|
def handle(userToken, packetData):
|
|
|
|
# read packet data
|
|
|
|
packetData = clientPackets.joinMatch(packetData)
|
|
|
|
|
|
|
|
# Get match from ID
|
|
|
|
joinMatch(userToken, packetData["matchID"], packetData["password"])
|
|
|
|
|
|
|
|
def joinMatch(userToken, matchID, password):
|
|
|
|
try:
|
|
|
|
# TODO: leave other matches
|
|
|
|
# TODO: Stop spectating
|
|
|
|
|
|
|
|
# get usertoken data
|
|
|
|
userID = userToken.userID
|
|
|
|
|
|
|
|
# Make sure the match exists
|
|
|
|
if matchID not in glob.matches.matches:
|
|
|
|
raise exceptions.matchNotFoundException
|
|
|
|
|
|
|
|
# Match exists, get object
|
|
|
|
match = glob.matches.matches[matchID]
|
|
|
|
|
|
|
|
# Check password
|
|
|
|
# TODO: Admins can enter every match
|
|
|
|
if match.matchPassword != "":
|
|
|
|
if match.matchPassword != password:
|
|
|
|
raise exceptions.matchWrongPasswordException
|
|
|
|
|
|
|
|
# Password is correct, join match
|
|
|
|
result = match.userJoin(userID)
|
|
|
|
|
|
|
|
# Check if we've joined the match successfully
|
|
|
|
if result == False:
|
|
|
|
raise exceptions.matchJoinErrorException
|
|
|
|
|
|
|
|
# Match joined, set matchID for usertoken
|
|
|
|
userToken.joinMatch(matchID)
|
|
|
|
|
|
|
|
# Send packets
|
|
|
|
userToken.enqueue(serverPackets.matchJoinSuccess(matchID))
|
2016-07-14 10:37:07 +00:00
|
|
|
chat.joinChannel(token=userToken, channel="#multi_{}".format(matchID))
|
2016-04-19 17:40:59 +00:00
|
|
|
except exceptions.matchNotFoundException:
|
|
|
|
userToken.enqueue(serverPackets.matchJoinFail())
|
2016-06-04 10:44:54 +00:00
|
|
|
log.warning("{} has tried to join a mp room, but it doesn't exist".format(userToken.username))
|
2016-04-19 17:40:59 +00:00
|
|
|
except exceptions.matchWrongPasswordException:
|
|
|
|
userToken.enqueue(serverPackets.matchJoinFail())
|
2016-06-04 10:44:54 +00:00
|
|
|
log.warning("{} has tried to join a mp room, but he typed the wrong password".format(userToken.username))
|
2016-04-19 17:40:59 +00:00
|
|
|
except exceptions.matchJoinErrorException:
|
|
|
|
userToken.enqueue(serverPackets.matchJoinFail())
|
2016-06-04 10:44:54 +00:00
|
|
|
log.warning("{} has tried to join a mp room, but an error has occured".format(userToken.username))
|