patch 88dc8263a1e44bbacb642ba34ec7ddcfa6ec0719 Author: E. Bosch Date: Sun Feb 21 23:35:32 CET 2021 * irc: Add VERSION command diff -rN -u old-irgramd/irc.py new-irgramd/irc.py --- old-irgramd/irc.py 2024-11-23 02:01:39.005486256 +0100 +++ new-irgramd/irc.py 2024-11-23 02:01:39.009486249 +0100 @@ -34,6 +34,7 @@ IRC_QUIT_RX = re.compile(PREFIX + r'QUIT( +:| +|\n)(?P[^\n]+|)') IRC_TOPIC_RX = re.compile(PREFIX + r'TOPIC( +:| +|\n)(?P[^\n ]+|)') IRC_USER_RX = re.compile(PREFIX + r'USER( +|\n)(?P[^ ]+) +[^ ]+ +[^ ]+( +:| +|\n)(?P[^\n]+|)') +IRC_VERSION_RX = re.compile(PREFIX + r'VERSION( +:| +|\n)(?P[^\n ]+|)') IRC_WHO_RX = re.compile(PREFIX + r'WHO( +:| +|\n)(?P[^\n ]+|)') IRC_WHOIS_RX = re.compile(PREFIX + r'WHOIS( +:| +|\n)(?P[^\n ]+|)') @@ -109,6 +110,7 @@ (IRC_QUIT_RX, self.handle_irc_quit, False, False), (IRC_TOPIC_RX, self.handle_irc_topic, True, True), (IRC_USER_RX, self.handle_irc_user, False, True), + (IRC_VERSION_RX, self.handle_irc_version, True, False), (IRC_WHO_RX, self.handle_irc_who, True, True), (IRC_WHOIS_RX, self.handle_irc_whois, True, True), ) @@ -256,6 +258,16 @@ else: await self.reply_code(user, 'ERR_NOSUCHNICK', (nick,)) + async def handle_irc_version(self, user, target): + self.logger.debug('Handling VERSION: %s', target) + + tgt = target.lower() + if not tgt or tgt == self.hostname or tgt in self.users.keys(): + await self.reply_code(user, 'RPL_VERSION', (VERSION, self.hostname)) + await self.send_isupport(user) + else: + await self.reply_code(user, 'ERR_NOSUCHSERVER', (target,)) + async def handle_irc_privmsg(self, user, nick, message): self.logger.debug('Handling PRIVMSG: %s, %s', nick, message) @@ -301,7 +313,7 @@ await self.reply_code(user, 'RPL_YOURHOST', (self.hostname, VERSION)) await self.reply_code(user, 'RPL_CREATED', (self.start_time,)) await self.reply_code(user, 'RPL_MYINFO', (self.hostname, VERSION)) - await self.reply_code(user, 'RPL_ISUPPORT', (str(CHAN_MAX_LENGHT), str(NICK_MAX_LENGTH))) + await self.send_isupport(user) await self.send_motd(user) async def send_motd(self, user): @@ -318,6 +330,9 @@ await self.reply_code(user, 'RPL_MOTD', ('darcs repository: https://src.presi.org/darcs/irgramd',)) await self.reply_code(user, 'RPL_ENDOFMOTD') + async def send_isupport(self, user): + await self.reply_code(user, 'RPL_ISUPPORT', (CHAN_MAX_LENGHT, NICK_MAX_LENGTH)) + async def send_users_irc(self, prfx, command, params): for usr in [x for x in self.users.values() if x.stream]: await self.reply_command(usr, prfx, command, params) diff -rN -u old-irgramd/irc_replies.py new-irgramd/irc_replies.py --- old-irgramd/irc_replies.py 2024-11-23 02:01:39.005486256 +0100 +++ new-irgramd/irc_replies.py 2024-11-23 02:01:39.009486249 +0100 @@ -18,6 +18,7 @@ 'RPL_TOPIC': ('332', '{} :{}'), 'RPL_TOPICWHOTIME': ('333', '{} {} {}'), 'RPL_WHOISBOT': ('335', '{} :is a Telegram bot'), + 'RPL_VERSION': ('351', 'irgramd-{} {} :IRC to Telegram gateway'), 'RPL_WHOREPLY': ('352', '{} {} {} {} {} H{} :0 {}'), 'RPL_NAMREPLY': ('353', '{} {} :{}'), 'RPL_ENDOFNAMES': ('366', '{} :End of NAME reply'),