diff options
-rw-r--r-- | kike-replies | 2 | ||||
-rw-r--r-- | kike.c | 18 |
2 files changed, 20 insertions, 0 deletions
diff --git a/kike-replies b/kike-replies index 0011120..942eb38 100644 --- a/kike-replies +++ b/kike-replies @@ -41,6 +41,8 @@ 351 IRC_RPL_VERSION "%s.%d %s :%s" 352 IRC_RPL_WHOREPLY "%s %s %s %s %s %s :%d %s" 353 IRC_RPL_NAMREPLY "%c %s :%s" +364 IRC_RPL_LINKS "%s %s :%d %s" +365 IRC_RPL_ENDOFLINKS "%s :End of LINKS list" 366 IRC_RPL_ENDOFNAMES "%s :End of NAMES list" 367 IRC_RPL_BANLIST "%s %s" 368 IRC_RPL_ENDOFBANLIST "%s :End of channel ban list" @@ -2918,6 +2918,23 @@ irc_handle_stats (const struct irc_message *msg, struct client *c) } static void +irc_handle_links (const struct irc_message *msg, struct client *c) +{ + if (msg->params.len > 1 && !irc_is_this_me (c->ctx, msg->params.vector[0])) + RETURN_WITH_REPLY (c, IRC_ERR_NOSUCHSERVER, msg->params.vector[0]); + + const char *mask = "*"; + if (msg->params.len > 0) + mask = msg->params.vector[msg->params.len > 1]; + + if (!irc_fnmatch (mask, c->ctx->server_name)) + irc_send_reply (c, IRC_RPL_LINKS, mask, + c->ctx->server_name, 0 /* hop count */, + str_map_find (&c->ctx->config, "server_info")); + irc_send_reply (c, IRC_RPL_ENDOFLINKS, mask); +} + +static void irc_handle_kill (const struct irc_message *msg, struct client *c) { if (msg->params.len < 2) @@ -2973,6 +2990,7 @@ irc_register_handlers (struct server_context *ctx) { "AWAY", true, irc_handle_away, 0, 0 }, { "ADMIN", true, irc_handle_admin, 0, 0 }, { "STATS", true, irc_handle_stats, 0, 0 }, + { "LINKS", true, irc_handle_links, 0, 0 }, { "MODE", true, irc_handle_mode, 0, 0 }, { "PRIVMSG", true, irc_handle_privmsg, 0, 0 }, |