X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_botmode.cpp;h=44241e82c5e83151391bb48a33cba37865f50a77;hb=9982ec4e5b027ed24b1fda5e6fd3ab35b98de1a7;hp=67f692b8623077a4fd40b77a42f163f5346bcc86;hpb=3a3ff949670c61a4a8856e1391222e156eb1cd17;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_botmode.cpp b/src/modules/m_botmode.cpp index 67f692b86..44241e82c 100644 --- a/src/modules/m_botmode.cpp +++ b/src/modules/m_botmode.cpp @@ -20,21 +20,53 @@ #include "inspircd.h" +#include "modules/cap.h" +#include "modules/whois.h" -/** Handles user mode +B - */ -class BotMode : public SimpleUserModeHandler +enum +{ + // From UnrealIRCd. + RPL_WHOISBOT = 335 +}; + +class BotTag : public ClientProtocol::MessageTagProvider { + private: + SimpleUserModeHandler& botmode; + Cap::Reference ctctagcap; + public: - BotMode(Module* Creator) : SimpleUserModeHandler(Creator, "bot", 'B') { } + BotTag(Module* mod, SimpleUserModeHandler& bm) + : ClientProtocol::MessageTagProvider(mod) + , botmode(bm) + , ctctagcap(mod, "message-tags") + { + } + + void OnPopulateTags(ClientProtocol::Message& msg) CXX11_OVERRIDE + { + User* const user = msg.GetSourceUser(); + if (user && user->IsModeSet(botmode)) + msg.AddTag("inspircd.org/bot", this, ""); + } + + bool ShouldSendTag(LocalUser* user, const ClientProtocol::MessageTagData& tagdata) CXX11_OVERRIDE + { + return ctctagcap.get(user); + } }; -class ModuleBotMode : public Module +class ModuleBotMode : public Module, public Whois::EventListener { - BotMode bm; + private: + SimpleUserModeHandler bm; + BotTag tag; + public: ModuleBotMode() - : bm(this) + : Whois::EventListener(this) + , bm(this, "bot", 'B') + , tag(this, bm) { } @@ -43,11 +75,11 @@ class ModuleBotMode : public Module return Version("Provides user mode +B to mark the user as a bot",VF_VENDOR); } - void OnWhois(User* src, User* dst) CXX11_OVERRIDE + void OnWhois(Whois::Context& whois) CXX11_OVERRIDE { - if (dst->IsModeSet(bm)) + if (whois.GetTarget()->IsModeSet(bm)) { - ServerInstance->SendWhoisLine(src, dst, 335, dst->nick+" :is a bot on "+ServerInstance->Config->Network); + whois.SendLine(RPL_WHOISBOT, "is a bot on " + ServerInstance->Config->Network); } } };