summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-03-02 17:19:49 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-03-02 17:19:49 +0000
commit4927edc5fb5be69ff745044f087b8e3f1fc539d8 (patch)
treed22f78ba1518065156fd24d14328b407667331f2 /src
parentd1212c607146f410b89b5a0788d38cbafc9d1f77 (diff)
*UNTESTED* speeding up HasPermission by factor of hundreds, avoid using EnumConf and ConfValue outside of rehash *AT ALL*
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@3430 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src')
-rw-r--r--src/inspircd_io.cpp1
-rw-r--r--src/users.cpp74
2 files changed, 54 insertions, 21 deletions
diff --git a/src/inspircd_io.cpp b/src/inspircd_io.cpp
index 5488b025f..9195399a4 100644
--- a/src/inspircd_io.cpp
+++ b/src/inspircd_io.cpp
@@ -417,6 +417,7 @@ void ServerConfig::Read(bool bail, userrec* user)
Config->ulines.push_back(ServName);
}
}
+ ReadClassesAndTypes();
log(DEFAULT,"Reading K lines,Q lines and Z lines from config...");
read_xline_defaults();
log(DEFAULT,"Applying K lines, Q lines and Z lines...");
diff --git a/src/users.cpp b/src/users.cpp
index 50589dd6e..2d53ea374 100644
--- a/src/users.cpp
+++ b/src/users.cpp
@@ -54,6 +54,43 @@ extern std::vector<userrec*> local_users;
std::vector<userrec*> all_opers;
+typedef std::map<irc::string,char*> opertype_t;
+typedef opertype_t operclass_t;
+
+opertype_t opertypes;
+operclass_t operclass;
+
+void ReadClassesAndTypes()
+{
+ char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
+ for (opertype_t::iterator n = opertypes.begin(); n != opertypes.end(); n++)
+ {
+ if (n->second)
+ delete[] n->second;
+ }
+ for (operclass_t::iterator n = operclass.begin(); n != operclass.end(); n++)
+ {
+ if (n->second)
+ delete[] n->second;
+ }
+ opertypes.clear();
+ operclass.clear();
+ for (int j =0; j < Config->ConfValueEnum("type",&Config->config_f); j++)
+ {
+ Config->ConfValue("type","name",j,TypeName,&Config->config_f);
+ Config->ConfValue("type","classes",j,Classes,&Config->config_f);
+ opertypes[TypeName] = sstrdup(Classes);
+ log(DEBUG,"Read oper TYPE '%s' with classes '%s'",TypeName,Classes);
+ }
+ for (int k =0; k < Config->ConfValueEnum("class",&Config->config_f); k++)
+ {
+ Config->ConfValue("class","name",k,ClassName,&Config->config_f);
+ Config->ConfValue("class","commands",k,CommandList,&Config->config_f);
+ operclass[ClassName] = sstrdup(CommandList);
+ log(DEBUG,"Read oper CLASS '%s' with commands '%s'",ClassName,CommandList);
+ }
+}
+
template<typename T> inline string ConvToStr(const T &in)
{
stringstream tmp;
@@ -196,10 +233,11 @@ void userrec::RemoveInvite(irc::string &channel)
bool userrec::HasPermission(std::string &command)
{
- char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
+ char* CommandList;
char* mycmd;
char* savept;
char* savept2;
+ char* Classes;
// users on remote servers can completely bypass
// all permissions based checks.
@@ -211,34 +249,28 @@ bool userrec::HasPermission(std::string &command)
// are they even an oper at all?
if (*this->oper)
{
- for (int j =0; j < Config->ConfValueEnum("type",&Config->config_f); j++)
+ opertype_t::iterator iter_opertype = opertypes.find(this->oper);
+ if (iter_opertype != opertypes.end())
{
- Config->ConfValue("type","name",j,TypeName,&Config->config_f);
- if (!strcmp(TypeName,this->oper))
+ Classes = iter_opertype->second;
+ char* myclass = strtok_r(Classes," ",&savept);
+ while (myclass)
{
- Config->ConfValue("type","classes",j,Classes,&Config->config_f);
- char* myclass = strtok_r(Classes," ",&savept);
- while (myclass)
+ operclass_t::iterator iter_operclass = operclass.find(myclass);
+ if (iter_operclass != operclass.end())
{
- for (int k =0; k < Config->ConfValueEnum("class",&Config->config_f); k++)
+ char* CommandList = iter_operclass->second;
+ mycmd = strtok_r(CommandList," ",&savept2);
+ while (mycmd)
{
- Config->ConfValue("class","name",k,ClassName,&Config->config_f);
- if (!strcmp(ClassName,myclass))
+ if ((!strcasecmp(mycmd,command.c_str())) || (*mycmd == '*'))
{
- Config->ConfValue("class","commands",k,CommandList,&Config->config_f);
- mycmd = strtok_r(CommandList," ",&savept2);
- while (mycmd)
- {
- if ((!strcasecmp(mycmd,command.c_str())) || (*mycmd == '*'))
- {
- return true;
- }
- mycmd = strtok_r(NULL," ",&savept2);
- }
+ return true;
}
+ mycmd = strtok_r(NULL," ",&savept2);
}
- myclass = strtok_r(NULL," ",&savept);
}
+ myclass = strtok_r(NULL," ",&savept);
}
}
}