summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorspecial <special@e03df62e-2008-0410-955e-edbf42e46eb7>2007-08-15 01:39:12 +0000
committerspecial <special@e03df62e-2008-0410-955e-edbf42e46eb7>2007-08-15 01:39:12 +0000
commit6bdb96eef6c1a245d6549933964083a743e48dc7 (patch)
tree00457ca83883579428782d127270dd4129baaa1a
parente9d1efc1ae29ee86b3c2a42bf56531afac7add6d (diff)
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
-rw-r--r--src/modules/m_messageflood.cpp27
1 files changed, 16 insertions, 11 deletions
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()