mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-23 18:54:05 +01:00
relay: rebase "no duplicate modes" branch over devel
Conflicts: plugins/relay.py
This commit is contained in:
parent
7b84bda11b
commit
48aa0c3160
@ -472,6 +472,10 @@ def relayModes(irc, remoteirc, sender, channel, modes=None):
|
|||||||
for name, m in irc.cmodes.items():
|
for name, m in irc.cmodes.items():
|
||||||
supported_char = None
|
supported_char = None
|
||||||
if modechar == m:
|
if modechar == m:
|
||||||
|
supported_char = remoteirc.cmodes.get(name)
|
||||||
|
if supported_char is None:
|
||||||
|
break
|
||||||
|
modepair = (prefix+supported_char, arg)
|
||||||
if name not in whitelisted_cmodes:
|
if name not in whitelisted_cmodes:
|
||||||
log.debug("(%s) Relay mode: skipping mode (%r, %r) because "
|
log.debug("(%s) Relay mode: skipping mode (%r, %r) because "
|
||||||
"it isn't a whitelisted (safe) mode for relay.",
|
"it isn't a whitelisted (safe) mode for relay.",
|
||||||
@ -490,6 +494,11 @@ def relayModes(irc, remoteirc, sender, channel, modes=None):
|
|||||||
log.debug("(%s) Relay mode: argument found as (%r, %r) "
|
log.debug("(%s) Relay mode: argument found as (%r, %r) "
|
||||||
"for network %r.",
|
"for network %r.",
|
||||||
irc.name, modechar, arg, remoteirc.name)
|
irc.name, modechar, arg, remoteirc.name)
|
||||||
|
if arg in remoteirc.channels[remotechan].prefixmodes[name+'s']:
|
||||||
|
# Don't set prefix modes that are already set.
|
||||||
|
log.debug("(%s) Relay mode: skipping setting %s on %s/%s because it appears to be already set.",
|
||||||
|
irc.name, name, arg, remoteirc.name)
|
||||||
|
break
|
||||||
supported_char = remoteirc.cmodes.get(name)
|
supported_char = remoteirc.cmodes.get(name)
|
||||||
if supported_char:
|
if supported_char:
|
||||||
if name in ('ban', 'banexception', 'invex') and not utils.isHostmask(arg):
|
if name in ('ban', 'banexception', 'invex') and not utils.isHostmask(arg):
|
||||||
@ -497,7 +506,13 @@ def relayModes(irc, remoteirc, sender, channel, modes=None):
|
|||||||
log.debug("(%s) Relay mode: skipping mode (%r, %r) because it doesn't match nick!user@host syntax.",
|
log.debug("(%s) Relay mode: skipping mode (%r, %r) because it doesn't match nick!user@host syntax.",
|
||||||
irc.name, modechar, arg)
|
irc.name, modechar, arg)
|
||||||
break
|
break
|
||||||
supported_modes.append((prefix+supported_char, arg))
|
# Don't set modes that are already set, to prevent floods on TS6
|
||||||
|
# where the same mode can be set infinite times.
|
||||||
|
if modepair in remoteirc.channels[remotechan].modes:
|
||||||
|
log.debug("(%s) Relay mode: skipping setting mode (%r, %r) on %s%s because it appears to be already set.",
|
||||||
|
irc.name, supported_char, arg, remoteirc.name, remotechan)
|
||||||
|
break
|
||||||
|
supported_modes.append(modepair)
|
||||||
log.debug('(%s) Relay mode: final modelist (sending to %s%s) is %s', irc.name, remoteirc.name, remotechan, supported_modes)
|
log.debug('(%s) Relay mode: final modelist (sending to %s%s) is %s', irc.name, remoteirc.name, remotechan, supported_modes)
|
||||||
# Don't send anything if there are no supported modes left after filtering.
|
# Don't send anything if there are no supported modes left after filtering.
|
||||||
if supported_modes:
|
if supported_modes:
|
||||||
|
Loading…
Reference in New Issue
Block a user