3
0
mirror of https://github.com/jlu5/PyLink.git synced 2025-01-12 21:22:36 +01:00

nefarious: don't confuse the TS argument with the user list, if a BURST is sent with only bans

This commit is contained in:
James Lu 2016-04-18 21:29:00 -07:00
parent fd909395ff
commit 9f454402d2

View File

@ -927,8 +927,6 @@ class P10Protocol(Protocol):
# Remove this argument from the args list. # Remove this argument from the args list.
args = args[:-1] args = args[:-1]
userlist = args[-1].split(',')
# Then, we can make the modestring just encompass all the text until the end of the string. # Then, we can make the modestring just encompass all the text until the end of the string.
# If no modes are given, this will simply be empty. # If no modes are given, this will simply be empty.
modestring = args[2:-1] modestring = args[2:-1]
@ -947,31 +945,35 @@ class P10Protocol(Protocol):
log.debug('(%s) handle_sjoin: got userlist %r for %r', self.irc.name, userlist, channel) log.debug('(%s) handle_sjoin: got userlist %r for %r', self.irc.name, userlist, channel)
prefixes = '' prefixes = ''
for userpair in userlist:
# This is given in the form UID1,UID2:prefixes. However, when one userpair is given
# with a certain prefix, it implicitly applies to all other following UIDs, until
# another userpair is given with a prefix. For example: UID1,UID3:o,UID4,UID5 would
# assume that UID1 has no prefixes, but UID3-5 all have op when joining.
try:
user, prefixes = userpair.split(':')
except ValueError:
user = userpair
log.debug('(%s) handle_burst: got mode prefixes %r for user %r', self.irc.name, prefixes, user)
# Don't crash when we get an invalid UID. userlist = args[-1].split(',')
if user not in self.irc.users: if args[-1] != args[1]: # Make sure the userlist is the right argument (not the TS).
log.warning('(%s) handle_burst: tried to introduce user %s not in our user list, ignoring...', for userpair in userlist:
self.irc.name, user) # This is given in the form UID1,UID2:prefixes. However, when one userpair is given
continue # with a certain prefix, it implicitly applies to all other following UIDs, until
# another userpair is given with a prefix. For example: UID1,UID3:o,UID4,UID5 would
# assume that UID1 has no prefixes, but UID3-5 all have op when joining.
try:
user, prefixes = userpair.split(':')
except ValueError:
user = userpair
log.debug('(%s) handle_burst: got mode prefixes %r for user %r', self.irc.name, prefixes, user)
namelist.append(user) # Don't crash when we get an invalid UID.
if user not in self.irc.users:
log.warning('(%s) handle_burst: tried to introduce user %s not in our user list, ignoring...',
self.irc.name, user)
continue
self.irc.users[user].channels.add(channel) namelist.append(user)
if their_ts <= our_ts: self.irc.users[user].channels.add(channel)
utils.applyModes(self.irc, channel, [('+%s' % mode, user) for mode in prefixes])
if their_ts <= our_ts:
utils.applyModes(self.irc, channel, [('+%s' % mode, user) for mode in prefixes])
self.irc.channels[channel].users.add(user)
self.irc.channels[channel].users.add(user)
return {'channel': channel, 'users': namelist, 'modes': parsedmodes, 'ts': their_ts} return {'channel': channel, 'users': namelist, 'modes': parsedmodes, 'ts': their_ts}
def handle_join(self, source, command, args): def handle_join(self, source, command, args):