summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorPeter Powell <petpow@saberuk.com>2018-08-13 21:44:11 +0100
committerPeter Powell <petpow@saberuk.com>2018-08-13 22:01:21 +0100
commit224952435591734d8308fd2b612d51c030416e53 (patch)
tree5e4c0af3f77687cdeefdbd32e45c2cfb030d2616 /include
parentc60f88bb5ce23d1291dddfd3e15ba71c801b7d3c (diff)
Add support for the IRCv3 server-time specification.
Co-authored-by: Attila Molnar <attilamolnar@hush.com>
Diffstat (limited to 'include')
-rw-r--r--include/modules/ircv3_servertime.h88
1 files changed, 88 insertions, 0 deletions
diff --git a/include/modules/ircv3_servertime.h b/include/modules/ircv3_servertime.h
new file mode 100644
index 000000000..b917531a0
--- /dev/null
+++ b/include/modules/ircv3_servertime.h
@@ -0,0 +1,88 @@
+/*
+ * InspIRCd -- Internet Relay Chat Daemon
+ *
+ * Copyright (C) 2016 Attila Molnar <attilamolnar@hush.com>
+ *
+ * This file is part of InspIRCd. InspIRCd is free software: you can
+ * redistribute it and/or modify it under the terms of the GNU General Public
+ * License as published by the Free Software Foundation, version 2.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+
+#pragma once
+
+namespace IRCv3
+{
+ namespace ServerTime
+ {
+ class Manager;
+ class API;
+
+ /** Format a unix timestamp into the format used by server-time.
+ * @param t Time to format.
+ * @return Time in server-time format, as a string.
+ */
+ inline std::string FormatTime(time_t t)
+ {
+ return InspIRCd::TimeString(t, "%Y-%m-%dT%H:%M:%S.000Z", true);
+ }
+ }
+}
+
+/** Implements manipulating the server time on messages.
+ * A timestamp can be attached to outgoing client protocol messages to indicate the time when the message
+ * was generated by us. If a message has server time attached then recipient clients who have negotiated
+ * the appropriate protocol extension will receive it.
+ */
+class IRCv3::ServerTime::Manager : public DataProvider
+{
+ protected:
+ ClientProtocol::MessageTagProvider* tagprov;
+
+ public:
+ /** Constructor.
+ * @param mod Module that owns the Manager.
+ */
+ Manager(Module* mod)
+ : DataProvider(mod, "servertimeapi")
+ {
+ }
+
+ /** Set the server time on a message.
+ * @param msg Message to set the time on. No-op if the message already has server time set.
+ * @param t Unix timestamp to set.
+ */
+ void Set(ClientProtocol::Message& msg, time_t t)
+ {
+ Set(msg, FormatTime(t));
+ }
+
+ /** Set the server time on a message.
+ * @param msg Message to set the time on. No-op if the message already has server time set.
+ * @param timestr Timestamp to set. Must be in server time format.
+ * The FormatTime() function can be used to convert unix timestamps into the required format.
+ */
+ void Set(ClientProtocol::Message& msg, const std::string& timestr)
+ {
+ msg.AddTag("time", tagprov, timestr);
+ }
+};
+
+/** Server time API. Use this to access the Manager.
+ */
+class IRCv3::ServerTime::API : public dynamic_reference_nocheck<Manager>
+{
+ public:
+ API(Module* mod)
+ : dynamic_reference_nocheck<Manager>(mod, "servertimeapi")
+ {
+ }
+};