Fix foka responding to commands even if the command is not at the beginning of the message
This commit is contained in:
		| @@ -757,6 +757,32 @@ def report(fro, chan, message): | |||||||
| 					token.enqueue(serverPackets.notification(msg)) | 					token.enqueue(serverPackets.notification(msg)) | ||||||
| 	return False | 	return False | ||||||
|  |  | ||||||
|  | def multiplayer(fro, chan, message): | ||||||
|  | 	def mpMake(): | ||||||
|  | 		return "Not implemented yet." | ||||||
|  |  | ||||||
|  | 	def mpClose(): | ||||||
|  | 		myToken = glob.tokens.getTokenFromUsername(fro) | ||||||
|  | 		if myToken.matchID == -1: | ||||||
|  | 			return "You're not in a multiplayer match" | ||||||
|  | 		glob.matches.disposeMatch(myToken.matchID) | ||||||
|  | 		return "Multiplayer match #{} disposed successfully".format(myToken.matchID) | ||||||
|  |  | ||||||
|  | 	try: | ||||||
|  | 		subcommands = { | ||||||
|  | 			"make": mpMake, | ||||||
|  | 			"clear": mpClose | ||||||
|  | 		} | ||||||
|  | 		requestedSubcommand = message[0].lower().strip() | ||||||
|  | 		if requestedSubcommand not in subcommands: | ||||||
|  | 			raise exceptions.invalidArgumentsException("Invalid subcommand") | ||||||
|  | 		return subcommands[requestedSubcommand]() | ||||||
|  | 	except exceptions.invalidArgumentsException as e: | ||||||
|  | 		return str(e) | ||||||
|  | 	except: | ||||||
|  | 		raise | ||||||
|  |  | ||||||
|  |  | ||||||
| """ | """ | ||||||
| Commands list | Commands list | ||||||
|  |  | ||||||
| @@ -891,6 +917,11 @@ commands = [ | |||||||
| 	}, { | 	}, { | ||||||
| 		"trigger": "!update", | 		"trigger": "!update", | ||||||
| 		"callback": updateBeatmap | 		"callback": updateBeatmap | ||||||
|  | 	}, { | ||||||
|  | 		"trigger": "!mp", | ||||||
|  | 		"privileges": privileges.ADMIN_MANAGE_SERVERS,	# TODO: replace with admin tournament privilege | ||||||
|  | 		"syntax": "<subcommand>", | ||||||
|  | 		"callback": multiplayer | ||||||
| 	} | 	} | ||||||
| 	# | 	# | ||||||
| 	#	"trigger": "!acc", | 	#	"trigger": "!acc", | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ def fokabotResponse(fro, chan, message): | |||||||
| 	""" | 	""" | ||||||
| 	for i in fokabotCommands.commands: | 	for i in fokabotCommands.commands: | ||||||
| 		# Loop though all commands | 		# Loop though all commands | ||||||
| 		if generalUtils.strContains(message, i["trigger"]): | 		if message.strip().startswith(i["trigger"]): | ||||||
| 			# message has triggered a command | 			# message has triggered a command | ||||||
|  |  | ||||||
| 			# Make sure the user has right permissions | 			# Make sure the user has right permissions | ||||||
|   | |||||||
| @@ -440,11 +440,12 @@ class match: | |||||||
|  |  | ||||||
| 		return False | 		return False | ||||||
|  |  | ||||||
| 	def userLeft(self, user): | 	def userLeft(self, user, disposeMatch=True): | ||||||
| 		""" | 		""" | ||||||
| 		Remove someone from users in match | 		Remove someone from users in match | ||||||
|  |  | ||||||
| 		:param user: user object of the user | 		:param user: user object of the user | ||||||
|  | 		:param disposeMatch: if `True`, will try to dispose match if there are no users in the room | ||||||
| 		:return: | 		:return: | ||||||
| 		""" | 		""" | ||||||
| 		# Make sure the user is in room | 		# Make sure the user is in room | ||||||
| @@ -456,10 +457,10 @@ class match: | |||||||
| 		self.setSlot(slotID, slotStatuses.FREE, 0, None, 0) | 		self.setSlot(slotID, slotStatuses.FREE, 0, None, 0) | ||||||
|  |  | ||||||
| 		# Check if everyone left | 		# Check if everyone left | ||||||
| 		if self.countUsers() == 0: | 		if self.countUsers() == 0 and disposeMatch: | ||||||
| 			# Dispose match | 			# Dispose match | ||||||
| 			glob.matches.disposeMatch(self.matchID) | 			glob.matches.disposeMatch(self.matchID) | ||||||
| 			log.info("MPROOM{}: Room disposed".format(self.matchID)) | 			log.info("MPROOM{}: Room disposed because all users left".format(self.matchID)) | ||||||
| 			return | 			return | ||||||
|  |  | ||||||
| 		# Check if host left | 		# Check if host left | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| from objects import match | from objects import match | ||||||
| from objects import glob | from objects import glob | ||||||
| from constants import serverPackets | from constants import serverPackets | ||||||
|  | from common.log import logUtils as log | ||||||
|  |  | ||||||
| class matchList: | class matchList: | ||||||
| 	def __init__(self): | 	def __init__(self): | ||||||
| @@ -38,8 +39,18 @@ class matchList: | |||||||
| 		if matchID not in self.matches: | 		if matchID not in self.matches: | ||||||
| 			return | 			return | ||||||
|  |  | ||||||
| 		# Remove match object and stream | 		# Get match and disconnect all players | ||||||
| 		_match = self.matches.pop(matchID) | 		_match = self.matches[matchID] | ||||||
|  | 		for slot in _match.slots: | ||||||
|  | 			_token = glob.tokens.getTokenFromUserID(slot.userID, ignoreIRC=True) | ||||||
|  | 			if _token is None: | ||||||
|  | 				continue | ||||||
|  | 			_match.userLeft(_token, disposeMatch=False)	# don't dispose the match twice when we remove all players | ||||||
|  |  | ||||||
|  | 		# Send matchDisposed packet before disposing streams | ||||||
|  | 		glob.streams.broadcast(_match.streamName, serverPackets.disposeMatch(_match.matchID)) | ||||||
|  |  | ||||||
|  | 		# Dispose all streams | ||||||
| 		glob.streams.dispose(_match.streamName) | 		glob.streams.dispose(_match.streamName) | ||||||
| 		glob.streams.dispose(_match.playingStreamName) | 		glob.streams.dispose(_match.playingStreamName) | ||||||
| 		glob.streams.remove(_match.streamName) | 		glob.streams.remove(_match.streamName) | ||||||
| @@ -47,3 +58,5 @@ class matchList: | |||||||
|  |  | ||||||
| 		# Send match dispose packet to everyone in lobby | 		# Send match dispose packet to everyone in lobby | ||||||
| 		glob.streams.broadcast("lobby", serverPackets.disposeMatch(matchID)) | 		glob.streams.broadcast("lobby", serverPackets.disposeMatch(matchID)) | ||||||
|  | 		del self.matches[matchID] | ||||||
|  | 		log.info("MPROOM{}: Room disposed manually".format(_match.matchID)) | ||||||
| @@ -323,19 +323,20 @@ class token: | |||||||
| 		self.leaveStream("multi/{}".format(self.matchID)) | 		self.leaveStream("multi/{}".format(self.matchID)) | ||||||
| 		self.leaveStream("multi/{}/playing".format(self.matchID))	# optional | 		self.leaveStream("multi/{}/playing".format(self.matchID))	# optional | ||||||
|  |  | ||||||
|  | 		# Set usertoken match to -1 | ||||||
|  | 		leavingMatchID = self.matchID | ||||||
|  | 		self.matchID = -1 | ||||||
|  |  | ||||||
| 		# Make sure the match exists | 		# Make sure the match exists | ||||||
| 		if self.matchID not in glob.matches.matches: | 		if leavingMatchID not in glob.matches.matches: | ||||||
| 			return | 			return | ||||||
|  |  | ||||||
| 		# The match exists, get object | 		# The match exists, get object | ||||||
| 		match = glob.matches.matches[self.matchID] | 		match = glob.matches.matches[leavingMatchID] | ||||||
|  |  | ||||||
| 		# Set slot to free | 		# Set slot to free | ||||||
| 		match.userLeft(self) | 		match.userLeft(self) | ||||||
|  |  | ||||||
| 		# Set usertoken match to -1 |  | ||||||
| 		self.matchID = -1 |  | ||||||
|  |  | ||||||
| 	def kick(self, message="You have been kicked from the server. Please login again.", reason="kick"): | 	def kick(self, message="You have been kicked from the server. Please login again.", reason="kick"): | ||||||
| 		""" | 		""" | ||||||
| 		Kick this user from the server | 		Kick this user from the server | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user