summaryrefslogtreecommitdiff
path: root/modules/protocol/charybdis.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2016-12-08 10:18:27 -0500
committerAdam <Adam@anope.org>2016-12-08 10:18:27 -0500
commited08d1a31119adb379f8bec46d7ad47ee35c4c92 (patch)
treebe5de3edeaf26ad7efbf23a3d6508645614f283e /modules/protocol/charybdis.cpp
parent0d112886980787ffd5c69e514eebe476bcec8343 (diff)
Export protocol implementations into protocol module headers
Diffstat (limited to 'modules/protocol/charybdis.cpp')
-rw-r--r--modules/protocol/charybdis.cpp222
1 files changed, 99 insertions, 123 deletions
diff --git a/modules/protocol/charybdis.cpp b/modules/protocol/charybdis.cpp
index c111a31d3..4488f5425 100644
--- a/modules/protocol/charybdis.cpp
+++ b/modules/protocol/charybdis.cpp
@@ -40,143 +40,119 @@ class ChannelModeLargeBan : public ChannelMode
};
-class CharybdisProto : public IRCDProto
+charybdis::Proto::Proto(Module *creator) : IRCDProto(creator, "Charybdis 3.4+")
+ , ratbox("ratbox")
{
- ServiceReference<IRCDProto> ratbox; // XXX
-
- public:
- CharybdisProto(Module *creator) : IRCDProto(creator, "Charybdis 3.4+")
- , ratbox("ratbox")
- {
- DefaultPseudoclientModes = "+oiS";
- CanCertFP = true;
- CanSNLine = true;
- CanSQLine = true;
- CanSQLineChannel = true;
- CanSZLine = true;
- CanSVSNick = true;
- CanSVSHold = true;
- CanSetVHost = true;
- RequiresID = true;
- MaxModes = 4;
- }
+ DefaultPseudoclientModes = "+oiS";
+ CanCertFP = true;
+ CanSNLine = true;
+ CanSQLine = true;
+ CanSQLineChannel = true;
+ CanSZLine = true;
+ CanSVSNick = true;
+ CanSVSHold = true;
+ CanSetVHost = true;
+ RequiresID = true;
+ MaxModes = 4;
+}
- void SendSVSKill(const MessageSource &source, User *targ, const Anope::string &reason) override { ratbox->SendSVSKill(source, targ, reason); }
- void SendGlobalNotice(ServiceBot *bi, Server *dest, const Anope::string &msg) override { ratbox->SendGlobalNotice(bi, dest, msg); }
- void SendGlobalPrivmsg(ServiceBot *bi, Server *dest, const Anope::string &msg) override { ratbox->SendGlobalPrivmsg(bi, dest, msg); }
- void SendGlobops(const MessageSource &source, const Anope::string &buf) override { ratbox->SendGlobops(source, buf); }
- void SendSGLine(User *u, XLine *x) override { ratbox->SendSGLine(u, x); }
- void SendSGLineDel(XLine *x) override { ratbox->SendSGLineDel(x); }
- void SendAkill(User *u, XLine *x) override { ratbox->SendAkill(u, x); }
- void SendAkillDel(XLine *x) override { ratbox->SendAkillDel(x); }
- void SendSQLine(User *u, XLine *x) override { ratbox->SendSQLine(u, x); }
- void SendSQLineDel(XLine *x) override { ratbox->SendSQLineDel(x); }
- void SendJoin(User *user, Channel *c, const ChannelStatus *status) override { ratbox->SendJoin(user, c, status); }
- void SendServer(Server *server) override { ratbox->SendServer(server); }
- void SendChannel(Channel *c) override { ratbox->SendChannel(c); }
- void SendTopic(const MessageSource &source, Channel *c) override { ratbox->SendTopic(source, c); }
- bool IsIdentValid(const Anope::string &ident) override { return ratbox->IsIdentValid(ident); }
- void SendLogin(User *u, NickServ::Nick *na) override { ratbox->SendLogin(u, na); }
- void SendLogout(User *u) override { ratbox->SendLogout(u); }
-
- void SendConnect() override
- {
- Uplink::Send("PASS", Config->Uplinks[Anope::CurrentUplink].password, "TS", 6, Me->GetSID());
-
- /*
- * Received: CAPAB :BAN CHW CLUSTER ENCAP EOPMOD EUID EX IE KLN
- * KNOCK MLOCK QS RSFNC SAVE SERVICES TB UNKLN
- *
- * BAN - Can do BAN message
- * CHW - Can do channel wall @#
- * CLUSTER - Supports umode +l, can send LOCOPS (encap only)
- * 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)
- * EX - Can do channel +e exemptions
- * GLN - Can set G:Lines
- * IE - Can do invite exceptions
- * KLN - Can set K:Lines (encap only)
- * KNOCK - Supports KNOCK
- * MLOCK - Supports MLOCK
- * RSFNC - Forces a nickname change and propagates it (encap only)
- * SERVICES - Support channel mode +r (only registered users may join)
- * SAVE - Resolve a nick collision by changing a nickname to the UID.
- * TB - Supports topic burst
- * UNKLN - Can do UNKLINE (encap only)
- * QS - Can handle quit storm removal
- */
- Uplink::Send("CAPAB", "BAN CHW CLUSTER ENCAP EOPMOD EUID EX IE KLN KNOCK MLOCK QS RSFNC SERVICES TB UNKLN");
-
- /* Make myself known to myself in the serverlist */
- SendServer(Me);
-
- /*
- * Received: SVINFO 6 6 0 :1353235537
- * arg[0] = current TS version
- * arg[1] = minimum required TS version
- * arg[2] = '0'
- * arg[3] = server's idea of UTC time
- */
- Uplink::Send("SVINFO", 6, 6, Anope::CurTime);
- }
+void charybdis::Proto::SendConnect()
+{
+ Uplink::Send("PASS", Config->Uplinks[Anope::CurrentUplink].password, "TS", 6, Me->GetSID());
- void SendClientIntroduction(User *u) override
- {
- Anope::string modes = "+" + u->GetModes();
- Uplink::Send(Me, "EUID", u->nick, 1, u->timestamp, modes, u->GetIdent(), u->host, 0, u->GetUID(), "*", "*", u->realname);
- }
+ /*
+ * Received: CAPAB :BAN CHW CLUSTER ENCAP EOPMOD EUID EX IE KLN
+ * KNOCK MLOCK QS RSFNC SAVE SERVICES TB UNKLN
+ *
+ * BAN - Can do BAN message
+ * CHW - Can do channel wall @#
+ * CLUSTER - Supports umode +l, can send LOCOPS (encap only)
+ * 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)
+ * EX - Can do channel +e exemptions
+ * GLN - Can set G:Lines
+ * IE - Can do invite exceptions
+ * KLN - Can set K:Lines (encap only)
+ * KNOCK - Supports KNOCK
+ * MLOCK - Supports MLOCK
+ * RSFNC - Forces a nickname change and propagates it (encap only)
+ * SERVICES - Support channel mode +r (only registered users may join)
+ * SAVE - Resolve a nick collision by changing a nickname to the UID.
+ * TB - Supports topic burst
+ * UNKLN - Can do UNKLINE (encap only)
+ * QS - Can handle quit storm removal
+ */
+ Uplink::Send("CAPAB", "BAN CHW CLUSTER ENCAP EOPMOD EUID EX IE KLN KNOCK MLOCK QS RSFNC SERVICES TB UNKLN");
+
+ /* Make myself known to myself in the serverlist */
+ SendServer(Me);
- void SendForceNickChange(User *u, const Anope::string &newnick, time_t when) override
- {
- Uplink::Send(Me, "ENCAP", u->server->GetName(), "RSFNC", u->GetUID(),
- newnick, when, u->timestamp);
- }
+ /*
+ * Received: SVINFO 6 6 0 :1353235537
+ * arg[0] = current TS version
+ * arg[1] = minimum required TS version
+ * arg[2] = '0'
+ * arg[3] = server's idea of UTC time
+ */
+ Uplink::Send("SVINFO", 6, 6, Anope::CurTime);
+}
- void SendSVSHold(const Anope::string &nick, time_t delay) override
- {
- Uplink::Send(Me, "ENCAP", "*", "NICKDELAY", delay, nick);
- }
+void charybdis::Proto::SendClientIntroduction(User *u)
+{
+ Anope::string modes = "+" + u->GetModes();
+ Uplink::Send(Me, "EUID", u->nick, 1, u->timestamp, modes, u->GetIdent(), u->host, 0, u->GetUID(), "*", "*", u->realname);
+}
- void SendSVSHoldDel(const Anope::string &nick) override
- {
- Uplink::Send(Me, "ENCAP", "*", "NICKDELAY", 0, nick);
- }
+void charybdis::Proto::SendForceNickChange(User *u, const Anope::string &newnick, time_t when)
+{
+ Uplink::Send(Me, "ENCAP", u->server->GetName(), "RSFNC", u->GetUID(),
+ newnick, when, u->timestamp);
+}
- void SendVhost(User *u, const Anope::string &ident, const Anope::string &host) override
- {
- Uplink::Send(Me, "ENCAP", "*", "CHGHOST", u->GetUID(), host);
- }
+void charybdis::Proto::SendSVSHold(const Anope::string &nick, time_t delay)
+{
+ Uplink::Send(Me, "ENCAP", "*", "NICKDELAY", delay, nick);
+}
- void SendVhostDel(User *u) override
- {
- this->SendVhost(u, "", u->host);
- }
+void charybdis::Proto::SendSVSHoldDel(const Anope::string &nick)
+{
+ Uplink::Send(Me, "ENCAP", "*", "NICKDELAY", 0, nick);
+}
- void SendSASLMechanisms(std::vector<Anope::string> &mechanisms) override
- {
- Anope::string mechlist;
+void charybdis::Proto::SendVhost(User *u, const Anope::string &ident, const Anope::string &host)
+{
+ Uplink::Send(Me, "ENCAP", "*", "CHGHOST", u->GetUID(), host);
+}
- for (unsigned i = 0; i < mechanisms.size(); ++i)
- {
- mechlist += "," + mechanisms[i];
- }
+void charybdis::Proto::SendVhostDel(User *u)
+{
+ this->SendVhost(u, "", u->host);
+}
- Uplink::Send(Me, "ENCAP", "*", "MECHLIST", mechlist.empty() ? "" : mechlist.substr(1));
- }
+void charybdis::Proto::SendSASLMechanisms(std::vector<Anope::string> &mechanisms)
+{
+ Anope::string mechlist;
- void SendSASLMessage(const SASL::Message &message) override
+ for (unsigned i = 0; i < mechanisms.size(); ++i)
{
- Server *s = Server::Find(message.target.substr(0, 3));
- Uplink::Send(Me, "ENCAP", s ? s->GetName() : message.target.substr(0, 3), "SASL", message.source, message.target, message.type, message.data, message.ext.empty() ? "" : message.ext);
+ mechlist += "," + mechanisms[i];
}
- void SendSVSLogin(const Anope::string &uid, const Anope::string &acc, const Anope::string &vident, const Anope::string &vhost) override
- {
- Server *s = Server::Find(uid.substr(0, 3));
- Uplink::Send(Me, "ENCAP", s ? s->GetName() : uid.substr(0, 3), "SVSLOGIN", uid, "*", vident.empty() ? "*" : vident, vhost.empty() ? "*" : vhost, acc);
- }
-};
+ Uplink::Send(Me, "ENCAP", "*", "MECHLIST", mechlist.empty() ? "" : mechlist.substr(1));
+}
+
+void charybdis::Proto::SendSASLMessage(const SASL::Message &message)
+{
+ Server *s = Server::Find(message.target.substr(0, 3));
+ Uplink::Send(Me, "ENCAP", s ? s->GetName() : message.target.substr(0, 3), "SASL", message.source, message.target, message.type, message.data, message.ext.empty() ? "" : message.ext);
+}
+
+void charybdis::Proto::SendSVSLogin(const Anope::string &uid, const Anope::string &acc, const Anope::string &vident, const Anope::string &vhost)
+{
+ Server *s = Server::Find(uid.substr(0, 3));
+ Uplink::Send(Me, "ENCAP", s ? s->GetName() : uid.substr(0, 3), "SVSLOGIN", uid, "*", vident.empty() ? "*" : vident, vhost.empty() ? "*" : vhost, acc);
+}
void charybdis::Encap::Run(MessageSource &source, const std::vector<Anope::string> &params)
@@ -268,7 +244,7 @@ class ProtoCharybdis : public Module
{
ServiceReference<ModeLocks> mlocks;
- CharybdisProto ircd_proto;
+ charybdis::Proto ircd_proto;
/* Core message handlers */
rfc1459::Away message_away;