aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--kike-replies2
-rw-r--r--kike.c18
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"
diff --git a/kike.c b/kike.c
index 08b015b..602f654 100644
--- a/kike.c
+++ b/kike.c
@@ -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 },