mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-12 13:12:36 +01:00
unreal: handle timestamps in MODE (channel bursts), ignoring when TS is 0
This commit is contained in:
parent
f39321f2e7
commit
4a4c43d3c4
@ -383,7 +383,7 @@ class UnrealProtocol(TS6BaseProtocol):
|
|||||||
userlist = args[-1].split()
|
userlist = args[-1].split()
|
||||||
our_ts = self.irc.channels[channel].ts
|
our_ts = self.irc.channels[channel].ts
|
||||||
their_ts = int(args[0])
|
their_ts = int(args[0])
|
||||||
if their_ts < our_ts:
|
if their_ts < our_ts and their_ts > 0:
|
||||||
# Channel timestamp was reset on burst
|
# Channel timestamp was reset on burst
|
||||||
log.debug('(%s) Setting channel TS of %s to %s from %s',
|
log.debug('(%s) Setting channel TS of %s to %s from %s',
|
||||||
self.irc.name, channel, their_ts, our_ts)
|
self.irc.name, channel, their_ts, our_ts)
|
||||||
@ -426,20 +426,39 @@ class UnrealProtocol(TS6BaseProtocol):
|
|||||||
# <- :unreal.midnight.vpn MODE #endlessvoid +q GL 1444361345
|
# <- :unreal.midnight.vpn MODE #endlessvoid +q GL 1444361345
|
||||||
# <- :unreal.midnight.vpn MODE #endlessvoid +ntCo GL 1444361345
|
# <- :unreal.midnight.vpn MODE #endlessvoid +ntCo GL 1444361345
|
||||||
# <- :unreal.midnight.vpn MODE #endlessvoid +mntClfo 5 [10t]:5 GL 1444361345
|
# <- :unreal.midnight.vpn MODE #endlessvoid +mntClfo 5 [10t]:5 GL 1444361345
|
||||||
# Well... this seems relatively inconsistent.
|
# <- :GL MODE #services +v GL
|
||||||
# Why does only setting some modes show a TS?
|
|
||||||
|
# This seems pretty relatively inconsistent - why do some commands have a TS at the end while others don't?
|
||||||
|
# Answer: the first syntax (MODE sent by SERVER) is used for channel bursts - according to Unreal 3.2 docs,
|
||||||
|
# the last argument should be interpreted as a timestamp ONLY if it is a number and the sender is a server.
|
||||||
|
# Ban bursting does not give any TS, nor do normal users setting modes. SAMODE is special though, it will
|
||||||
|
# send 0 as a TS argument (which should be ignored unless breaking the internal channel TS is desired).
|
||||||
|
|
||||||
# Also, we need to get rid of that extra space following the +f argument. :|
|
# Also, we need to get rid of that extra space following the +f argument. :|
|
||||||
if utils.isChannel(args[0]):
|
if utils.isChannel(args[0]):
|
||||||
channel = utils.toLower(self.irc, args[0])
|
channel = utils.toLower(self.irc, args[0])
|
||||||
oldobj = self.irc.channels[channel].deepcopy()
|
oldobj = self.irc.channels[channel].deepcopy()
|
||||||
modes = list(filter(None, args[1:]))
|
modes = list(filter(None, args[1:])) # normalize whitespace
|
||||||
parsedmodes = utils.parseModes(self.irc, channel, modes)
|
parsedmodes = utils.parseModes(self.irc, channel, modes)
|
||||||
if parsedmodes:
|
if parsedmodes:
|
||||||
utils.applyModes(self.irc, channel, parsedmodes)
|
utils.applyModes(self.irc, channel, parsedmodes)
|
||||||
|
if numeric in self.irc.servers and args[-1].isdigit():
|
||||||
|
# Sender is a server AND last arg is number. Perform TS updates.
|
||||||
|
our_ts = self.irc.channels[channel].ts
|
||||||
|
their_ts = int(args[-1])
|
||||||
|
if their_ts < our_ts and their_ts > 0:
|
||||||
|
# Channel timestamp was reset on burst
|
||||||
|
log.debug('(%s) Setting channel TS of %s to %s from %s',
|
||||||
|
self.irc.name, channel, their_ts, our_ts)
|
||||||
|
self.irc.channels[channel].ts = their_ts
|
||||||
|
self.irc.channels[channel].modes.clear()
|
||||||
|
for p in self.irc.channels[channel].prefixmodes.values():
|
||||||
|
p.clear()
|
||||||
return {'target': channel, 'modes': parsedmodes, 'oldchan': oldobj}
|
return {'target': channel, 'modes': parsedmodes, 'oldchan': oldobj}
|
||||||
else:
|
else:
|
||||||
log.warning("(%s) received MODE for non-channel target: %r",
|
log.warning("(%s) received MODE for non-channel target: %r",
|
||||||
self.irc.name, args)
|
self.irc.name, args)
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def handle_umode2(self, numeric, command, args):
|
def handle_umode2(self, numeric, command, args):
|
||||||
"""Handles UMODE2, used to set user modes on oneself."""
|
"""Handles UMODE2, used to set user modes on oneself."""
|
||||||
|
Loading…
Reference in New Issue
Block a user