From 6bdb96eef6c1a245d6549933964083a743e48dc7 Mon Sep 17 00:00:00 2001 From: special Date: Wed, 15 Aug 2007 01:39:12 +0000 Subject: Changed m_messageflood to use PreMessage and PreNotice, because it may kick the user git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@7719 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_messageflood.cpp | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) (limited to 'src/modules') diff --git a/src/modules/m_messageflood.cpp b/src/modules/m_messageflood.cpp index 2d0cd43fd..1a89ea428 100644 --- a/src/modules/m_messageflood.cpp +++ b/src/modules/m_messageflood.cpp @@ -216,11 +216,11 @@ class ModuleMsgFlood : public Module throw ModuleException("Could not add new modes!"); } - void ProcessMessages(userrec* user,chanrec* dest, const std::string &text) + int ProcessMessages(userrec* user,chanrec* dest, const std::string &text) { if (!IS_LOCAL(user) || CHANOPS_EXEMPT(ServerInstance, 'f') && dest->GetStatus(user) == STATUS_OP) { - return; + return 0; } floodsettings *f; @@ -254,25 +254,30 @@ class ModuleMsgFlood : public Module char kickmessage[MAXBUF]; snprintf(kickmessage, MAXBUF, "Channel flood triggered (limit is %d lines in %d secs)", f->lines, f->secs); if (!dest->ServerKickUser(user, kickmessage, true)) + { delete dest; + return 1; + } } } + + return 0; } - virtual void OnUserMessage(userrec* user, void* dest, int target_type, const std::string &text, char status, const CUList &exempt_list) + virtual int OnUserPreMessage(userrec *user, void *dest, int target_type, std::string &text, char status, CUList &exempt_list) { if (target_type == TYPE_CHANNEL) - { - ProcessMessages(user,(chanrec*)dest,text); - } + return ProcessMessages(user,(chanrec*)dest,text); + + return 0; } - virtual void OnUserNotice(userrec* user, void* dest, int target_type, const std::string &text, char status, const CUList &exempt_list) + virtual int OnUserPreNotice(userrec *user, void *dest, int target_type, std::string &text, char status, CUList &exempt_list) { if (target_type == TYPE_CHANNEL) - { - ProcessMessages(user,(chanrec*)dest,text); - } + return ProcessMessages(user,(chanrec*)dest,text); + + return 0; } void OnChannelDelete(chanrec* chan) @@ -287,7 +292,7 @@ class ModuleMsgFlood : public Module void Implements(char* List) { - List[I_OnChannelDelete] = List[I_OnUserNotice] = List[I_OnUserMessage] = 1; + List[I_OnChannelDelete] = List[I_OnUserPreNotice] = List[I_OnUserPreMessage] = 1; } virtual ~ModuleMsgFlood() -- cgit v1.2.3