X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_securelist.cpp;h=d98870425e49f8f593af1b206723c2e96ba628f3;hb=02c6ce1ad09a7471a6b03dc00bac4b843d157489;hp=b9d7363a5f4dbe561765774e85130485e7890f4e;hpb=3a554ef1e9be9dbcf3de3301a4a6c2938d643bea;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_securelist.cpp b/src/modules/m_securelist.cpp index b9d7363a5..d98870425 100644 --- a/src/modules/m_securelist.cpp +++ b/src/modules/m_securelist.cpp @@ -10,24 +10,23 @@ * * --------------------------------------------------- */ - + +#include "inspircd.h" #include "users.h" #include "channels.h" #include "modules.h" -#include -#include "inspircd.h" - /* $ModDesc: A module overriding /list, and making it safe - stop those sendq problems. */ class ModuleSecureList : public Module { private: - + std::vector allowlist; + time_t WaitTime; public: - ModuleSecureList(InspIRCd* Me) : Module::Module(Me) + ModuleSecureList(InspIRCd* Me) : Module(Me) { - + OnRehash(NULL,""); } virtual ~ModuleSecureList() @@ -38,10 +37,20 @@ class ModuleSecureList : public Module { return Version(1,1,0,0,VF_VENDOR,API_VERSION); } + + void OnRehash(userrec* user, const std::string ¶meter) + { + ConfigReader* MyConf = new ConfigReader(ServerInstance); + allowlist.clear(); + for (int i = 0; i < MyConf->Enumerate("securehost"); i++) + allowlist.push_back(MyConf->ReadValue("securehost", "exception", i)); + WaitTime = MyConf->ReadInteger("securelist", "waittime", "60", 0, true); + DELETE(MyConf); + } void Implements(char* List) { - List[I_OnPreCommand] = List[I_On005Numeric] = 1; + List[I_OnRehash] = List[I_OnPreCommand] = List[I_On005Numeric] = 1; } /* @@ -54,9 +63,15 @@ class ModuleSecureList : public Module if (!validated) return 0; - if ((command == "LIST") && (ServerInstance->Time() < (user->signon+60)) && (!*user->oper)) + if ((command == "LIST") && (ServerInstance->Time() < (user->signon+WaitTime)) && (!IS_OPER(user))) { - user->WriteServ("NOTICE %s :*** You cannot list within the first minute of connecting. Please try again later.",user->nick); + /* Normally wouldnt be allowed here, are they exempt? */ + for (std::vector::iterator x = allowlist.begin(); x != allowlist.end(); x++) + if (ServerInstance->MatchText(user->MakeHost(), *x)) + return 0; + + /* Not exempt, BOOK EM DANNO! */ + user->WriteServ("NOTICE %s :*** You cannot list within the first %d seconds of connecting. Please try again later.",user->nick, WaitTime); /* Some crap clients (read: mIRC, various java chat applets) muck up if they don't * receive these numerics whenever they send LIST, so give them an empty LIST to mull over. */ @@ -101,7 +116,7 @@ class ModuleSecureListFactory : public ModuleFactory }; -extern "C" void * init_module( void ) +extern "C" DllExport void * init_module( void ) { return new ModuleSecureListFactory; }