3
0
mirror of https://github.com/jlu5/PyLink.git synced 2025-01-23 10:44:09 +01:00

relay: make separator a per-network config option

This commit is contained in:
James Lu 2015-07-20 14:36:47 -07:00
parent 2bc0a65128
commit ad34f6c4f9
2 changed files with 9 additions and 2 deletions

View File

@ -43,6 +43,9 @@ servers:
# When more than two consecutive pings are missed, PyLink will disconnect with a ping timeout.
pingfreq: 30
# Separator character (used by relay)
separator: "/"
# Plugins to load (omit the .py extension)
plugins:
- commands

View File

@ -15,12 +15,15 @@ from log import log
dbname = "pylinkrelay.db"
relayusers = defaultdict(dict)
def normalizeNick(irc, netname, nick, separator="/"):
def normalizeNick(irc, netname, nick, separator=None):
# Block until we know the IRC network's nick length (after capabilities
# are sent)
log.debug('(%s) normalizeNick: waiting for irc.connected', irc.name)
irc.connected.wait(1)
separator = separator or irc.serverdata.get('separator') or "/"
log.debug('(%s) normalizeNick: using %r as separator.', irc.name, separator)
orig_nick = nick
protoname = irc.proto.__name__
maxnicklen = irc.maxnicklen
@ -45,7 +48,7 @@ def normalizeNick(irc, netname, nick, separator="/"):
nick = nick[:allowedlength]
nick += suffix
# TODO: factorize
# FIXME: factorize
while utils.nickToUid(irc, nick) and not utils.isInternalClient(irc, utils.nickToUid(irc, nick)):
# The nick we want exists? Darn, create another one then, but only if
# the target isn't an internal client!
@ -53,6 +56,7 @@ def normalizeNick(irc, netname, nick, separator="/"):
# but couldn't be created due to a nick conflict.
# This can happen when someone steals a relay user's nick.
new_sep = separator + separator[-1]
log.debug('(%s) normalizeNick: using %r as new_sep.', irc.name, separator)
nick = normalizeNick(irc, netname, orig_nick, separator=new_sep)
finalLength = len(nick)
assert finalLength <= maxnicklen, "Normalized nick %r went over max " \