X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_noctcp.cpp;h=c73f8308e08005e1fbb25010d065f942a4263ae7;hb=e59cb85871f75b7603c63c6cd274d57536cf6794;hp=9dd9bf852d25e1dd3da1e4ed88079ad2f1aba315;hpb=81027f3a0888ac4c8e3fb6ea90081492defce946;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_noctcp.cpp b/src/modules/m_noctcp.cpp index 9dd9bf852..c73f8308e 100644 --- a/src/modules/m_noctcp.cpp +++ b/src/modules/m_noctcp.cpp @@ -22,45 +22,70 @@ #include "inspircd.h" #include "modules/exemption.h" -class NoCTCP : public SimpleChannelModeHandler +class NoCTCPUser : public SimpleUserModeHandler { - public: - NoCTCP(Module* Creator) : SimpleChannelModeHandler(Creator, "noctcp", 'C') { } +public: + NoCTCPUser(Module* Creator) + : SimpleUserModeHandler(Creator, "u_noctcp", 'T') + { + if (!ServerInstance->Config->ConfValue("noctcp")->getBool("enableumode")) + DisableAutoRegister(); + } }; class ModuleNoCTCP : public Module { CheckExemption::EventProvider exemptionprov; - NoCTCP nc; + SimpleChannelModeHandler nc; + NoCTCPUser ncu; public: ModuleNoCTCP() : exemptionprov(this) - , nc(this) + , nc(this, "noctcp", 'C') + , ncu(this) { } Version GetVersion() CXX11_OVERRIDE { - return Version("Provides channel mode +C to block CTCPs", VF_VENDOR); + return Version("Provides user mode +T and channel mode +C to block CTCPs", VF_VENDOR); } - ModResult OnUserPreMessage(User* user, void* dest, int target_type, std::string& text, char status, CUList& exempt_list, MessageType msgtype) CXX11_OVERRIDE + ModResult OnUserPreMessage(User* user, const MessageTarget& target, MessageDetails& details) CXX11_OVERRIDE { - if ((target_type == TYPE_CHANNEL) && (IS_LOCAL(user))) + if (!IS_LOCAL(user)) + return MOD_RES_PASSTHRU; + + std::string ctcpname; + if (!details.IsCTCP(ctcpname) || irc::equals(ctcpname, "ACTION")) + return MOD_RES_PASSTHRU; + + if (target.type == MessageTarget::TYPE_CHANNEL) { - Channel* c = (Channel*)dest; - if ((text.empty()) || (text[0] != '\001') || (!strncmp(text.c_str(),"\1ACTION ",8))) + if (user->HasPrivPermission("channels/ignore-noctcp")) return MOD_RES_PASSTHRU; - ModResult res; - FIRST_MOD_RESULT_CUSTOM(exemptionprov, CheckExemption::EventListener, OnCheckExemption, res, (user, c, "noctcp")); + Channel* c = target.Get(); + ModResult res = CheckExemption::Call(exemptionprov, user, c, "noctcp"); if (res == MOD_RES_ALLOW) return MOD_RES_PASSTHRU; if (!c->GetExtBanStatus(user, 'C').check(!c->IsModeSet(nc))) { - user->WriteNumeric(ERR_NOCTCPALLOWED, c->name, "Can't send CTCP to channel (+C set)"); + user->WriteNumeric(ERR_CANNOTSENDTOCHAN, c->name, "Can't send CTCP to channel (+C is set)"); + return MOD_RES_DENY; + } + } + else if (target.type == MessageTarget::TYPE_USER) + { + if (user->HasPrivPermission("users/ignore-noctcp")) + return MOD_RES_PASSTHRU; + + User* u = target.Get(); + if (u->IsModeSet(ncu)) + { + user->WriteNumeric(ERR_CANTSENDTOUSER, u->nick, "Can't send CTCP to user (+T is set)"); return MOD_RES_DENY; } }