Handle empty arguments in fokabot !mp commands

This commit is contained in:
Giuseppe Guerra 2018-03-23 21:28:24 +01:00
parent 3275d31861
commit 201593ea02

View File

@ -781,7 +781,10 @@ def multiplayer(fro, chan, message):
def mpMake(): def mpMake():
if len(message) < 2: if len(message) < 2:
raise exceptions.invalidArgumentsException("Wrong syntax: !mp make <name>") raise exceptions.invalidArgumentsException("Wrong syntax: !mp make <name>")
matchID = glob.matches.createMatch(" ".join(message[1:]), generalUtils.stringMd5(generalUtils.randomString(32)), 0, "Tournament", "", 0, -1, isTourney=True) matchName = " ".join(message[1:]).strip()
if not matchName:
raise exceptions.invalidArgumentsException("Match name must not be empty!")
matchID = glob.matches.createMatch(matchName, generalUtils.stringMd5(generalUtils.randomString(32)), 0, "Tournament", "", 0, -1, isTourney=True)
glob.matches.matches[matchID].sendUpdates() glob.matches.matches[matchID].sendUpdates()
return "Tourney match #{} created!".format(matchID) return "Tourney match #{} created!".format(matchID)
@ -835,7 +838,9 @@ def multiplayer(fro, chan, message):
def mpHost(): def mpHost():
if len(message) < 2: if len(message) < 2:
raise exceptions.invalidArgumentsException("Wrong syntax: !mp host <username>") raise exceptions.invalidArgumentsException("Wrong syntax: !mp host <username>")
username = message[1] username = message[1].strip()
if not username:
raise exceptions.invalidArgumentsException("Please provide a username")
userID = userUtils.getIDSafe(username) userID = userUtils.getIDSafe(username)
if userID is None: if userID is None:
raise exceptions.userNotFoundException("No such user") raise exceptions.userNotFoundException("No such user")
@ -900,7 +905,9 @@ def multiplayer(fro, chan, message):
def mpInvite(): def mpInvite():
if len(message) < 2: if len(message) < 2:
raise exceptions.invalidArgumentsException("Wrong syntax: !mp invite <username>") raise exceptions.invalidArgumentsException("Wrong syntax: !mp invite <username>")
username = message[1] username = message[1].strip()
if not username:
raise exceptions.invalidArgumentsException("Please provide a username")
userID = userUtils.getIDSafe(username) userID = userUtils.getIDSafe(username)
if userID is None: if userID is None:
raise exceptions.userNotFoundException("No such user") raise exceptions.userNotFoundException("No such user")
@ -967,7 +974,9 @@ def multiplayer(fro, chan, message):
def mpKick(): def mpKick():
if len(message) < 2: if len(message) < 2:
raise exceptions.invalidArgumentsException("Wrong syntax: !mp kick <username>") raise exceptions.invalidArgumentsException("Wrong syntax: !mp kick <username>")
username = message[1] username = message[1].strip()
if not username:
raise exceptions.invalidArgumentsException("Please provide a username")
userID = userUtils.getIDSafe(username) userID = userUtils.getIDSafe(username)
if userID is None: if userID is None:
raise exceptions.userNotFoundException("No such user") raise exceptions.userNotFoundException("No such user")
@ -980,7 +989,7 @@ def multiplayer(fro, chan, message):
return "{} has been kicked from the match.".format(username) return "{} has been kicked from the match.".format(username)
def mpPassword(): def mpPassword():
password = "" if len(message) < 2 else message[1] password = "" if len(message) < 2 or not message[1].strip() else message[1]
_match = glob.matches.matches[getMatchIDFromChannel(chan)] _match = glob.matches.matches[getMatchIDFromChannel(chan)]
_match.changePassword(password) _match.changePassword(password)
return "Match password has been changed!" return "Match password has been changed!"
@ -1024,7 +1033,9 @@ def multiplayer(fro, chan, message):
def mpTeam(): def mpTeam():
if len(message) < 3: if len(message) < 3:
raise exceptions.invalidArgumentsException("Wrong syntax: !mp team <username> <colour>") raise exceptions.invalidArgumentsException("Wrong syntax: !mp team <username> <colour>")
username = message[1] username = message[1].strip()
if not username:
raise exceptions.invalidArgumentsException("Please provide a username")
colour = message[2].lower().strip() colour = message[2].lower().strip()
if colour not in ["red", "blue"]: if colour not in ["red", "blue"]:
raise exceptions.invalidArgumentsException("Team colour must be red or blue") raise exceptions.invalidArgumentsException("Team colour must be red or blue")