summaryrefslogtreecommitdiff
path: root/src/modules/m_restrictchans.cpp
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-01-19 19:10:18 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-01-19 19:10:18 +0000
commit265ff48624afc2a008d1f688ca1f50ea898cfa98 (patch)
tree5b170c4fabc8bc93bc3b9eccc6fccbabbd20be60 /src/modules/m_restrictchans.cpp
parent9a7b1fb30d71936f057c0c0ee0fa5e711042311e (diff)
Added <allowchannel:name> to allow specific channels
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2822 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/m_restrictchans.cpp')
-rw-r--r--src/modules/m_restrictchans.cpp31
1 files changed, 28 insertions, 3 deletions
diff --git a/src/modules/m_restrictchans.cpp b/src/modules/m_restrictchans.cpp
index 54113aead..0ca0dd921 100644
--- a/src/modules/m_restrictchans.cpp
+++ b/src/modules/m_restrictchans.cpp
@@ -17,6 +17,7 @@
using namespace std;
#include <stdio.h>
+#include <map>
#include "users.h"
#include "channels.h"
#include "modules.h"
@@ -28,22 +29,46 @@ Server *Srv;
class ModuleRestrictChans : public Module
{
+
+ std::map<irc::string,int> allowchans;
+
+ void ReadConfig()
+ {
+ ConfigReader* MyConf = new ConfigReader();
+ allowchans.clear();
+ for (int i = 0; i < MyConf->Enumerate("allowchannel"); i++)
+ {
+ std::string txt;
+ txt = MyConf->ReadValue("allowchannel", "name", i);
+ irc::string channel = txt.c_str();
+ allowchans[channel] = 1;
+ }
+ delete MyConf;
+ }
+
public:
ModuleRestrictChans(Server* Me)
: Module::Module(Me)
{
Srv = Me;
+ ReadConfig();
+ }
+
+ virtual void OnRehash(std::string parameter)
+ {
+ ReadConfig();
}
void Implements(char* List)
{
- List[I_OnUserPreJoin] = 1;
+ List[I_OnUserPreJoin] = List[I_OnRehash] = 1;
}
virtual int OnUserPreJoin(userrec* user, chanrec* chan, const char* cname)
{
- // user is not an oper
- if (!strchr(user->modes,'o'))
+ irc::string x = cname;
+ // user is not an oper and its not in the allow list
+ if ((!strchr(user->modes,'o')) && (allowchans.find(x) == allowchans.end()))
{
// channel does not yet exist (record is null, about to be created IF we were to allow it)
if (!chan)