summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-03-04 17:29:05 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-03-04 17:29:05 +0000
commitd1fad914b1d42bb82a64fad01066990a4dbe2e85 (patch)
treec30a50538615f023048fce91b73103ef76053a6c
parent63f5e1e2056cab6b5a076569cb725670c3696e00 (diff)
Tidyup of m_filter
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@3446 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--src/modules.cpp2
-rw-r--r--src/modules/m_filter.cpp65
-rwxr-xr-xsrc/svn-rev.sh2
3 files changed, 43 insertions, 26 deletions
diff --git a/src/modules.cpp b/src/modules.cpp
index 64a61c1b0..e5a0145c0 100644
--- a/src/modules.cpp
+++ b/src/modules.cpp
@@ -859,6 +859,7 @@ ConfigReader::ConfigReader()
this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
this->readerror = Config->LoadConf(CONFIG_FILE,this->cache,this->errorlog);
+ tags.clear();
if (!this->readerror)
this->error = CONF_FILE_NOT_FOUND;
}
@@ -879,6 +880,7 @@ ConfigReader::ConfigReader(std::string filename)
this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
this->readerror = Config->LoadConf(filename.c_str(),this->cache,this->errorlog);
+ tags.clear();
if (!this->readerror)
this->error = CONF_FILE_NOT_FOUND;
};
diff --git a/src/modules/m_filter.cpp b/src/modules/m_filter.cpp
index c8d5633ff..f1254e3fb 100644
--- a/src/modules/m_filter.cpp
+++ b/src/modules/m_filter.cpp
@@ -29,6 +29,14 @@ using namespace std;
/* $ModDesc: An enhanced version of the unreal m_filter.so used by chatspike.net */
+class Filter
+{
+ std::string reason;
+ std::string action;
+};
+
+typedef std::map<std::string,Filter*> filter_t;
+
class FilterException : public ModuleException
{
public:
@@ -42,6 +50,7 @@ class ModuleFilter : public Module
{
Server *Srv;
ConfigReader *Conf, *MyConf;
+ filter_t* filters;
public:
ModuleFilter(Server* Me)
@@ -53,14 +62,7 @@ class ModuleFilter : public Module
// of the main config... but rather messy. That's why the capability
// of using a seperate config file is provided.
Srv = Me;
- Conf = new ConfigReader;
- std::string filterfile = Conf->ReadValue("filter","file",0);
- MyConf = new ConfigReader(filterfile);
- if ((filterfile == "") || (!MyConf->Verify()))
- {
- FilterException e;
- throw(e);
- }
+ OnRehash("");
Srv->Log(DEFAULT,std::string("m_filter: read configuration from ")+filterfile);
}
@@ -85,18 +87,13 @@ class ModuleFilter : public Module
virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text, char status)
{
std::string text2 = text+" ";
- for (int index = 0; index < MyConf->Enumerate("keyword"); index++)
+ for (filter_t::iterator index = filters.begin(); index != filters.end(); index++)
{
- std::string pattern = MyConf->ReadValue("keyword","pattern",index);
- if ((Srv->MatchText(text2,pattern)) || (Srv->MatchText(text,pattern)))
+ if ((Srv->MatchText(text2,index->first)) || (Srv->MatchText(text,index->first)))
{
+ Filter* f = (Filter*)*x->second;
std::string target = "";
- std::string reason = MyConf->ReadValue("keyword","reason",index);
- std::string do_action = MyConf->ReadValue("keyword","action",index);
- if (do_action == "")
- do_action = "none";
-
if (target_type == TYPE_USER)
{
userrec* t = (userrec*)dest;
@@ -107,21 +104,22 @@ class ModuleFilter : public Module
chanrec* t = (chanrec*)dest;
target = std::string(t->name);
}
- if (do_action == "block")
+
+ if (f->action == "block")
{
Srv->SendOpers(std::string("FILTER: ")+std::string(user->nick)+
std::string(" had their notice filtered, target was ")+
- target+": "+reason);
+ target+": "+f->reason);
Srv->SendTo(NULL,user,"NOTICE "+std::string(user->nick)+
- " :Your notice has been filtered and opers notified: "+reason);
+ " :Your notice has been filtered and opers notified: "+f->reason);
}
Srv->Log(DEFAULT,std::string("FILTER: ")+std::string(user->nick)+
std::string(" had their notice filtered, target was ")+
- target+": "+reason+" Action: "+do_action);
+ target+": "+f->reason+" Action: "+f->action);
- if (do_action == "kill")
+ if (f->action == "kill")
{
- Srv->QuitUser(user,reason);
+ Srv->QuitUser(user,f->reason);
}
return 1;
}
@@ -133,8 +131,6 @@ class ModuleFilter : public Module
{
// reload our config file on rehash - we must destroy and re-allocate the classes
// to call the constructor again and re-read our data.
- delete Conf;
- delete MyConf;
Conf = new ConfigReader;
std::string filterfile = Conf->ReadValue("filter","file",0);
// this automatically re-reads the configuration file into the class
@@ -145,13 +141,32 @@ class ModuleFilter : public Module
FilterException e;
throw(e);
}
+ for (filter_t::iterator n = filters.begin(); n != filters.end(); n++)
+ {
+ delete n->second;
+ }
+ filters.clear();
+ for (int index = 0; index < MyConf->Enumerate("keyword"); index++)
+ {
+ std::string pattern = MyConf->ReadValue("keyword","pattern",index);
+ std::string reason = MyConf->ReadValue("keyword","reason",index);
+ std::string do_action = MyConf->ReadValue("keyword","action",index);
+ if (do_action == "")
+ do_action = "none";
+ Filter* x = new Filter;
+ x->reason = reason;
+ x->action = do_action;
+ filters[pattern] = x;
+ }
Srv->Log(DEFAULT,std::string("m_filter: read configuration from ")+filterfile);
+ delete Conf;
+ delete MyConf;
}
virtual Version GetVersion()
{
// This is version 2 because version 1.x is the unreleased unrealircd module
- return Version(2,0,0,1,VF_VENDOR);
+ return Version(2,0,0,2,VF_VENDOR);
}
};
diff --git a/src/svn-rev.sh b/src/svn-rev.sh
index 6e8fa9622..38d106f2d 100755
--- a/src/svn-rev.sh
+++ b/src/svn-rev.sh
@@ -1 +1 @@
-echo 3443
+echo 3445