From dbcdd42b5b41c8a6c3dbe8081a39eb50008c69e4 Mon Sep 17 00:00:00 2001 From: brain Date: Tue, 18 Mar 2008 20:31:23 +0000 Subject: Implement CAP LIST git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9122 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_cap.cpp | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) (limited to 'src') diff --git a/src/modules/m_cap.cpp b/src/modules/m_cap.cpp index 564ed594b..8a57de0c7 100644 --- a/src/modules/m_cap.cpp +++ b/src/modules/m_cap.cpp @@ -14,14 +14,21 @@ #include "inspircd.h" #include "m_cap.h" -/* $ModDesc: Provides a pointless /dalinfo command, demo module */ +/* $ModDesc: Provides the CAP negotiation mechanism seen in ratbox-derived ircds */ /* - * std::string type; - * std::vector parameters; - * User* user; - * Module* creator; - */ +CAP LS +:alfred.staticbox.net CAP * LS :multi-prefix sasl +CAP REQ :multi-prefix +:alfred.staticbox.net CAP * ACK :multi-prefix +CAP CLEAR +:alfred.staticbox.net CAP * ACK :-multi-prefix +CAP REQ :multi-prefix +:alfred.staticbox.net CAP * ACK :multi-prefix +CAP LIST +:alfred.staticbox.net CAP * LIST :multi-prefix +CAP END +*/ /** Handle /CAP */ @@ -54,16 +61,16 @@ class CommandCAP : public Command { user->Shrink("CAP_REGHOLD"); } - else if (subcommand == "LS") + else if ((subcommand == "LS") || (subcommand == "LIST")) { CapData Data; user->Extend("CAP_REGHOLD"); - Data.type = "LS"; + Data.type = subcommand; Data.user = user; Data.creator = this->Creator; Data.parameter.clear(); - Event event((char*) &Data, (Module*)this->Creator, "cap_ls"); + Event event((char*) &Data, (Module*)this->Creator, subcommand == "LS" ? "cap_ls" : "cap_list"); event.Send(this->ServerInstance); user->WriteServ("CAP * LS :%s", Data.parameter.c_str()); -- cgit v1.2.3