import logging from paircd.reply import RPL_ENDOFNAMES, RPL_NAMREPLY, RPL_TOPIC from paircd.client import Client from paircd.command_handler import CommandHandler from paircd.message import Message from paircd.server import Server class JoinHandler(CommandHandler): def __init__(self) -> None: super().__init__("JOIN", 1) async def handle(self, server: Server, client: Client, msg: Message) -> None: if not client.registered: client.log("join: not registered", level=logging.WARN) return channel_name = msg.args[0] if not channel_name.startswith("#"): client.log("tried to join invalid channel", level=logging.WARN) return channel = server.get_channel_by_name(channel_name) channel.add_client(client) client.channels.add(channel_name) client.log(f"joined {channel_name}") channel.write_message( Message(cmd="JOIN", args=[channel_name], prefix=client.id()) ) if channel.topic != "": client.write_message( RPL_TOPIC(client.nickname, channel_name, channel.topic) ) client.log("TODO: implement user channel modes", level=logging.WARN) channel_members = list(channel.clients_by_nick.keys()) client.write_message( # "=" means public channel (ref: https://modern.ircdocs.horse/#rplnamreply-353) RPL_NAMREPLY(client.nickname, "=", channel_name, " ".join(channel_members)) ) client.write_message(RPL_ENDOFNAMES(client.nickname, channel_name))