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:
parent
fd909395ff
commit
9f454402d2
@ -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):
|
||||||
|
Loading…
Reference in New Issue
Block a user