* ---------------------------------------------------
*/
-#include "users.h"
-#include "modules.h"
-
#include "inspircd.h"
/* $ModDesc: Connection throttle */
public:
- ModuleConnFlood(InspIRCd* Me) : Module::Module(Me)
+ ModuleConnFlood(InspIRCd* Me) : Module(Me)
{
InitConf();
first = ServerInstance->Time();
}
- virtual int OnUserRegister(userrec* user)
+ virtual int OnUserRegister(User* user)
{
time_t next = ServerInstance->Time();
- if (!first)
- first = next - boot_wait;
-
+
+ if ((ServerInstance->startup_time + boot_wait) > next)
+ return 0;
+
/* time difference between first and latest connection */
time_t tdiff = next - first;
ServerInstance->WriteOpers("*** Connection throttle deactivated");
return 0;
}
- userrec::QuitUser(ServerInstance, user, quitmsg);
+ User::QuitUser(ServerInstance, user, quitmsg);
return 1;
}
{
throttled = 1;
ServerInstance->WriteOpers("*** Connection throttle activated");
- userrec::QuitUser(ServerInstance, user, quitmsg);
+ User::QuitUser(ServerInstance, user, quitmsg);
return 1;
}
}
return 0;
}
- virtual void OnRehash(userrec* user, const std::string ¶meter)
+ virtual void OnRehash(User* user, const std::string ¶meter)
{
InitConf();
}
};
-
-class ModuleConnFloodFactory : public ModuleFactory
-{
-public:
- ModuleConnFloodFactory()
- {
- }
-
- ~ModuleConnFloodFactory()
- {
- }
-
- virtual Module * CreateModule(InspIRCd* Me)
- {
- return new ModuleConnFlood(Me);
- }
-};
-
-
-extern "C" void * init_module( void )
-{
- return new ModuleConnFloodFactory;
-}
+MODULE_INIT(ModuleConnFlood)