]> jfr.im git - solanum.git/blobdiff - modules/cap_server_time.c
Combine stats A output parameters (#35)
[solanum.git] / modules / cap_server_time.c
index b20f5d09fadcaa33ac54a534bfa2400f13ca1f6c..1fd383fd3bd048fad2785730e67e43b6f371922d 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * charybdis: an advanced ircd.
+ * Solanum: a slightly advanced ircd
  * cap_server_time.c: implement the server-time IRCv3.2 capability
  *
  * Copyright (c) 2016 William Pitcock <nenolod@dereferenced.org>
 #include "chmode.h"
 #include "inline/stringops.h"
 
+static const char cap_server_time_desc[] =
+       "Provides the server-time client capability";
+
 static void cap_server_time_process(hook_data *);
+unsigned int CLICAP_SERVER_TIME = 0;
 
 mapi_hfn_list_av1 cap_server_time_hfnlist[] = {
        { "outbound_msgbuf", (hookfn) cap_server_time_process },
        { NULL, NULL }
 };
-
-unsigned int CLICAP_SERVER_TIME = 0;
+mapi_cap_list_av2 cap_server_time_cap_list[] = {
+       { MAPI_CAP_CLIENT, "server-time", NULL, &CLICAP_SERVER_TIME },
+       { 0, NULL, NULL, NULL }
+};
 
 static void
 cap_server_time_process(hook_data *data)
 {
-       static char buf[IRCD_BUFSIZE];
-       time_t ts = rb_current_time();
+       static char buf[BUFSIZE];
        struct MsgBuf *msgbuf = data->arg1;
+       struct timeval tv;
 
-       strftime(buf, sizeof buf, "%Y-%m-%dT%H:%M:%S.000Z", gmtime(&ts));
+       if (!rb_gettimeofday(&tv, NULL)) {
+               if (strftime(buf, sizeof(buf), "%Y-%m-%dT%H:%M:%S.", gmtime(&tv.tv_sec)) == 0)
+                       return;
 
-       msgbuf_append_tag(msgbuf, "time", buf, CLICAP_SERVER_TIME);
-}
+               if (rb_snprintf_append(buf, sizeof(buf), "%03uZ", (int)tv.tv_usec / 1000) < 0)
+                       return;
 
-static int
-_modinit(void)
-{
-       CLICAP_SERVER_TIME = capability_put(cli_capindex, "server-time", NULL);
-       return 0;
-}
-
-static void
-_moddeinit(void)
-{
-       capability_orphan(cli_capindex, "server-time");
+               msgbuf_append_tag(msgbuf, "time", buf, CLICAP_SERVER_TIME);
+       }
 }
 
-DECLARE_MODULE_AV1(cap_server_time, _modinit, _moddeinit, NULL, NULL, cap_server_time_hfnlist, "$Revision$");
+DECLARE_MODULE_AV2(cap_server_time, NULL, NULL, NULL, NULL, cap_server_time_hfnlist, cap_server_time_cap_list, NULL, cap_server_time_desc);