* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
- * InspIRCd: (C) 2002-2007 InspIRCd Development Team
- * See: http://www.inspircd.org/wiki/index.php/Credits
+ * InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ * See: http://wiki.inspircd.org/Credits
*
* This program is free but copyrighted software; see
* the file COPYING for details.
*/
#include "inspircd.h"
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
-#include "wildcard.h"
/* $ModDesc: Sets (and unsets) modes on users when they connect */
ConfigReader *Conf;
public:
- ModuleModesOnConnect(InspIRCd* Me)
- : Module(Me)
- {
-
- Conf = new ConfigReader(ServerInstance);
- }
+ ModuleModesOnConnect() {
- void Implements(char* List)
- {
- List[I_OnPostConnect] = List[I_OnRehash] = 1;
+ Conf = new ConfigReader;
+ Implementation eventlist[] = { I_OnUserConnect, I_OnRehash };
+ ServerInstance->Modules->Attach(eventlist, this, 2);
+ // for things like +x on connect, important, otherwise we have to resort to config order (bleh) -- w00t
+ ServerInstance->Modules->SetPriority(this, PRIORITY_FIRST);
}
- virtual void OnRehash(userrec* user, const std::string ¶meter)
+
+ virtual void OnRehash(User* user)
{
- DELETE(Conf);
- Conf = new ConfigReader(ServerInstance);
+ delete Conf;
+ Conf = new ConfigReader;
}
-
+
virtual ~ModuleModesOnConnect()
{
- DELETE(Conf);
+ delete Conf;
}
-
+
virtual Version GetVersion()
{
- return Version(1,1,0,1,VF_VENDOR,API_VERSION);
+ return Version("Sets (and unsets) modes on users when they connect", VF_VENDOR,API_VERSION);
}
-
- virtual void OnPostConnect(userrec* user)
+
+ virtual void OnUserConnect(User* user)
{
if (!IS_LOCAL(user))
return;
+ // Backup and zero out the disabled usermodes, so that we can override them here.
+ char save[64];
+ memcpy(save, ServerInstance->Config->DisabledUModes,
+ sizeof(ServerInstance->Config->DisabledUModes));
+ memset(ServerInstance->Config->DisabledUModes, 0, 64);
+
for (int j = 0; j < Conf->Enumerate("connect"); j++)
{
std::string hostn = Conf->ReadValue("connect","allow",j);
- if ((match(user->GetIPString(),hostn.c_str(),true)) || (match(user->host,hostn.c_str())))
+ /* XXX: Fixme: does not respect port, limit, etc */
+ if ((InspIRCd::MatchCIDR(user->GetIPString(),hostn, ascii_case_insensitive_map)) || (InspIRCd::Match(user->host,hostn, ascii_case_insensitive_map)))
{
std::string ThisModes = Conf->ReadValue("connect","modes",j);
if (!ThisModes.empty())
{
std::string buf;
- stringstream ss(ThisModes);
+ std::stringstream ss(ThisModes);
- vector<string> tokens;
+ std::vector<std::string> tokens;
// split ThisUserModes into modes and mode params
while (ss >> buf)
tokens.push_back(buf);
- int size = tokens.size() + 1;
- const char** modes = new const char*[size];
- modes[0] = user->nick;
- modes[1] = tokens[0].c_str();
+ std::vector<std::string> modes;
+ modes.push_back(user->nick);
+ modes.push_back(tokens[0]);
if (tokens.size() > 1)
{
// process mode params
- int i = 2;
for (unsigned int k = 1; k < tokens.size(); k++)
{
- modes[i] = tokens[k].c_str();
- i++;
+ modes.push_back(tokens[k]);
}
}
- ServerInstance->Parser->CallHandler("MODE", modes, size, user);
- delete [] modes;
+ ServerInstance->Parser->CallHandler("MODE", modes, user);
}
break;
}
}
- }
-};
-
-// stuff down here is the module-factory stuff. For basic modules you can ignore this.
-class ModuleModesOnConnectFactory : public ModuleFactory
-{
- public:
- ModuleModesOnConnectFactory()
- {
- }
-
- ~ModuleModesOnConnectFactory()
- {
+ memcpy(ServerInstance->Config->DisabledUModes, save, 64);
}
-
- virtual Module * CreateModule(InspIRCd* Me)
- {
- return new ModuleModesOnConnect(Me);
- }
-
};
-
-extern "C" DllExport void * init_module( void )
-{
- return new ModuleModesOnConnectFactory;
-}
-
+MODULE_INIT(ModuleModesOnConnect)