summaryrefslogtreecommitdiff
path: root/modules/protocol/solanum.cpp
diff options
context:
space:
mode:
authorSadie Powell <sadie@witchery.services>2021-04-21 14:02:32 +0100
committerSadie Powell <sadie@witchery.services>2021-04-21 14:05:35 +0100
commit622a8ea7e9e8cf50897648cf88e8d745fd145b4f (patch)
treee96c6d6f12e668fb28b60b1049d849ccc902400c /modules/protocol/solanum.cpp
parent0a518f4bbd4791e06924ed2e981d7da56869f024 (diff)
Implement support for the Solanum ECHO server capability.
https://github.com/solanum-ircd/solanum/commit/4cac091255d972b0131ffbf0cd278f984bd892d4
Diffstat (limited to 'modules/protocol/solanum.cpp')
-rw-r--r--modules/protocol/solanum.cpp43
1 files changed, 35 insertions, 8 deletions
diff --git a/modules/protocol/solanum.cpp b/modules/protocol/solanum.cpp
index 0a20cbf7f..9ec234539 100644
--- a/modules/protocol/solanum.cpp
+++ b/modules/protocol/solanum.cpp
@@ -88,6 +88,7 @@ class SolanumProto : public IRCDProto
* BAN - Can do BAN message
* CHW - Can do channel wall @#
* CLUSTER - Supports umode +l, can send LOCOPS (encap only)
+ * ECHO - Supports sending echoed messages
* ENCAP - Can do ENCAP message
* EOPMOD - Can do channel wall =# (for cmode +z)
* EUID - Can do EUID (its similar to UID but includes the ENCAP REALHOST and ENCAP LOGIN information)
@@ -104,7 +105,7 @@ class SolanumProto : public IRCDProto
* UNKLN - Can do UNKLINE (encap only)
* QS - Can handle quit storm removal
*/
- UplinkSocket::Message() << "CAPAB :BAN CHW CLUSTER ENCAP EOPMOD EUID EX IE KLN KNOCK MLOCK QS RSFNC SERVICES TB UNKLN";
+ UplinkSocket::Message() << "CAPAB :BAN CHW CLUSTER ECHO ENCAP EOPMOD EUID EX IE KLN KNOCK MLOCK QS RSFNC SERVICES TB UNKLN";
/* Make myself known to myself in the serverlist */
SendServer(Me);
@@ -276,6 +277,32 @@ struct IRCDMessagePass : IRCDMessage
}
};
+struct IRCDMessageNotice : Message::Notice
+{
+ IRCDMessageNotice(Module *creator) : Message::Notice(creator) { }
+
+ void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) anope_override
+ {
+ if (Servers::Capab.count("ECHO"))
+ UplinkSocket::Message(Me) << "ECHO N " << " " << source.GetSource() << " " << params[1];
+
+ Message::Notice::Run(source, params, tags);
+ }
+};
+
+struct IRCDMessagePrivmsg : Message::Privmsg
+{
+ IRCDMessagePrivmsg(Module *creator) : Message::Privmsg(creator) { }
+
+ void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) anope_override
+ {
+ if (Servers::Capab.count("ECHO"))
+ UplinkSocket::Message(Me) << "ECHO P " << " " << source.GetSource() << " " << params[1];
+
+ Message::Privmsg::Run(source, params, tags);
+ }
+};
+
class ProtoSolanum : public Module
{
Module *m_ratbox;
@@ -291,10 +318,8 @@ class ProtoSolanum : public Module
Message::Kill message_kill;
Message::Mode message_mode;
Message::MOTD message_motd;
- Message::Notice message_notice;
Message::Part message_part;
Message::Ping message_ping;
- Message::Privmsg message_privmsg;
Message::Quit message_quit;
Message::SQuit message_squit;
Message::Stats message_stats;
@@ -310,7 +335,9 @@ class ProtoSolanum : public Module
/* Our message handlers */
IRCDMessageEncap message_encap;
IRCDMessageEUID message_euid;
+ IRCDMessageNotice message_notice;
IRCDMessagePass message_pass;
+ IRCDMessagePrivmsg message_privmsg;
IRCDMessageServer message_server;
bool use_server_side_mlock;
@@ -343,9 +370,9 @@ class ProtoSolanum : public Module
ProtoSolanum(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, PROTOCOL | VENDOR),
ircd_proto(this),
message_away(this), message_capab(this), message_error(this), message_invite(this), message_kick(this),
- message_kill(this), message_mode(this), message_motd(this), message_notice(this), message_part(this),
- message_ping(this), message_privmsg(this), message_quit(this), message_squit(this), message_stats(this),
- message_time(this), message_topic(this), message_version(this), message_whois(this),
+ message_kill(this), message_mode(this), message_motd(this), message_part(this), message_ping(this),
+ message_quit(this), message_squit(this), message_stats(this), message_time(this), message_topic(this),
+ message_version(this), message_whois(this),
message_bmask("IRCDMessage", "solanum/bmask", "ratbox/bmask"),
message_join("IRCDMessage", "solanum/join", "ratbox/join"),
@@ -357,8 +384,8 @@ class ProtoSolanum : public Module
message_tmode("IRCDMessage", "solanum/tmode", "ratbox/tmode"),
message_uid("IRCDMessage", "solanum/uid", "ratbox/uid"),
- message_encap(this), message_euid(this), message_pass(this), message_server(this)
-
+ message_encap(this), message_euid(this), message_notice(this), message_pass(this),
+ message_privmsg(this), message_server(this)
{