X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_botmode.cpp;h=18a594c31bcf94b50c8a6ec495dc838c468abe09;hb=192ae99685903cfb71bbf70edc450c4a6314621e;hp=9ed7ef2ee2e1ade96fed0b2f95cab0dfd883c8d2;hpb=67878d628c15f2adec41b6d3b266830a636c2ed0;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_botmode.cpp b/src/modules/m_botmode.cpp index 9ed7ef2ee..18a594c31 100644 --- a/src/modules/m_botmode.cpp +++ b/src/modules/m_botmode.cpp @@ -11,12 +11,6 @@ * --------------------------------------------------- */ -#include -#include -#include "users.h" -#include "channels.h" -#include "modules.h" -#include "configreader.h" #include "inspircd.h" /* $ModDesc: Provides support for unreal-style umode +B */ @@ -28,12 +22,8 @@ class BotMode : public ModeHandler public: BotMode(InspIRCd* Instance) : ModeHandler(Instance, 'B', 0, 0, false, MODETYPE_USER, false) { } - ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) + ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding) { - /* Only opers can change other users modes */ - if ((source != dest) && (!*source->oper)) - return MODEACTION_DENY; - if (adding) { if (!dest->IsModeSet('B')) @@ -61,11 +51,11 @@ class ModuleBotMode : public Module BotMode* bm; public: ModuleBotMode(InspIRCd* Me) - : Module::Module(Me) + : Module(Me) { bm = new BotMode(ServerInstance); - if (!ServerInstance->AddMode(bm, 'B')) + if (!ServerInstance->AddMode(bm)) throw ModuleException("Could not add new modes!"); } @@ -85,38 +75,15 @@ class ModuleBotMode : public Module return Version(1,1,0,0,VF_COMMON|VF_VENDOR,API_VERSION); } - virtual void OnWhois(userrec* src, userrec* dst) + virtual void OnWhois(User* src, User* dst) { if (dst->IsModeSet('B')) { - ServerInstance->SendWhoisLine(src, dst, 335, std::string(src->nick)+" "+std::string(dst->nick)+" :is a \2bot\2 on "+ServerInstance->Config->Network); + ServerInstance->SendWhoisLine(src, dst, 335, std::string(src->nick)+" "+std::string(dst->nick)+" :is a bot on "+ServerInstance->Config->Network); } } }; -// stuff down here is the module-factory stuff. For basic modules you can ignore this. - -class ModuleBotModeFactory : public ModuleFactory -{ - public: - ModuleBotModeFactory() - { - } - - ~ModuleBotModeFactory() - { - } - - virtual Module * CreateModule(InspIRCd* Me) - { - return new ModuleBotMode(Me); - } - -}; - -extern "C" void * init_module( void ) -{ - return new ModuleBotModeFactory; -} +MODULE_INIT(ModuleBotMode)