X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=docs%2Fmodule-doc%2Fmodules_8cpp-source.html;h=abeda60ddc382fe2c845a815e6a3206609f7ae87;hb=c160de3e8dfead4a8ef3a41f1ed3ac586bfd190f;hp=c1b6188992e03a8dcc0aa4a91ba1ea36cf9f8bc1;hpb=44b62866f83dea028500d81274eaaba8e886e1c3;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/docs/module-doc/modules_8cpp-source.html b/docs/module-doc/modules_8cpp-source.html index c1b618899..abeda60dd 100644 --- a/docs/module-doc/modules_8cpp-source.html +++ b/docs/module-doc/modules_8cpp-source.html @@ -1,11 +1,11 @@ modules.cpp Source File - +
-Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members  
+Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members  

modules.cpp

Go to the documentation of this file.
00001 /*
 00002 
 00003 
@@ -14,225 +14,430 @@
 00006 
 00007 
 00008 #include <typeinfo>
-00009 #include <iostream.h>
+00009 #include <iostream>
 00010 #include "globals.h"
 00011 #include "modules.h"
-00012 #include "inspircd_io.h"
-00013 
-00014 // version is a simple class for holding a modules version number
+00012 #include "ctables.h"
+00013 #include "inspircd_io.h"
+00014 #include "wildcard.h"
 00015 
-00016 Version::Version(int major, int minor, int revision, int build) : Major(major), Minor(minor), Revision(revision), Build(build) { };
+00016 // class type for holding an extended mode character - internal to core
 00017 
-00018 // admin is a simple class for holding a server's administrative info
-00019 
-00020 Admin::Admin(string name, string email, string nick) : Name(name), Email(email), Nick(nick) { };
-00021 
-00022 //
-00023 // Announce to the world that the Module base
-00024 // class has been created or destroyed
-00025 //
-00026 
-00027 Module::Module() { }
-00028 Module::~Module() { }
-00029 void Module::OnUserConnect(userrec* user) { }
-00030 void Module::OnUserQuit(userrec* user) { }
-00031 void Module::OnUserJoin(userrec* user, chanrec* channel) { }
-00032 void Module::OnUserPart(userrec* user, chanrec* channel) { }
-00033 void Module::OnPacketTransmit(char *p) { }
-00034 void Module::OnPacketReceive(char *p) { }
-00035 void Module::OnRehash() { }
-00036 void Module::OnServerRaw(string &raw, bool inbound) { }
-00037 Version Module::GetVersion() { return Version(1,0,0,0); }
-00038 
-00039 // server is a wrapper class that provides methods to all of the C-style
-00040 // exports in the core
-00041 //
-00042 
-00043 Server::Server()
-00044 {
-00045 }
-00046 
-00047 Server::~Server()
-00048 {
-00049 }
-00050 
-00051 void Server::SendOpers(string s)
-00052 {
-00053         WriteOpers("%s",s.c_str());
-00054 }
-00055 
-00056 void Server::Log(int level, string s)
-00057 {
-00058         log(level,"%s",s.c_str());
-00059 }
-00060 
-00061 void Server::Send(int Socket, string s)
-00062 {
-00063         Write(Socket,"%s",s.c_str());
-00064 }
-00065 
-00066 void Server::SendServ(int Socket, string s)
-00067 {
-00068         WriteServ(Socket,"%s",s.c_str());
-00069 }
-00070 
-00071 void Server::SendFrom(int Socket, userrec* User, string s)
-00072 {
-00073         WriteFrom(Socket,User,"%s",s.c_str());
+00018 class ExtMode
+00019 {
+00020 public:
+00021         char modechar;
+00022         int type;
+00023         int params_when_on;
+00024         int params_when_off;
+00025         bool needsoper;
+00026         ExtMode(char mc, int ty, bool oper, int p_on, int p_off) : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
+00027 };                                     
+00028 
+00029 typedef std::vector<ExtMode> ExtModeList;
+00030 typedef ExtModeList::iterator ExtModeListIter;
+00031 
+00032 ExtModeList EMode;
+00033 
+00034 // returns true if an extended mode character is in use
+00035 bool ModeDefined(char modechar, int type)
+00036 {
+00037         log(DEBUG,"Size of extmodes vector is %d",EMode.size());
+00038         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
+00039         {
+00040                 log(DEBUG,"i->modechar==%c, modechar=%c, i->type=%d, type=%d",i->modechar,modechar,i->type,type);
+00041                 if ((i->modechar == modechar) && (i->type == type))
+00042                 {
+00043                         return true;
+00044                 }
+00045         }
+00046         return false;
+00047 }
+00048 
+00049 bool ModeDefinedOper(char modechar, int type)
+00050 {
+00051         log(DEBUG,"Size of extmodes vector is %d",EMode.size());
+00052         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
+00053         {
+00054                 log(DEBUG,"i->modechar==%c, modechar=%c, i->type=%d, type=%d",i->modechar,modechar,i->type,type);
+00055                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
+00056                 {
+00057                         return true;
+00058                 }
+00059         }
+00060         return false;
+00061 }
+00062 
+00063 // returns number of parameters for a custom mode when it is switched on
+00064 int ModeDefinedOn(char modechar, int type)
+00065 {
+00066         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
+00067         {
+00068                 if ((i->modechar == modechar) && (i->type == type))
+00069                 {
+00070                         return i->params_when_on;
+00071                 }
+00072         }
+00073         return 0;
 00074 }
 00075 
-00076 void Server::SendTo(userrec* Source, userrec* Dest, string s)
-00077 {
-00078         WriteTo(Source,Dest,"%s",s.c_str());
-00079 }
-00080 
-00081 void Server::SendChannel(userrec* User, chanrec* Channel, string s,bool IncludeSender)
-00082 {
-00083         if (IncludeSender)
-00084         {
-00085                 WriteChannel(Channel,User,"%s",s.c_str());
-00086         }
-00087         else
-00088         {
-00089                 ChanExceptSender(Channel,User,"%s",s.c_str());
-00090         }
-00091 }
-00092 
-00093 bool Server::CommonChannels(userrec* u1, userrec* u2)
-00094 {
-00095         return (common_channels(u1,u2) != 0);
-00096 }
-00097 
-00098 void Server::SendCommon(userrec* User, string text,bool IncludeSender)
-00099 {
-00100         if (IncludeSender)
-00101         {
-00102                 WriteCommon(User,"%s",text.c_str());
-00103         }
-00104         else
-00105         {
-00106                 WriteCommonExcept(User,"%s",text.c_str());
-00107         }
-00108 }
-00109 
-00110 void Server::SendWallops(userrec* User, string text)
-00111 {
-00112         WriteWallOps(User,"%s",text.c_str());
-00113 }
-00114 
-00115 bool Server::IsNick(string nick)
-00116 {
-00117         return (isnick(nick.c_str()) != 0);
-00118 }
-00119 
-00120 userrec* Server::FindNick(string nick)
-00121 {
-00122         return Find(nick);
-00123 }
-00124 
-00125 chanrec* Server::FindChannel(string channel)
-00126 {
-00127         return FindChan(channel.c_str());
-00128 }
-00129 
-00130 string Server::ChanMode(userrec* User, chanrec* Chan)
-00131 {
-00132         string mode = cmode(User,Chan);
-00133         return mode;
-00134 }
-00135 
-00136 string Server::GetServerName()
-00137 {
-00138         return getservername();
-00139 }
-00140 
-00141 string Server::GetNetworkName()
-00142 {
-00143         return getnetworkname();
-00144 }
-00145 
-00146 Admin Server::GetAdmin()
-00147 {
-00148         return Admin(getadminname(),getadminemail(),getadminnick());
-00149 }
-00150 
+00076 // returns number of parameters for a custom mode when it is switched on
+00077 int ModeDefinedOff(char modechar, int type)
+00078 {
+00079         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
+00080         {
+00081                 if ((i->modechar == modechar) && (i->type == type))
+00082                 {
+00083                         return i->params_when_off;
+00084                 }
+00085         }
+00086         return 0;
+00087 }
+00088 
+00089 // returns true if an extended mode character is in use
+00090 bool DoAddExtendedMode(char modechar, int type, bool requires_oper, int params_on, int params_off)
+00091 {
+00092         if (ModeDefined(modechar,type)) {
+00093                 return false;
+00094         }
+00095         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
+00096         return true;
+00097 }
+00098 
+00099 
+00100 // version is a simple class for holding a modules version number
+00101 
+00102 Version::Version(int major, int minor, int revision, int build) : Major(major), Minor(minor), Revision(revision), Build(build) { };
+00103 
+00104 // admin is a simple class for holding a server's administrative info
+00105 
+00106 Admin::Admin(std::string name, std::string email, std::string nick) : Name(name), Email(email), Nick(nick) { };
+00107 
+00108 Module::Module() { }
+00109 Module::~Module() { }
+00110 void Module::OnUserConnect(userrec* user) { }
+00111 void Module::OnUserQuit(userrec* user) { }
+00112 void Module::OnUserJoin(userrec* user, chanrec* channel) { }
+00113 void Module::OnUserPart(userrec* user, chanrec* channel) { }
+00114 void Module::OnPacketTransmit(char *p) { }
+00115 void Module::OnPacketReceive(char *p) { }
+00116 void Module::OnRehash() { }
+00117 void Module::OnServerRaw(std::string &raw, bool inbound) { }
+00118 int Module::OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { return 0; }
+00119 bool Module::OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params) { return false; }
+00120 Version Module::GetVersion() { return Version(1,0,0,0); }
+00121 void Module::OnOper(userrec* user) { };
+00122 void Module::OnInfo(userrec* user) { };
+00123 void Module::OnWhois(userrec* source, userrec* dest) { };
+00124 int Module::OnUserPreMessage(userrec* user,void* dest,int target_type, std::string text) { return 0; };
+00125 int Module::OnUserPreNotice(userrec* user,void* dest,int target_type, std::string text) { return 0; };
+00126 
+00127 // server is a wrapper class that provides methods to all of the C-style
+00128 // exports in the core
+00129 //
+00130 
+00131 Server::Server()
+00132 {
+00133 }
+00134 
+00135 Server::~Server()
+00136 {
+00137 }
+00138 
+00139 void Server::SendOpers(std::string s)
+00140 {
+00141         WriteOpers("%s",s.c_str());
+00142 }
+00143 
+00144 bool Server::MatchText(std::string sliteral, std::string spattern)
+00145 {
+00146         char literal[MAXBUF],pattern[MAXBUF];
+00147         strncpy(literal,sliteral.c_str(),MAXBUF);
+00148         strncpy(pattern,spattern.c_str(),MAXBUF);
+00149         return match(literal,pattern);
+00150 }
 00151 
-00152 ConfigReader::ConfigReader()
+00152 void Server::SendToModeMask(std::string modes, int flags, std::string text)
 00153 {
-00154         fname = CONFIG_FILE;
+00154         WriteMode(modes.c_str(),flags,"%s",text.c_str());
 00155 }
 00156 
-00157 
-00158 ConfigReader::~ConfigReader()
-00159 {
+00157 chanrec* Server::JoinUserToChannel(userrec* user, std::string cname, std::string key)
+00158 {
+00159         return add_channel(user,cname.c_str(),key.c_str(),true);
 00160 }
 00161 
-00162 
-00163 ConfigReader::ConfigReader(string filename) : fname(filename) { };
-00164 
-00165 string ConfigReader::ReadValue(string tag, string name, int index)
-00166 {
-00167         char val[MAXBUF];
-00168         ReadConf(fname.c_str(),tag.c_str(),name.c_str(),index,val);
-00169         string s = val;
-00170         return s;
-00171 }
-00172 
-00173 
-00174 int ConfigReader::Enumerate(string tag)
-00175 {
-00176         return EnumConf(fname.c_str(),tag.c_str());
-00177 }
-00178 
-00179 
-00180 bool ConfigReader::Verify()
-00181 {
-00182         return true;
-00183 }
-00184 
-00185 
-00186 FileReader::FileReader(string filename)
-00187 {
-00188         file_cache c;
-00189         readfile(c,filename.c_str());
-00190         this->fc = c;
+00162 chanrec* Server::PartUserFromChannel(userrec* user, std::string cname, std::string reason)
+00163 {
+00164         return del_channel(user,cname.c_str(),reason.c_str(),false);
+00165 }
+00166 
+00167 void Server::ChangeUserNick(userrec* user, std::string nickname)
+00168 {
+00169         force_nickchange(user,nickname.c_str());
+00170 }
+00171 
+00172 void Server::QuitUser(userrec* user, std::string reason)
+00173 {
+00174         send_network_quit(user->nick,reason.c_str());
+00175         kill_link(user,reason.c_str());
+00176 }
+00177 
+00178 void Server::CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user)
+00179 {
+00180         call_handler(commandname.c_str(),parameters,pcnt,user);
+00181 }
+00182 
+00183 void Server::Log(int level, std::string s)
+00184 {
+00185         log(level,"%s",s.c_str());
+00186 }
+00187 
+00188 void Server::AddCommand(char* cmd, handlerfunc f, char flags, int minparams)
+00189 {
+00190         createcommand(cmd,f,flags,minparams);
 00191 }
 00192 
-00193 FileReader::FileReader()
+00193 void Server::SendMode(char **parameters, int pcnt, userrec *user)
 00194 {
-00195 }
-00196 
-00197 void FileReader::LoadFile(string filename)
-00198 {
-00199         file_cache c;
-00200         readfile(c,filename.c_str());
-00201         this->fc = c;
-00202 }
-00203 
-00204 FileReader::~FileReader()
-00205 {
+00195         server_mode(parameters,pcnt,user);
+00196 }
+00197 
+00198 void Server::Send(int Socket, std::string s)
+00199 {
+00200         Write(Socket,"%s",s.c_str());
+00201 }
+00202 
+00203 void Server::SendServ(int Socket, std::string s)
+00204 {
+00205         WriteServ(Socket,"%s",s.c_str());
 00206 }
 00207 
-00208 string FileReader::GetLine(int x)
+00208 void Server::SendFrom(int Socket, userrec* User, std::string s)
 00209 {
-00210         if ((x<0) || (x>fc.size()))
-00211                 return "";
-00212         return fc[x];
-00213 }
-00214 
-00215 int FileReader::FileSize()
-00216 {
-00217         return fc.size();
-00218 }
-00219 
-00220 
-00221 vector<Module*> modules(255);
-00222 vector<ircd_module*> factory(255);
-00223 
-00224 int MODCOUNT  = -1;
-00225 
+00210         WriteFrom(Socket,User,"%s",s.c_str());
+00211 }
+00212 
+00213 void Server::SendTo(userrec* Source, userrec* Dest, std::string s)
+00214 {
+00215         if (!Source)
+00216         {
+00217                 // if source is NULL, then the message originates from the local server
+00218                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
+00219         }
+00220         else
+00221         {
+00222                 // otherwise it comes from the user specified
+00223                 WriteTo(Source,Dest,"%s",s.c_str());
+00224         }
+00225 }
 00226 
-

Generated on Sun Mar 30 13:27:58 2003 for InspIRCd by +00227 void Server::SendChannel(userrec* User, chanrec* Channel, std::string s,bool IncludeSender) +00228 { +00229 if (IncludeSender) +00230 { +00231 WriteChannel(Channel,User,"%s",s.c_str()); +00232 } +00233 else +00234 { +00235 ChanExceptSender(Channel,User,"%s",s.c_str()); +00236 } +00237 } +00238 +00239 bool Server::CommonChannels(userrec* u1, userrec* u2) +00240 { +00241 return (common_channels(u1,u2) != 0); +00242 } +00243 +00244 void Server::SendCommon(userrec* User, std::string text,bool IncludeSender) +00245 { +00246 if (IncludeSender) +00247 { +00248 WriteCommon(User,"%s",text.c_str()); +00249 } +00250 else +00251 { +00252 WriteCommonExcept(User,"%s",text.c_str()); +00253 } +00254 } +00255 +00256 void Server::SendWallops(userrec* User, std::string text) +00257 { +00258 WriteWallOps(User,false,"%s",text.c_str()); +00259 } +00260 +00261 void Server::ChangeHost(userrec* user, std::string host) +00262 { +00263 ChangeDisplayedHost(user,host.c_str()); +00264 } +00265 +00266 void Server::ChangeGECOS(userrec* user, std::string gecos) +00267 { +00268 ChangeName(user,gecos.c_str()); +00269 } +00270 +00271 bool Server::IsNick(std::string nick) +00272 { +00273 return (isnick(nick.c_str()) != 0); +00274 } +00275 +00276 userrec* Server::FindNick(std::string nick) +00277 { +00278 return Find(nick); +00279 } +00280 +00281 chanrec* Server::FindChannel(std::string channel) +00282 { +00283 return FindChan(channel.c_str()); +00284 } +00285 +00286 std::string Server::ChanMode(userrec* User, chanrec* Chan) +00287 { +00288 return cmode(User,Chan); +00289 } +00290 +00291 std::string Server::GetServerName() +00292 { +00293 return getservername(); +00294 } +00295 +00296 std::string Server::GetNetworkName() +00297 { +00298 return getnetworkname(); +00299 } +00300 +00301 Admin Server::GetAdmin() +00302 { +00303 return Admin(getadminname(),getadminemail(),getadminnick()); +00304 } +00305 +00306 +00307 +00308 bool Server::AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off) +00309 { +00310 if (type == MT_SERVER) +00311 { +00312 log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion"); +00313 return false; +00314 } +00315 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) +00316 { +00317 log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported"); +00318 return false; +00319 } +00320 if ((params_when_on>1) || (params_when_off>1)) +00321 { +00322 log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported"); +00323 return false; +00324 } +00325 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); +00326 } +00327 +00328 int Server::CountUsers(chanrec* c) +00329 { +00330 return usercount(c); +00331 } +00332 +00333 +00334 ConfigReader::ConfigReader() +00335 { +00336 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +00337 this->error = LoadConf(CONFIG_FILE,this->cache); +00338 } +00339 +00340 +00341 ConfigReader::~ConfigReader() +00342 { +00343 if (this->cache) +00344 delete this->cache; +00345 } +00346 +00347 +00348 ConfigReader::ConfigReader(std::string filename) +00349 { +00350 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +00351 this->error = LoadConf(filename.c_str(),this->cache); +00352 }; +00353 +00354 std::string ConfigReader::ReadValue(std::string tag, std::string name, int index) +00355 { +00356 char val[MAXBUF]; +00357 ReadConf(cache,tag.c_str(),name.c_str(),index,val); +00358 return val; +00359 } +00360 +00361 +00362 int ConfigReader::Enumerate(std::string tag) +00363 { +00364 return EnumConf(cache,tag.c_str()); +00365 } +00366 +00367 int ConfigReader::EnumerateValues(std::string tag, int index) +00368 { +00369 return EnumValues(cache, tag.c_str(), index); +00370 } +00371 +00372 bool ConfigReader::Verify() +00373 { +00374 return this->error; +00375 } +00376 +00377 +00378 FileReader::FileReader(std::string filename) +00379 { +00380 file_cache c; +00381 readfile(c,filename.c_str()); +00382 this->fc = c; +00383 } +00384 +00385 FileReader::FileReader() +00386 { +00387 } +00388 +00389 void FileReader::LoadFile(std::string filename) +00390 { +00391 file_cache c; +00392 readfile(c,filename.c_str()); +00393 this->fc = c; +00394 } +00395 +00396 +00397 FileReader::~FileReader() +00398 { +00399 } +00400 +00401 bool FileReader::Exists() +00402 { +00403 if (fc.size() == 0) +00404 { +00405 return(false); +00406 } +00407 else +00408 { +00409 return(true); +00410 } +00411 } +00412 +00413 std::string FileReader::GetLine(int x) +00414 { +00415 if ((x<0) || (x>fc.size())) +00416 return ""; +00417 return fc[x]; +00418 } +00419 +00420 int FileReader::FileSize() +00421 { +00422 return fc.size(); +00423 } +00424 +00425 +00426 std::vector<Module*> modules(255); +00427 std::vector<ircd_module*> factory(255); +00428 +00429 int MODCOUNT = -1; +00430 +00431 +
Generated on Sat Apr 17 13:33:44 2004 for InspIRCd by doxygen1.3-rc3