mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-12 05:02:33 +01:00
parent
7f526267ec
commit
df42a81191
@ -26,7 +26,9 @@ class Irc():
|
|||||||
self.lastping = time.time()
|
self.lastping = time.time()
|
||||||
|
|
||||||
# Server, channel, and user indexes to be populated by our protocol module
|
# Server, channel, and user indexes to be populated by our protocol module
|
||||||
self.servers = {self.sid: IrcServer(None, self.serverdata['hostname'], internal=True)}
|
self.servers = {self.sid: IrcServer(None, self.serverdata['hostname'],
|
||||||
|
internal=True, desc=self.serverdata.get('serverdesc')
|
||||||
|
or self.botdata['serverdesc'])}
|
||||||
self.users = {}
|
self.users = {}
|
||||||
self.channels = defaultdict(IrcChannel)
|
self.channels = defaultdict(IrcChannel)
|
||||||
# Sets flags such as whether to use halfops, etc. The default RFC1459
|
# Sets flags such as whether to use halfops, etc. The default RFC1459
|
||||||
@ -307,11 +309,12 @@ class IrcServer():
|
|||||||
name: The name of the server.
|
name: The name of the server.
|
||||||
internal: Whether the server is an internal PyLink PseudoServer.
|
internal: Whether the server is an internal PyLink PseudoServer.
|
||||||
"""
|
"""
|
||||||
def __init__(self, uplink, name, internal=False):
|
def __init__(self, uplink, name, internal=False, desc="(None given)"):
|
||||||
self.uplink = uplink
|
self.uplink = uplink
|
||||||
self.users = set()
|
self.users = set()
|
||||||
self.internal = internal
|
self.internal = internal
|
||||||
self.name = name.lower()
|
self.name = name.lower()
|
||||||
|
self.desc = desc
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return repr(self.__dict__)
|
return repr(self.__dict__)
|
||||||
|
|
||||||
|
@ -285,7 +285,7 @@ class InspIRCdProtocol(TS6BaseProtocol):
|
|||||||
if not utils.isServerName(name):
|
if not utils.isServerName(name):
|
||||||
raise ValueError('Invalid server name %r' % name)
|
raise ValueError('Invalid server name %r' % name)
|
||||||
self._send(uplink, 'SERVER %s * 1 %s :%s' % (name, sid, desc))
|
self._send(uplink, 'SERVER %s * 1 %s :%s' % (name, sid, desc))
|
||||||
self.irc.servers[sid] = IrcServer(uplink, name, internal=True)
|
self.irc.servers[sid] = IrcServer(uplink, name, internal=True, desc=desc)
|
||||||
self._send(sid, 'ENDBURST')
|
self._send(sid, 'ENDBURST')
|
||||||
return sid
|
return sid
|
||||||
|
|
||||||
@ -329,7 +329,8 @@ class InspIRCdProtocol(TS6BaseProtocol):
|
|||||||
if args[2] != self.irc.serverdata['recvpass']:
|
if args[2] != self.irc.serverdata['recvpass']:
|
||||||
# Check if recvpass is correct
|
# Check if recvpass is correct
|
||||||
raise ProtocolError('Error: recvpass from uplink server %s does not match configuration!' % servername)
|
raise ProtocolError('Error: recvpass from uplink server %s does not match configuration!' % servername)
|
||||||
self.irc.servers[numeric] = IrcServer(None, servername)
|
sdesc = ' '.join(args).split(':', 1)[1]
|
||||||
|
self.irc.servers[numeric] = IrcServer(None, servername, desc=sdesc)
|
||||||
self.irc.uplink = numeric
|
self.irc.uplink = numeric
|
||||||
return
|
return
|
||||||
elif args[0] == 'CAPAB':
|
elif args[0] == 'CAPAB':
|
||||||
@ -459,7 +460,7 @@ class InspIRCdProtocol(TS6BaseProtocol):
|
|||||||
servername = args[0].lower()
|
servername = args[0].lower()
|
||||||
sid = args[3]
|
sid = args[3]
|
||||||
sdesc = args[-1]
|
sdesc = args[-1]
|
||||||
self.irc.servers[sid] = IrcServer(numeric, servername)
|
self.irc.servers[sid] = IrcServer(numeric, servername, desc=sdesc)
|
||||||
return {'name': servername, 'sid': args[3], 'text': sdesc}
|
return {'name': servername, 'sid': args[3], 'text': sdesc}
|
||||||
|
|
||||||
def handle_fmode(self, numeric, command, args):
|
def handle_fmode(self, numeric, command, args):
|
||||||
|
@ -276,7 +276,7 @@ class TS6Protocol(TS6BaseProtocol):
|
|||||||
if not utils.isServerName(name):
|
if not utils.isServerName(name):
|
||||||
raise ValueError('Invalid server name %r' % name)
|
raise ValueError('Invalid server name %r' % name)
|
||||||
self._send(uplink, 'SID %s 1 %s :%s' % (name, sid, desc))
|
self._send(uplink, 'SID %s 1 %s :%s' % (name, sid, desc))
|
||||||
self.irc.servers[sid] = IrcServer(uplink, name, internal=True)
|
self.irc.servers[sid] = IrcServer(uplink, name, internal=True, desc=desc)
|
||||||
return sid
|
return sid
|
||||||
|
|
||||||
def squitServer(self, source, target, text='No reason given'):
|
def squitServer(self, source, target, text='No reason given'):
|
||||||
@ -407,6 +407,7 @@ class TS6Protocol(TS6BaseProtocol):
|
|||||||
sname = args[1].lower()
|
sname = args[1].lower()
|
||||||
log.debug('(%s) Found uplink server name as %r', self.irc.name, sname)
|
log.debug('(%s) Found uplink server name as %r', self.irc.name, sname)
|
||||||
self.irc.servers[self.irc.uplink].name = sname
|
self.irc.servers[self.irc.uplink].name = sname
|
||||||
|
self.irc.servers[self.irc.uplink].desc = ' '.join(args).split(':', 1)[1]
|
||||||
# According to the TS6 protocol documentation, we should send SVINFO
|
# According to the TS6 protocol documentation, we should send SVINFO
|
||||||
# when we get our uplink's SERVER command.
|
# when we get our uplink's SERVER command.
|
||||||
self.irc.send('SVINFO 6 6 0 :%s' % int(time.time()))
|
self.irc.send('SVINFO 6 6 0 :%s' % int(time.time()))
|
||||||
@ -593,7 +594,7 @@ class TS6Protocol(TS6BaseProtocol):
|
|||||||
# XXX: don't just save these by their server names; that's ugly!
|
# XXX: don't just save these by their server names; that's ugly!
|
||||||
sid = servername
|
sid = servername
|
||||||
sdesc = args[-1]
|
sdesc = args[-1]
|
||||||
self.irc.servers[sid] = IrcServer(numeric, servername)
|
self.irc.servers[sid] = IrcServer(numeric, servername, desc=sdesc)
|
||||||
return {'name': servername, 'sid': sid, 'text': sdesc}
|
return {'name': servername, 'sid': sid, 'text': sdesc}
|
||||||
|
|
||||||
handle_sid = handle_server
|
handle_sid = handle_server
|
||||||
|
Loading…
Reference in New Issue
Block a user