From 66f0cd6469d2643858c2fcd14726d362696bd68d Mon Sep 17 00:00:00 2001 From: brain Date: Tue, 24 May 2005 02:34:33 +0000 Subject: New methods, new docs git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@1484 e03df62e-2008-0410-955e-edbf42e46eb7 --- docs/man/man3/Admin.3 | 6 +- docs/man/man3/BanItem.3 | 2 +- docs/man/man3/ConfigReader.3 | 264 +-- docs/man/man3/ConnectClass.3 | 2 +- docs/man/man3/DNS.3 | 2 +- docs/man/man3/ELine.3 | 2 +- docs/man/man3/Event.3 | 40 +- docs/man/man3/ExemptItem.3 | 2 +- docs/man/man3/ExtMode.3 | 18 +- docs/man/man3/Extensible.3 | 2 +- docs/man/man3/FileReader.3 | 80 +- docs/man/man3/GLine.3 | 2 +- docs/man/man3/HostItem.3 | 2 +- docs/man/man3/InviteItem.3 | 2 +- docs/man/man3/Invited.3 | 2 +- docs/man/man3/KLine.3 | 2 +- docs/man/man3/ModeParameter.3 | 2 +- docs/man/man3/Module.3 | 226 +-- docs/man/man3/ModuleFactory.3 | 2 +- docs/man/man3/ModuleMessage.3 | 2 +- docs/man/man3/QLine.3 | 2 +- docs/man/man3/Request.3 | 52 +- docs/man/man3/Server.3 | 773 ++++---- docs/man/man3/Version.3 | 6 +- docs/man/man3/WhoWasUser.3 | 18 +- docs/man/man3/XLine.3 | 2 +- docs/man/man3/ZLine.3 | 2 +- docs/man/man3/base.h.3 | 2 +- docs/man/man3/channels.cpp.3 | 36 +- docs/man/man3/channels.h.3 | 2 +- docs/man/man3/chanrec.3 | 220 +-- docs/man/man3/classbase.3 | 2 +- docs/man/man3/command_t.3 | 2 +- docs/man/man3/commands.h.3 | 7 +- docs/man/man3/connection.3 | 117 +- docs/man/man3/connection.h.3 | 10 +- docs/man/man3/ctables.h.3 | 2 +- docs/man/man3/dns.h.3 | 2 +- docs/man/man3/dns_ip4list.3 | 2 +- docs/man/man3/hashcomp.h.3 | 4 +- docs/man/man3/irc.3 | 4 +- docs/man/man3/irc_InAddr_HashComp.3 | 4 +- docs/man/man3/irc_StrHashComp.3 | 4 +- docs/man/man3/irc_irc_char_traits.3 | 4 +- docs/man/man3/ircd_connector.3 | 120 +- docs/man/man3/message.h.3 | 12 +- docs/man/man3/mode.h.3 | 2 +- docs/man/man3/modules.cpp.3 | 262 ++- docs/man/man3/modules.h.3 | 4 +- docs/man/man3/nspace.3 | 2 +- docs/man/man3/nspace_nspace_hash_ in_addr _.3 | 2 +- docs/man/man3/nspace_nspace_hash_ string _.3 | 2 +- docs/man/man3/serverrec.3 | 526 +++++- docs/man/man3/servers.cpp.3 | 76 +- docs/man/man3/servers.h.3 | 2 +- docs/man/man3/std.3 | 2 +- docs/man/man3/std_char_traits.3 | 2 +- docs/man/man3/ucrec.3 | 2 +- docs/man/man3/userrec.3 | 499 ++--- docs/man/man3/users.cpp.3 | 6 +- docs/man/man3/users.h.3 | 2 +- docs/man/man3/xline.h.3 | 2 +- docs/module-doc/annotated.html | 2 +- docs/module-doc/base_8h-source.html | 2 +- docs/module-doc/base_8h.html | 2 +- docs/module-doc/channels_8cpp-source.html | 361 ++-- docs/module-doc/channels_8cpp.html | 138 +- docs/module-doc/channels_8h-source.html | 2 +- docs/module-doc/channels_8h.html | 2 +- docs/module-doc/classAdmin-members.html | 2 +- docs/module-doc/classAdmin.html | 6 +- docs/module-doc/classBanItem-members.html | 2 +- docs/module-doc/classBanItem.html | 2 +- docs/module-doc/classConfigReader-members.html | 2 +- docs/module-doc/classConfigReader.html | 278 +-- docs/module-doc/classConnectClass-members.html | 2 +- docs/module-doc/classConnectClass.html | 2 +- docs/module-doc/classDNS-members.html | 2 +- docs/module-doc/classDNS.html | 2 +- docs/module-doc/classELine-members.html | 2 +- docs/module-doc/classELine.html | 2 +- docs/module-doc/classEvent-members.html | 2 +- docs/module-doc/classEvent.html | 46 +- docs/module-doc/classExemptItem-members.html | 2 +- docs/module-doc/classExemptItem.html | 2 +- docs/module-doc/classExtMode-members.html | 2 +- docs/module-doc/classExtMode.html | 30 +- docs/module-doc/classExtensible-members.html | 2 +- docs/module-doc/classExtensible.html | 2 +- docs/module-doc/classFileReader-members.html | 2 +- docs/module-doc/classFileReader.html | 82 +- docs/module-doc/classGLine-members.html | 2 +- docs/module-doc/classGLine.html | 2 +- docs/module-doc/classHostItem-members.html | 2 +- docs/module-doc/classHostItem.html | 2 +- docs/module-doc/classInviteItem-members.html | 2 +- docs/module-doc/classInviteItem.html | 2 +- docs/module-doc/classInvited-members.html | 2 +- docs/module-doc/classInvited.html | 4 +- docs/module-doc/classKLine-members.html | 2 +- docs/module-doc/classKLine.html | 2 +- docs/module-doc/classModeParameter-members.html | 2 +- docs/module-doc/classModeParameter.html | 8 +- docs/module-doc/classModule-members.html | 2 +- docs/module-doc/classModule.html | 228 +-- docs/module-doc/classModuleFactory-members.html | 2 +- docs/module-doc/classModuleFactory.html | 2 +- docs/module-doc/classModuleMessage-members.html | 2 +- docs/module-doc/classModuleMessage.html | 2 +- docs/module-doc/classQLine-members.html | 2 +- docs/module-doc/classQLine.html | 2 +- docs/module-doc/classRequest-members.html | 2 +- docs/module-doc/classRequest.html | 60 +- docs/module-doc/classServer-members.html | 2 +- docs/module-doc/classServer.html | 837 ++++----- docs/module-doc/classVersion-members.html | 2 +- docs/module-doc/classVersion.html | 6 +- docs/module-doc/classWhoWasUser-members.html | 2 +- docs/module-doc/classWhoWasUser.html | 18 +- docs/module-doc/classXLine-members.html | 2 +- docs/module-doc/classXLine.html | 2 +- docs/module-doc/classZLine-members.html | 2 +- docs/module-doc/classZLine.html | 2 +- docs/module-doc/classchanrec-members.html | 2 +- docs/module-doc/classchanrec.html | 264 +-- docs/module-doc/classclassbase-members.html | 2 +- docs/module-doc/classclassbase.html | 2 +- docs/module-doc/classcommand__t-members.html | 2 +- docs/module-doc/classcommand__t.html | 2 +- docs/module-doc/classconnection-members.html | 11 +- docs/module-doc/classconnection.html | 477 +---- docs/module-doc/classconnection__coll__graph.gif | Bin 6065 -> 6624 bytes docs/module-doc/classes.html | 2 +- docs/module-doc/classircd__connector-members.html | 54 +- docs/module-doc/classircd__connector.html | 559 +++++- .../classircd__connector__coll__graph.gif | Bin 4622 -> 6239 bytes docs/module-doc/classserverrec-members.html | 21 +- docs/module-doc/classserverrec.html | 916 +++++++++- docs/module-doc/classserverrec__coll__graph.gif | Bin 7112 -> 7628 bytes docs/module-doc/classstd_1_1char__traits.html | 2 +- docs/module-doc/classucrec-members.html | 2 +- docs/module-doc/classucrec.html | 6 +- docs/module-doc/classuserrec-members.html | 31 +- docs/module-doc/classuserrec.html | 707 ++++---- docs/module-doc/classuserrec__coll__graph.gif | Bin 12762 -> 12932 bytes docs/module-doc/commands_8h-source.html | 67 +- docs/module-doc/commands_8h.html | 164 +- docs/module-doc/connection_8h-source.html | 212 +-- docs/module-doc/connection_8h.html | 23 +- docs/module-doc/connection_8h__dep__incl.gif | Bin 2579 -> 3144 bytes docs/module-doc/ctables_8h-source.html | 2 +- docs/module-doc/ctables_8h.html | 2 +- docs/module-doc/dns_8h-source.html | 2 +- docs/module-doc/dns_8h.html | 2 +- docs/module-doc/files.html | 2 +- docs/module-doc/functions.html | 111 +- docs/module-doc/functions_func.html | 87 +- docs/module-doc/functions_vars.html | 14 +- docs/module-doc/globals.html | 177 +- docs/module-doc/globals_defs.html | 2 +- docs/module-doc/globals_func.html | 109 +- docs/module-doc/globals_type.html | 16 +- docs/module-doc/globals_vars.html | 58 +- docs/module-doc/graph_legend.html | 2 +- docs/module-doc/hashcomp_8h-source.html | 145 +- docs/module-doc/hashcomp_8h.html | 4 +- docs/module-doc/hierarchy.html | 2 +- docs/module-doc/inherits.html | 2 +- docs/module-doc/main.html | 2 +- docs/module-doc/message_8h-source.html | 38 +- docs/module-doc/message_8h.html | 136 +- docs/module-doc/mode_8h-source.html | 2 +- docs/module-doc/mode_8h.html | 2 +- docs/module-doc/modules_8cpp-source.html | 1910 ++++++++++---------- docs/module-doc/modules_8cpp.html | 498 +++-- docs/module-doc/modules_8h-source.html | 14 +- docs/module-doc/modules_8h.html | 36 +- docs/module-doc/namespaceirc.html | 4 +- docs/module-doc/namespacemembers.html | 2 +- docs/module-doc/namespacemembers_type.html | 2 +- docs/module-doc/namespacenspace.html | 2 +- docs/module-doc/namespaces.html | 2 +- docs/module-doc/namespacestd.html | 2 +- docs/module-doc/servers_8cpp-source.html | 483 ++++- docs/module-doc/servers_8cpp.html | 131 +- docs/module-doc/servers_8cpp__incl.gif | Bin 3785 -> 11979 bytes docs/module-doc/servers_8h-source.html | 32 +- docs/module-doc/servers_8h.html | 2 +- docs/module-doc/structdns__ip4list-members.html | 2 +- docs/module-doc/structdns__ip4list.html | 2 +- .../structirc_1_1InAddr__HashComp-members.html | 2 +- docs/module-doc/structirc_1_1InAddr__HashComp.html | 4 +- .../structirc_1_1StrHashComp-members.html | 2 +- docs/module-doc/structirc_1_1StrHashComp.html | 4 +- .../structirc_1_1irc__char__traits-members.html | 2 +- .../module-doc/structirc_1_1irc__char__traits.html | 4 +- ..._1nspace_1_1hash_3_01in__addr_01_4-members.html | 2 +- ...nspace_1_1nspace_1_1hash_3_01in__addr_01_4.html | 2 +- ..._1_1nspace_1_1hash_3_01string_01_4-members.html | 2 +- ...ctnspace_1_1nspace_1_1hash_3_01string_01_4.html | 2 +- docs/module-doc/users_8cpp-source.html | 531 +++--- docs/module-doc/users_8cpp.html | 6 +- docs/module-doc/users_8h-source.html | 68 +- docs/module-doc/users_8h.html | 4 +- docs/module-doc/xline_8h-source.html | 2 +- docs/module-doc/xline_8h.html | 22 +- 206 files changed, 7993 insertions(+), 5899 deletions(-) diff --git a/docs/man/man3/Admin.3 b/docs/man/man3/Admin.3 index e2001754e..416575798 100644 --- a/docs/man/man3/Admin.3 +++ b/docs/man/man3/Admin.3 @@ -1,4 +1,4 @@ -.TH "Admin" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Admin" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -43,10 +43,10 @@ Definition at line 123 of file modules.h. .PP .SS "Admin::Admin (std::string name, std::string email, std::string nick)" .PP -Definition at line 238 of file modules.cpp. +Definition at line 247 of file modules.cpp. .PP .nf -238 : Name(name), Email(email), Nick(nick) { }; +247 : Name(name), Email(email), Nick(nick) { }; .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/BanItem.3 b/docs/man/man3/BanItem.3 index 8fb296ba1..1df522d83 100644 --- a/docs/man/man3/BanItem.3 +++ b/docs/man/man3/BanItem.3 @@ -1,4 +1,4 @@ -.TH "BanItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "BanItem" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ConfigReader.3 b/docs/man/man3/ConfigReader.3 index 23b16d688..db2f5d282 100644 --- a/docs/man/man3/ConfigReader.3 +++ b/docs/man/man3/ConfigReader.3 @@ -1,4 +1,4 @@ -.TH "ConfigReader" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ConfigReader" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -89,213 +89,213 @@ Definition at line 1150 of file modules.h. .PP .SS "ConfigReader::ConfigReader ()" .PP -Default constructor. This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.Definition at line 799 of file modules.cpp. +Default constructor. This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.Definition at line 819 of file modules.cpp. .PP References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. .PP .nf -800 { -801 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -802 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -803 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); -804 if (!this->readerror) -805 this->error = CONF_FILE_NOT_FOUND; -806 } +820 { +821 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +822 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +823 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); +824 if (!this->readerror) +825 this->error = CONF_FILE_NOT_FOUND; +826 } .fi .SS "ConfigReader::ConfigReader (std::string filename)" .PP -Overloaded constructor. This constructor initialises the ConfigReader class to read a user-specified config fileDefinition at line 818 of file modules.cpp. +Overloaded constructor. This constructor initialises the ConfigReader class to read a user-specified config fileDefinition at line 838 of file modules.cpp. .PP References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. .PP .nf -819 { -820 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -821 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -822 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); -823 if (!this->readerror) -824 this->error = CONF_FILE_NOT_FOUND; -825 }; +839 { +840 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +841 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +842 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); +843 if (!this->readerror) +844 this->error = CONF_FILE_NOT_FOUND; +845 }; .fi .SS "ConfigReader::~\fBConfigReader\fP ()" .PP -Default destructor. This method destroys the ConfigReader class.Definition at line 809 of file modules.cpp. +Default destructor. This method destroys the ConfigReader class.Definition at line 829 of file modules.cpp. .PP References cache, and errorlog. .PP .nf -810 { -811 if (this->cache) -812 delete this->cache; -813 if (this->errorlog) -814 delete this->errorlog; -815 } +830 { +831 if (this->cache) +832 delete this->cache; +833 if (this->errorlog) +834 delete this->errorlog; +835 } .fi .SH "Member Function Documentation" .PP .SS "void ConfigReader::DumpErrors (bool bail, \fBuserrec\fP * user)" .PP -Dumps the list of errors in a config file to an output location. If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.Definition at line 896 of file modules.cpp. +Dumps the list of errors in a config file to an output location. If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.Definition at line 916 of file modules.cpp. .PP References errorlog, connection::fd, and userrec::nick. .PP .nf -897 { -898 if (bail) -899 { -900 printf('There were errors in your configuration:\n%s',errorlog->str().c_str()); -901 exit(0); -902 } -903 else -904 { -905 char dataline[1024]; -906 if (user) -907 { -908 WriteServ(user->fd,'NOTICE %s :There were errors in the configuration file:',user->nick); -909 while (!errorlog->eof()) -910 { -911 errorlog->getline(dataline,1024); -912 WriteServ(user->fd,'NOTICE %s :%s',user->nick,dataline); -913 } -914 } -915 else -916 { -917 WriteOpers('There were errors in the configuration file:',user->nick); -918 while (!errorlog->eof()) -919 { -920 errorlog->getline(dataline,1024); -921 WriteOpers(dataline); -922 } -923 } -924 return; -925 } -926 } +917 { +918 if (bail) +919 { +920 printf('There were errors in your configuration:\n%s',errorlog->str().c_str()); +921 exit(0); +922 } +923 else +924 { +925 char dataline[1024]; +926 if (user) +927 { +928 WriteServ(user->fd,'NOTICE %s :There were errors in the configuration file:',user->nick); +929 while (!errorlog->eof()) +930 { +931 errorlog->getline(dataline,1024); +932 WriteServ(user->fd,'NOTICE %s :%s',user->nick,dataline); +933 } +934 } +935 else +936 { +937 WriteOpers('There were errors in the configuration file:',user->nick); +938 while (!errorlog->eof()) +939 { +940 errorlog->getline(dataline,1024); +941 WriteOpers(dataline); +942 } +943 } +944 return; +945 } +946 } .fi .SS "int ConfigReader::Enumerate (std::string tag)" .PP -Counts the number of times a given tag appears in the config file. This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of \fBConfigReader::ReadValue\fP to loop through all copies of a multiple instance tag.Definition at line 929 of file modules.cpp. +Counts the number of times a given tag appears in the config file. This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of \fBConfigReader::ReadValue\fP to loop through all copies of a multiple instance tag.Definition at line 949 of file modules.cpp. .PP References cache. .PP .nf -930 { -931 return EnumConf(cache,tag.c_str()); -932 } +950 { +951 return EnumConf(cache,tag.c_str()); +952 } .fi .SS "int ConfigReader::EnumerateValues (std::string tag, int index)" .PP -Returns the number of items within a tag. For example if the tag was then this function would return 2. Spaces and newlines both qualify as valid seperators between values.Definition at line 934 of file modules.cpp. +Returns the number of items within a tag. For example if the tag was then this function would return 2. Spaces and newlines both qualify as valid seperators between values.Definition at line 954 of file modules.cpp. .PP References cache. .PP .nf -935 { -936 return EnumValues(cache, tag.c_str(), index); -937 } +955 { +956 return EnumValues(cache, tag.c_str(), index); +957 } .fi .SS "long ConfigReader::GetError ()" .PP -Returns the last error to occur. Valid errors can be found by looking in \fBmodules.h\fP. Any nonzero value indicates an error condition. A call to \fBGetError()\fP resets the error flag back to 0.Definition at line 889 of file modules.cpp. +Returns the last error to occur. Valid errors can be found by looking in \fBmodules.h\fP. Any nonzero value indicates an error condition. A call to \fBGetError()\fP resets the error flag back to 0.Definition at line 909 of file modules.cpp. .PP References error. .PP .nf -890 { -891 long olderr = this->error; -892 this->error = 0; -893 return olderr; -894 } +910 { +911 long olderr = this->error; +912 this->error = 0; +913 return olderr; +914 } .fi .SS "bool ConfigReader::ReadFlag (std::string tag, std::string name, int index)" .PP -Retrieves a boolean value from the config file. This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values '1', 'yes' and 'true' in the config file count as true to ReadFlag, and any other value counts as false.Definition at line 843 of file modules.cpp. +Retrieves a boolean value from the config file. This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values '1', 'yes' and 'true' in the config file count as true to ReadFlag, and any other value counts as false.Definition at line 863 of file modules.cpp. .PP References cache, CONF_VALUE_NOT_FOUND, and error. .PP .nf -844 { -845 char val[MAXBUF]; -846 char t[MAXBUF]; -847 char n[MAXBUF]; -848 strlcpy(t,tag.c_str(),MAXBUF); -849 strlcpy(n,name.c_str(),MAXBUF); -850 int res = ReadConf(cache,t,n,index,val); -851 if (!res) -852 { -853 this->error = CONF_VALUE_NOT_FOUND; -854 return false; -855 } -856 std::string s = val; -857 return ((s == 'yes') || (s == 'YES') || (s == 'true') || (s == 'TRUE') || (s == '1')); -858 } +864 { +865 char val[MAXBUF]; +866 char t[MAXBUF]; +867 char n[MAXBUF]; +868 strlcpy(t,tag.c_str(),MAXBUF); +869 strlcpy(n,name.c_str(),MAXBUF); +870 int res = ReadConf(cache,t,n,index,val); +871 if (!res) +872 { +873 this->error = CONF_VALUE_NOT_FOUND; +874 return false; +875 } +876 std::string s = val; +877 return ((s == 'yes') || (s == 'YES') || (s == 'true') || (s == 'TRUE') || (s == '1')); +878 } .fi .SS "long ConfigReader::ReadInteger (std::string tag, std::string name, int index, bool needs_unsigned)" .PP -Retrieves an integer value from the config file. This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to \fBGetError()\fP will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and \fBGetError()\fP will return CONF_NOT_UNSIGNEDDefinition at line 860 of file modules.cpp. +Retrieves an integer value from the config file. This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to \fBGetError()\fP will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and \fBGetError()\fP will return CONF_NOT_UNSIGNEDDefinition at line 880 of file modules.cpp. .PP References cache, CONF_NOT_A_NUMBER, CONF_NOT_UNSIGNED, CONF_VALUE_NOT_FOUND, and error. .PP .nf -861 { -862 char val[MAXBUF]; -863 char t[MAXBUF]; -864 char n[MAXBUF]; -865 strlcpy(t,tag.c_str(),MAXBUF); -866 strlcpy(n,name.c_str(),MAXBUF); -867 int res = ReadConf(cache,t,n,index,val); -868 if (!res) -869 { -870 this->error = CONF_VALUE_NOT_FOUND; -871 return 0; -872 } -873 for (int i = 0; i < strlen(val); i++) -874 { -875 if (!isdigit(val[i])) -876 { -877 this->error = CONF_NOT_A_NUMBER; -878 return 0; -879 } -880 } -881 if ((needs_unsigned) && (atoi(val)<0)) -882 { -883 this->error = CONF_NOT_UNSIGNED; -884 return 0; -885 } -886 return atoi(val); -887 } +881 { +882 char val[MAXBUF]; +883 char t[MAXBUF]; +884 char n[MAXBUF]; +885 strlcpy(t,tag.c_str(),MAXBUF); +886 strlcpy(n,name.c_str(),MAXBUF); +887 int res = ReadConf(cache,t,n,index,val); +888 if (!res) +889 { +890 this->error = CONF_VALUE_NOT_FOUND; +891 return 0; +892 } +893 for (int i = 0; i < strlen(val); i++) +894 { +895 if (!isdigit(val[i])) +896 { +897 this->error = CONF_NOT_A_NUMBER; +898 return 0; +899 } +900 } +901 if ((needs_unsigned) && (atoi(val)<0)) +902 { +903 this->error = CONF_NOT_UNSIGNED; +904 return 0; +905 } +906 return atoi(val); +907 } .fi .SS "std::string ConfigReader::ReadValue (std::string tag, std::string name, int index)" .PP -Retrieves a value from the config file. This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.Definition at line 827 of file modules.cpp. +Retrieves a value from the config file. This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.Definition at line 847 of file modules.cpp. .PP References cache, CONF_VALUE_NOT_FOUND, and error. .PP .nf -828 { -829 char val[MAXBUF]; -830 char t[MAXBUF]; -831 char n[MAXBUF]; -832 strlcpy(t,tag.c_str(),MAXBUF); -833 strlcpy(n,name.c_str(),MAXBUF); -834 int res = ReadConf(cache,t,n,index,val); -835 if (!res) -836 { -837 this->error = CONF_VALUE_NOT_FOUND; -838 return ''; -839 } -840 return val; -841 } +848 { +849 char val[MAXBUF]; +850 char t[MAXBUF]; +851 char n[MAXBUF]; +852 strlcpy(t,tag.c_str(),MAXBUF); +853 strlcpy(n,name.c_str(),MAXBUF); +854 int res = ReadConf(cache,t,n,index,val); +855 if (!res) +856 { +857 this->error = CONF_VALUE_NOT_FOUND; +858 return ''; +859 } +860 return val; +861 } .fi .SS "bool ConfigReader::Verify ()" .PP -Returns true if a config file is valid. This method is partially implemented and will only return false if the config file does not exist or could not be opened.Definition at line 939 of file modules.cpp. +Returns true if a config file is valid. This method is partially implemented and will only return false if the config file does not exist or could not be opened.Definition at line 959 of file modules.cpp. .PP References readerror. .PP .nf -940 { -941 return this->readerror; -942 } +960 { +961 return this->readerror; +962 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/ConnectClass.3 b/docs/man/man3/ConnectClass.3 index c71050d3c..23662d063 100644 --- a/docs/man/man3/ConnectClass.3 +++ b/docs/man/man3/ConnectClass.3 @@ -1,4 +1,4 @@ -.TH "ConnectClass" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ConnectClass" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/DNS.3 b/docs/man/man3/DNS.3 index f70f13979..f5b6d1c9d 100644 --- a/docs/man/man3/DNS.3 +++ b/docs/man/man3/DNS.3 @@ -1,4 +1,4 @@ -.TH "DNS" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "DNS" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ELine.3 b/docs/man/man3/ELine.3 index cf223c4a7..b68821320 100644 --- a/docs/man/man3/ELine.3 +++ b/docs/man/man3/ELine.3 @@ -1,4 +1,4 @@ -.TH "ELine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ELine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Event.3 b/docs/man/man3/Event.3 index 249e9bcba..66edc1d3d 100644 --- a/docs/man/man3/Event.3 +++ b/docs/man/man3/Event.3 @@ -1,4 +1,4 @@ -.TH "Event" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Event" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -63,59 +63,59 @@ Definition at line 194 of file modules.h. .PP .SS "Event::Event (char * anydata, \fBModule\fP * src, std::string eventid)" .PP -Create a new Event. Definition at line 269 of file modules.cpp. +Create a new Event. Definition at line 278 of file modules.cpp. .PP .nf -269 : data(anydata), source(src), id(eventid) { }; +278 : data(anydata), source(src), id(eventid) { }; .fi .SH "Member Function Documentation" .PP .SS "char * Event::GetData ()" .PP -Get the Event data. Definition at line 271 of file modules.cpp. +Get the Event data. Definition at line 280 of file modules.cpp. .PP References data. .PP .nf -272 { -273 return this->data; -274 } +281 { +282 return this->data; +283 } .fi .SS "std::string Event::GetEventID ()" .PP -Get the event ID. Use this to determine the event type for safe casting of the data Definition at line 287 of file modules.cpp. +Get the event ID. Use this to determine the event type for safe casting of the data Definition at line 296 of file modules.cpp. .PP References id. .PP .nf -288 { -289 return this->id; -290 } +297 { +298 return this->id; +299 } .fi .SS "\fBModule\fP * Event::GetSource ()" .PP -Get the event Source. Definition at line 276 of file modules.cpp. +Get the event Source. Definition at line 285 of file modules.cpp. .PP References source. .PP .nf -277 { -278 return this->source; -279 } +286 { +287 return this->source; +288 } .fi .SS "char * Event::Send ()\fC [virtual]\fP" .PP Send the Event. The return result of an \fBEvent::Send()\fP will always be NULL as no replies are expected. Implements \fBModuleMessage\fP. .PP -Definition at line 281 of file modules.cpp. +Definition at line 290 of file modules.cpp. .PP References FOREACH_MOD. .PP .nf -282 { -283 FOREACH_MOD OnEvent(this); -284 return NULL; -285 } +291 { +292 FOREACH_MOD OnEvent(this); +293 return NULL; +294 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/ExemptItem.3 b/docs/man/man3/ExemptItem.3 index b30ba6601..aa5258002 100644 --- a/docs/man/man3/ExemptItem.3 +++ b/docs/man/man3/ExemptItem.3 @@ -1,4 +1,4 @@ -.TH "ExemptItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ExemptItem" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ExtMode.3 b/docs/man/man3/ExtMode.3 index 353b17ce3..236e8cd8a 100644 --- a/docs/man/man3/ExtMode.3 +++ b/docs/man/man3/ExtMode.3 @@ -1,4 +1,4 @@ -.TH "ExtMode" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ExtMode" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -41,41 +41,41 @@ Inherits \fBclassbase\fP. .PP .SS "ExtMode::ExtMode (char mc, int ty, bool oper, int p_on, int p_off)\fC [inline]\fP" .PP -Definition at line 136 of file modules.cpp. +Definition at line 145 of file modules.cpp. .PP References modechar, needsoper, params_when_off, params_when_on, and type. .PP .nf -136 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { }; +145 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { }; .fi .SH "Member Data Documentation" .PP .SS "bool \fBExtMode::list\fP" .PP -Definition at line 135 of file modules.cpp. +Definition at line 144 of file modules.cpp. .SS "char \fBExtMode::modechar\fP" .PP -Definition at line 130 of file modules.cpp. +Definition at line 139 of file modules.cpp. .PP Referenced by ExtMode(). .SS "bool \fBExtMode::needsoper\fP" .PP -Definition at line 134 of file modules.cpp. +Definition at line 143 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::params_when_off\fP" .PP -Definition at line 133 of file modules.cpp. +Definition at line 142 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::params_when_on\fP" .PP -Definition at line 132 of file modules.cpp. +Definition at line 141 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::type\fP" .PP -Definition at line 131 of file modules.cpp. +Definition at line 140 of file modules.cpp. .PP Referenced by ExtMode(). diff --git a/docs/man/man3/Extensible.3 b/docs/man/man3/Extensible.3 index 46a699705..d36912f60 100644 --- a/docs/man/man3/Extensible.3 +++ b/docs/man/man3/Extensible.3 @@ -1,4 +1,4 @@ -.TH "Extensible" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Extensible" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/FileReader.3 b/docs/man/man3/FileReader.3 index 1df4ff063..f791a880e 100644 --- a/docs/man/man3/FileReader.3 +++ b/docs/man/man3/FileReader.3 @@ -1,4 +1,4 @@ -.TH "FileReader" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "FileReader" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -62,89 +62,89 @@ Definition at line 1239 of file modules.h. .PP .SS "FileReader::FileReader ()" .PP -Default constructor. This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.Definition at line 952 of file modules.cpp. +Default constructor. This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.Definition at line 972 of file modules.cpp. .PP .nf -953 { -954 } +973 { +974 } .fi .SS "FileReader::FileReader (std::string filename)" .PP -Secondary constructor. This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 945 of file modules.cpp. +Secondary constructor. This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 965 of file modules.cpp. .PP References fc, and file_cache. .PP .nf -946 { -947 file_cache c; -948 readfile(c,filename.c_str()); -949 this->fc = c; -950 } +966 { +967 file_cache c; +968 readfile(c,filename.c_str()); +969 this->fc = c; +970 } .fi .SS "FileReader::~\fBFileReader\fP ()" .PP -Default destructor. This deletes the memory allocated to the file.Definition at line 964 of file modules.cpp. +Default destructor. This deletes the memory allocated to the file.Definition at line 984 of file modules.cpp. .PP .nf -965 { -966 } +985 { +986 } .fi .SH "Member Function Documentation" .PP .SS "bool FileReader::Exists ()" .PP -Returns true if the file exists This function will return false if the file could not be opened. Definition at line 968 of file modules.cpp. +Returns true if the file exists This function will return false if the file could not be opened. Definition at line 988 of file modules.cpp. .PP References fc. .PP .nf -969 { -970 if (fc.size() == 0) -971 { -972 return(false); -973 } -974 else -975 { -976 return(true); -977 } -978 } +989 { +990 if (fc.size() == 0) +991 { +992 return(false); +993 } +994 else +995 { +996 return(true); +997 } +998 } .fi .SS "int FileReader::FileSize ()" .PP -Returns the size of the file in lines. This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.Definition at line 987 of file modules.cpp. +Returns the size of the file in lines. This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.Definition at line 1007 of file modules.cpp. .PP References fc. .PP .nf -988 { -989 return fc.size(); -990 } +1008 { +1009 return fc.size(); +1010 } .fi .SS "std::string FileReader::GetLine (int x)" .PP -Retrieve one line from the file. This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.Definition at line 980 of file modules.cpp. +Retrieve one line from the file. This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.Definition at line 1000 of file modules.cpp. .PP References fc. .PP .nf -981 { -982 if ((x<0) || (x>fc.size())) -983 return ''; -984 return fc[x]; -985 } +1001 { +1002 if ((x<0) || (x>fc.size())) +1003 return ''; +1004 return fc[x]; +1005 } .fi .SS "void FileReader::LoadFile (std::string filename)" .PP -Used to load a file. This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 956 of file modules.cpp. +Used to load a file. This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 976 of file modules.cpp. .PP References fc, and file_cache. .PP .nf -957 { -958 file_cache c; -959 readfile(c,filename.c_str()); -960 this->fc = c; -961 } +977 { +978 file_cache c; +979 readfile(c,filename.c_str()); +980 this->fc = c; +981 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/GLine.3 b/docs/man/man3/GLine.3 index e781013fa..8a8523190 100644 --- a/docs/man/man3/GLine.3 +++ b/docs/man/man3/GLine.3 @@ -1,4 +1,4 @@ -.TH "GLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "GLine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/HostItem.3 b/docs/man/man3/HostItem.3 index 37b11a714..7d151b18d 100644 --- a/docs/man/man3/HostItem.3 +++ b/docs/man/man3/HostItem.3 @@ -1,4 +1,4 @@ -.TH "HostItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "HostItem" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/InviteItem.3 b/docs/man/man3/InviteItem.3 index 50608345f..a38f1bd5f 100644 --- a/docs/man/man3/InviteItem.3 +++ b/docs/man/man3/InviteItem.3 @@ -1,4 +1,4 @@ -.TH "InviteItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "InviteItem" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Invited.3 b/docs/man/man3/Invited.3 index e09d4d9b5..87fb6a718 100644 --- a/docs/man/man3/Invited.3 +++ b/docs/man/man3/Invited.3 @@ -1,4 +1,4 @@ -.TH "Invited" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Invited" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/KLine.3 b/docs/man/man3/KLine.3 index ed73e3e15..076be1032 100644 --- a/docs/man/man3/KLine.3 +++ b/docs/man/man3/KLine.3 @@ -1,4 +1,4 @@ -.TH "KLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "KLine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ModeParameter.3 b/docs/man/man3/ModeParameter.3 index 2a85198db..bd6f50b0e 100644 --- a/docs/man/man3/ModeParameter.3 +++ b/docs/man/man3/ModeParameter.3 @@ -1,4 +1,4 @@ -.TH "ModeParameter" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModeParameter" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Module.3 b/docs/man/man3/Module.3 index b33e933cd..eab4669bb 100644 --- a/docs/man/man3/Module.3 +++ b/docs/man/man3/Module.3 @@ -1,4 +1,4 @@ -.TH "Module" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Module" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -251,35 +251,35 @@ Definition at line 236 of file modules.h. .PP .SS "Module::Module ()" .PP -Default constructor creates a module class. Definition at line 294 of file modules.cpp. +Default constructor creates a module class. Definition at line 303 of file modules.cpp. .PP .nf -294 { } +303 { } .fi .SS "Module::~\fBModule\fP ()\fC [virtual]\fP" .PP -Default destructor destroys a module class. Definition at line 295 of file modules.cpp. +Default destructor destroys a module class. Definition at line 304 of file modules.cpp. .PP .nf -295 { } +304 { } .fi .SH "Member Function Documentation" .PP .SS "\fBVersion\fP Module::GetVersion ()\fC [virtual]\fP" .PP -Returns the version number of a Module. The method should return a \fBVersion\fP object with its version information assigned via \fBVersion::Version\fPDefinition at line 307 of file modules.cpp. +Returns the version number of a Module. The method should return a \fBVersion\fP object with its version information assigned via \fBVersion::Version\fPDefinition at line 316 of file modules.cpp. .PP References VF_VENDOR. .PP .nf -307 { return Version(1,0,0,0,VF_VENDOR); } +316 { return Version(1,0,0,0,VF_VENDOR); } .fi .SS "void Module::On005Numeric (std::string & output)\fC [virtual]\fP" .PP -Called when a 005 numeric is about to be output. The module should modify the 005 numeric if needed to indicate its features.Definition at line 319 of file modules.cpp. +Called when a 005 numeric is about to be output. The module should modify the 005 numeric if needed to indicate its features.Definition at line 328 of file modules.cpp. .PP .nf -319 { }; +328 { }; .fi .SS "int Module::OnAccessCheck (\fBuserrec\fP * source, \fBuserrec\fP * dest, \fBchanrec\fP * channel, int access_type)\fC [virtual]\fP" .PP @@ -307,312 +307,312 @@ Called before an action which requires a channel privilage check. This function .br .br - Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).Definition at line 316 of file modules.cpp. + Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).Definition at line 325 of file modules.cpp. .PP References ACR_DEFAULT. .PP .nf -316 { return ACR_DEFAULT; }; +325 { return ACR_DEFAULT; }; .fi .SS "int Module::OnAddBan (\fBuserrec\fP * source, \fBchanrec\fP * channel, std::string banmask)\fC [virtual]\fP" .PP -Called whenever a ban is added to a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being added.Definition at line 344 of file modules.cpp. +Called whenever a ban is added to a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being added.Definition at line 353 of file modules.cpp. .PP .nf -344 { return 0; }; +353 { return 0; }; .fi .SS "void Module::OnBackgroundTimer (time_t curtime)\fC [virtual]\fP" .PP -Called once every five seconds for background processing. This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.Definition at line 322 of file modules.cpp. +Called once every five seconds for background processing. This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.Definition at line 331 of file modules.cpp. .PP .nf -322 { }; +331 { }; .fi .SS "int Module::OnChangeLocalUserGECOS (\fBuserrec\fP * user, std::string newhost)\fC [virtual]\fP" .PP -Called whenever a change of a local users GECOS (fullname field) is attempted. return 1 to deny the name change, or 0 to allow it.Definition at line 336 of file modules.cpp. +Called whenever a change of a local users GECOS (fullname field) is attempted. return 1 to deny the name change, or 0 to allow it.Definition at line 345 of file modules.cpp. .PP .nf -336 { return 0; }; +345 { return 0; }; .fi .SS "int Module::OnChangeLocalUserHost (\fBuserrec\fP * user, std::string newhost)\fC [virtual]\fP" .PP -Called whenever a change of a local users displayed host is attempted. Return 1 to deny the host change, or 0 to allow it.Definition at line 335 of file modules.cpp. +Called whenever a change of a local users displayed host is attempted. Return 1 to deny the host change, or 0 to allow it.Definition at line 344 of file modules.cpp. .PP .nf -335 { return 0; }; +344 { return 0; }; .fi .SS "\fBstring_list\fP Module::OnChannelSync (\fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called during a netburst to sync channel data. This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 318 of file modules.cpp. +Called during a netburst to sync channel data. This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 327 of file modules.cpp. .PP References string_list. .PP .nf -318 { string_list empty; return empty; } +327 { string_list empty; return empty; } .fi .SS "int Module::OnCheckBan (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if banlist checks should go ahead or not. This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 333 of file modules.cpp. +Called whenever a user joins a channel, to determine if banlist checks should go ahead or not. This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 342 of file modules.cpp. .PP .nf -333 { return 0; }; +342 { return 0; }; .fi .SS "int Module::OnCheckInvite (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if invite checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.Definition at line 330 of file modules.cpp. +Called whenever a user joins a channel, to determine if invite checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.Definition at line 339 of file modules.cpp. .PP .nf -330 { return 0; }; +339 { return 0; }; .fi .SS "int Module::OnCheckKey (\fBuserrec\fP * user, \fBchanrec\fP * chan, std::string keygiven)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if key checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 331 of file modules.cpp. +Called whenever a user joins a channel, to determine if key checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 340 of file modules.cpp. .PP .nf -331 { return 0; }; +340 { return 0; }; .fi .SS "int Module::OnCheckLimit (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if channel limit checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 332 of file modules.cpp. +Called whenever a user joins a channel, to determine if channel limit checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 341 of file modules.cpp. .PP .nf -332 { return 0; }; +341 { return 0; }; .fi .SS "bool Module::OnCheckReady (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called to check if a user who is connecting can now be allowed to register If any modules return false for this function, the user is held in the waiting state until all modules return true. For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.Definition at line 325 of file modules.cpp. +Called to check if a user who is connecting can now be allowed to register If any modules return false for this function, the user is held in the waiting state until all modules return true. For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.Definition at line 334 of file modules.cpp. .PP .nf -325 { return true; }; +334 { return true; }; .fi .SS "int Module::OnDelBan (\fBuserrec\fP * source, \fBchanrec\fP * channel, std::string banmask)\fC [virtual]\fP" .PP -Called whenever a ban is removed from a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.Definition at line 345 of file modules.cpp. +Called whenever a ban is removed from a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.Definition at line 354 of file modules.cpp. .PP .nf -345 { return 0; }; +354 { return 0; }; .fi .SS "void Module::OnEvent (\fBEvent\fP * event)\fC [virtual]\fP" .PP -Called whenever an \fBEvent\fP class is sent to all module by another module. Please see the documentation of \fBEvent::Send()\fP for further information. The \fBEvent\fP sent can always be assumed to be non-NULL, you should *always* check the value of \fBEvent::GetEventID()\fP before doing anything to the event data, and you should *not* change the event data in any way!Definition at line 339 of file modules.cpp. +Called whenever an \fBEvent\fP class is sent to all module by another module. Please see the documentation of \fBEvent::Send()\fP for further information. The \fBEvent\fP sent can always be assumed to be non-NULL, you should *always* check the value of \fBEvent::GetEventID()\fP before doing anything to the event data, and you should *not* change the event data in any way!Definition at line 348 of file modules.cpp. .PP .nf -339 { return; }; +348 { return; }; .fi .SS "int Module::OnExtendedMode (\fBuserrec\fP * user, void * target, char modechar, int type, bool mode_on, \fBstring_list\fP & params)\fC [virtual]\fP" .PP -Called whenever an extended mode is to be processed. The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with \fBServer::AddExtendedMode\fP If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.Definition at line 306 of file modules.cpp. +Called whenever an extended mode is to be processed. The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with \fBServer::AddExtendedMode\fP If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.Definition at line 315 of file modules.cpp. .PP .nf -306 { return false; } +315 { return false; } .fi .SS "void Module::OnGlobalConnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user connects, anywhere on the network. This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.Definition at line 343 of file modules.cpp. +Called whenever a user connects, anywhere on the network. This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.Definition at line 352 of file modules.cpp. .PP .nf -343 { }; +352 { }; .fi .SS "void Module::OnGlobalOper (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user is given usermode +o, anywhere on the network. You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.Definition at line 342 of file modules.cpp. +Called whenever a user is given usermode +o, anywhere on the network. You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.Definition at line 351 of file modules.cpp. .PP .nf -342 { }; +351 { }; .fi .SS "void Module::OnInfo (\fBuserrec\fP * user)\fC [virtual]\fP" .PP Called whenever a user types /INFO. The userrec will contain the information of the user who typed the command. Modules may use this method to output their own credits in /INFO (which is the ircd's version of an about box). It is purposefully not possible to modify any info that has already been output, or halt the list. You must write a 371 numeric to the user, containing your info in the following format: .PP - :information hereDefinition at line 309 of file modules.cpp. + :information hereDefinition at line 318 of file modules.cpp. .PP .nf -309 { }; +318 { }; .fi .SS "int Module::OnKill (\fBuserrec\fP * source, \fBuserrec\fP * dest, std::string reason)\fC [virtual]\fP" .PP -Called when a client is disconnected by KILL. If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!Definition at line 320 of file modules.cpp. +Called when a client is disconnected by KILL. If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!Definition at line 329 of file modules.cpp. .PP .nf -320 { return 0; }; +329 { return 0; }; .fi .SS "void Module::OnLoadModule (\fBModule\fP * mod, std::string name)\fC [virtual]\fP" .PP -Called whenever a module is loaded. mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded 'm_killwidgets.so' with 'm_makewidgets.so'. It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).Definition at line 321 of file modules.cpp. +Called whenever a module is loaded. mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded 'm_killwidgets.so' with 'm_makewidgets.so'. It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).Definition at line 330 of file modules.cpp. .PP .nf -321 { }; +330 { }; .fi .SS "int Module::OnLocalTopicChange (\fBuserrec\fP * user, \fBchanrec\fP * chan, std::string topic)\fC [virtual]\fP" .PP -Called whenever a topic is changed by a local user. Return 1 to deny the topic change, or 0 to allow it.Definition at line 337 of file modules.cpp. +Called whenever a topic is changed by a local user. Return 1 to deny the topic change, or 0 to allow it.Definition at line 346 of file modules.cpp. .PP .nf -337 { return 0; }; +346 { return 0; }; .fi .SS "int Module::OnMeshToken (char token, \fBstring_list\fP params, \fBserverrec\fP * source, \fBserverrec\fP * reply, std::string tcp_host, std::string ipaddr, int port)\fC [virtual]\fP" .PP -Called whenever an unknown token is received in a server to server link. The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.Definition at line 338 of file modules.cpp. +Called whenever an unknown token is received in a server to server link. The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.Definition at line 347 of file modules.cpp. .PP .nf -338 { return 0; }; +347 { return 0; }; .fi .SS "void Module::OnOper (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user opers locally. The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.Definition at line 308 of file modules.cpp. +Called whenever a user opers locally. The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.Definition at line 317 of file modules.cpp. .PP .nf -308 { }; +317 { }; .fi .SS "int Module::OnOperCompare (std::string password, std::string input)\fC [virtual]\fP" .PP -Called whenever an oper password is to be compared to what a user has input. The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.Definition at line 341 of file modules.cpp. +Called whenever an oper password is to be compared to what a user has input. The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.Definition at line 350 of file modules.cpp. .PP .nf -341 { return 0; }; +350 { return 0; }; .fi .SS "void Module::OnPacketReceive (std::string & data, std::string serv)\fC [virtual]\fP" .PP -Called after a packet is received from another irc server. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.Definition at line 302 of file modules.cpp. +Called after a packet is received from another irc server. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.Definition at line 311 of file modules.cpp. .PP .nf -302 { } +311 { } .fi .SS "void Module::OnPacketTransmit (std::string & data, std::string serv)\fC [virtual]\fP" .PP -Called before a packet is transmitted across the irc network between two irc servers. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.Definition at line 301 of file modules.cpp. +Called before a packet is transmitted across the irc network between two irc servers. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.Definition at line 310 of file modules.cpp. .PP .nf -301 { } +310 { } .fi .SS "int Module::OnPreCommand (std::string command, char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever any command is about to be executed. This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using \fBServer::QuitUser\fP) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)Definition at line 324 of file modules.cpp. +Called whenever any command is about to be executed. This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using \fBServer::QuitUser\fP) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)Definition at line 333 of file modules.cpp. .PP .nf -324 { return 0; }; +333 { return 0; }; .fi .SS "int Module::OnRawMode (\fBuserrec\fP * user, \fBchanrec\fP * chan, char mode, std::string param, bool adding, int pcnt)\fC [virtual]\fP" .PP -Called whenever a mode character is processed. Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!Definition at line 329 of file modules.cpp. +Called whenever a mode character is processed. Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!Definition at line 338 of file modules.cpp. .PP .nf -329 { return 0; }; +338 { return 0; }; .fi .SS "void Module::OnRawSocketAccept (int fd, std::string ip, int localport)\fC [virtual]\fP" .PP -Called immediately after any connection is accepted. This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.Definition at line 346 of file modules.cpp. +Called immediately after any connection is accepted. This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.Definition at line 355 of file modules.cpp. .PP .nf -346 { }; +355 { }; .fi .SS "void Module::OnRawSocketClose (int fd)\fC [virtual]\fP" .PP -Called immediately before any socket is closed. When this event is called, shutdown() has not yet been called on the socket.Definition at line 348 of file modules.cpp. +Called immediately before any socket is closed. When this event is called, shutdown() has not yet been called on the socket.Definition at line 357 of file modules.cpp. .PP .nf -348 { }; +357 { }; .fi .SS "int Module::OnRawSocketRead (int fd, char * buffer, unsigned int count, int & readresult)\fC [virtual]\fP" .PP -Called immediately before any read() operation on a client socket in the core. This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.Definition at line 349 of file modules.cpp. +Called immediately before any read() operation on a client socket in the core. This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.Definition at line 358 of file modules.cpp. .PP .nf -349 { return 0; }; +358 { return 0; }; .fi .SS "int Module::OnRawSocketWrite (int fd, char * buffer, int count)\fC [virtual]\fP" .PP -Called immediately before any write() operation on a user's socket in the core. Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().Definition at line 347 of file modules.cpp. +Called immediately before any write() operation on a user's socket in the core. Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().Definition at line 356 of file modules.cpp. .PP .nf -347 { return 0; }; +356 { return 0; }; .fi .SS "void Module::OnRehash ()\fC [virtual]\fP" .PP -Called on rehash. This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.Definition at line 303 of file modules.cpp. +Called on rehash. This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.Definition at line 312 of file modules.cpp. .PP .nf -303 { } +312 { } .fi .SS "char * Module::OnRequest (\fBRequest\fP * request)\fC [virtual]\fP" .PP -Called whenever a \fBRequest\fP class is sent to your module by another module. Please see the documentation of \fBRequest::Send()\fP for further information. The \fBRequest\fP sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).Definition at line 340 of file modules.cpp. +Called whenever a \fBRequest\fP class is sent to your module by another module. Please see the documentation of \fBRequest::Send()\fP for further information. The \fBRequest\fP sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).Definition at line 349 of file modules.cpp. .PP Referenced by Request::Send(). .PP .nf -340 { return NULL; }; +349 { return NULL; }; .fi .SS "void Module::OnSendList (\fBuserrec\fP * user, \fBchanrec\fP * channel, char mode)\fC [virtual]\fP" .PP -Called whenever a list is needed for a listmode. For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.Definition at line 323 of file modules.cpp. +Called whenever a list is needed for a listmode. For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.Definition at line 332 of file modules.cpp. .PP .nf -323 { }; +332 { }; .fi .SS "void Module::OnServerRaw (std::string & raw, bool inbound, \fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a raw command is transmitted or received. This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter 'raw'. If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.Definition at line 304 of file modules.cpp. +Called when a raw command is transmitted or received. This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter 'raw'. If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.Definition at line 313 of file modules.cpp. .PP .nf -304 { } +313 { } .fi .SS "void Module::OnStats (char symbol)\fC [virtual]\fP" .PP -Called on all /STATS commands This method is triggered for all /STATS use, including stats symbols handled by the core. Definition at line 334 of file modules.cpp. +Called on all /STATS commands This method is triggered for all /STATS use, including stats symbols handled by the core. Definition at line 343 of file modules.cpp. .PP .nf -334 { }; +343 { }; .fi .SS "void Module::OnUserConnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a user connects. The details of the connecting user are available to you in the parameter userrec *userDefinition at line 296 of file modules.cpp. +Called when a user connects. The details of the connecting user are available to you in the parameter userrec *userDefinition at line 305 of file modules.cpp. .PP .nf -296 { } +305 { } .fi .SS "void Module::OnUserDisconnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user's socket is closed. The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.Definition at line 298 of file modules.cpp. +Called whenever a user's socket is closed. The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.Definition at line 307 of file modules.cpp. .PP .nf -298 { } +307 { } .fi .SS "void Module::OnUserJoin (\fBuserrec\fP * user, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called when a user joins a channel. The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channelDefinition at line 299 of file modules.cpp. +Called when a user joins a channel. The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channelDefinition at line 308 of file modules.cpp. .PP .nf -299 { } +308 { } .fi .SS "void Module::OnUserKick (\fBuserrec\fP * source, \fBuserrec\fP * user, \fBchanrec\fP * chan, std::string reason)\fC [virtual]\fP" .PP -Called whenever a user is kicked. If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use \fBModule::OnUserPreKick\fP instead of this method.Definition at line 328 of file modules.cpp. +Called whenever a user is kicked. If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use \fBModule::OnUserPreKick\fP instead of this method.Definition at line 337 of file modules.cpp. .PP .nf -328 { }; +337 { }; .fi .SS "void Module::OnUserPart (\fBuserrec\fP * user, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called when a user parts a channel. The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channelDefinition at line 300 of file modules.cpp. +Called when a user parts a channel. The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channelDefinition at line 309 of file modules.cpp. .PP .nf -300 { } +309 { } .fi .SS "void Module::OnUserPostNick (\fBuserrec\fP * user, std::string oldnick)\fC [virtual]\fP" .PP -Called after any nickchange, local or remote. This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this. Definition at line 315 of file modules.cpp. +Called after any nickchange, local or remote. This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this. Definition at line 324 of file modules.cpp. .PP .nf -315 { }; +324 { }; .fi .SS "int Module::OnUserPreInvite (\fBuserrec\fP * source, \fBuserrec\fP * dest, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called whenever a user is about to invite another user into a channel, before any processing is done. Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.Definition at line 311 of file modules.cpp. +Called whenever a user is about to invite another user into a channel, before any processing is done. Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.Definition at line 320 of file modules.cpp. .PP .nf -311 { return 0; }; +320 { return 0; }; .fi .SS "int Module::OnUserPreJoin (\fBuserrec\fP * user, \fBchanrec\fP * chan, const char * cname)\fC [virtual]\fP" .PP @@ -620,68 +620,68 @@ Called whenever a user is about to join a channel, before any processing is done .PP IMPORTANT NOTE! .PP -If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.Definition at line 305 of file modules.cpp. +If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.Definition at line 314 of file modules.cpp. .PP .nf -305 { return 0; } +314 { return 0; } .fi .SS "int Module::OnUserPreKick (\fBuserrec\fP * source, \fBuserrec\fP * user, \fBchanrec\fP * chan, std::string reason)\fC [virtual]\fP" .PP -Called whenever a user is about to be kicked. Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. Definition at line 327 of file modules.cpp. +Called whenever a user is about to be kicked. Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. Definition at line 336 of file modules.cpp. .PP .nf -327 { return 0; }; +336 { return 0; }; .fi .SS "int Module::OnUserPreMessage (\fBuserrec\fP * user, void * dest, int target_type, std::string & text)\fC [virtual]\fP" .PP -Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.Definition at line 312 of file modules.cpp. +Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.Definition at line 321 of file modules.cpp. .PP .nf -312 { return 0; }; +321 { return 0; }; .fi .SS "int Module::OnUserPreNick (\fBuserrec\fP * user, std::string newnick)\fC [virtual]\fP" .PP -Called before any nickchange, local or remote. This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.Definition at line 314 of file modules.cpp. +Called before any nickchange, local or remote. This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.Definition at line 323 of file modules.cpp. .PP .nf -314 { return 0; }; +323 { return 0; }; .fi .SS "int Module::OnUserPreNotice (\fBuserrec\fP * user, void * dest, int target_type, std::string & text)\fC [virtual]\fP" .PP -Called whenever a user is about to NOTICE A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.Definition at line 313 of file modules.cpp. +Called whenever a user is about to NOTICE A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.Definition at line 322 of file modules.cpp. .PP .nf -313 { return 0; }; +322 { return 0; }; .fi .SS "void Module::OnUserQuit (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a user quits. The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.Definition at line 297 of file modules.cpp. +Called when a user quits. The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.Definition at line 306 of file modules.cpp. .PP .nf -297 { } +306 { } .fi .SS "void Module::OnUserRegister (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user is about to register their connection (e.g. before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.Definition at line 326 of file modules.cpp. +Called whenever a user is about to register their connection (e.g. before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.Definition at line 335 of file modules.cpp. .PP .nf -326 { }; +335 { }; .fi .SS "\fBstring_list\fP Module::OnUserSync (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called during a netburst to sync user data. This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 317 of file modules.cpp. +Called during a netburst to sync user data. This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 326 of file modules.cpp. .PP References string_list. .PP .nf -317 { string_list empty; return empty; } +326 { string_list empty; return empty; } .fi .SS "void Module::OnWhois (\fBuserrec\fP * source, \fBuserrec\fP * dest)\fC [virtual]\fP" .PP -Called whenever a /WHOIS is performed on a local user. The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.Definition at line 310 of file modules.cpp. +Called whenever a /WHOIS is performed on a local user. The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.Definition at line 319 of file modules.cpp. .PP .nf -310 { }; +319 { }; .fi diff --git a/docs/man/man3/ModuleFactory.3 b/docs/man/man3/ModuleFactory.3 index be57b64c8..779bd0e86 100644 --- a/docs/man/man3/ModuleFactory.3 +++ b/docs/man/man3/ModuleFactory.3 @@ -1,4 +1,4 @@ -.TH "ModuleFactory" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModuleFactory" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ModuleMessage.3 b/docs/man/man3/ModuleMessage.3 index 63b7dba85..4d4080144 100644 --- a/docs/man/man3/ModuleMessage.3 +++ b/docs/man/man3/ModuleMessage.3 @@ -1,4 +1,4 @@ -.TH "ModuleMessage" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModuleMessage" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/QLine.3 b/docs/man/man3/QLine.3 index 3d9dbdc20..9e71ad7a0 100644 --- a/docs/man/man3/QLine.3 +++ b/docs/man/man3/QLine.3 @@ -1,4 +1,4 @@ -.TH "QLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "QLine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Request.3 b/docs/man/man3/Request.3 index 2f7487d15..f836f2662 100644 --- a/docs/man/man3/Request.3 +++ b/docs/man/man3/Request.3 @@ -1,4 +1,4 @@ -.TH "Request" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Request" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -63,65 +63,65 @@ Definition at line 154 of file modules.h. .PP .SS "Request::Request (char * anydata, \fBModule\fP * src, \fBModule\fP * dst)" .PP -Create a new Request. Definition at line 240 of file modules.cpp. +Create a new Request. Definition at line 249 of file modules.cpp. .PP .nf -240 : data(anydata), source(src), dest(dst) { }; +249 : data(anydata), source(src), dest(dst) { }; .fi .SH "Member Function Documentation" .PP .SS "char * Request::GetData ()" .PP -Fetch the Request data. Definition at line 242 of file modules.cpp. +Fetch the Request data. Definition at line 251 of file modules.cpp. .PP References data. .PP .nf -243 { -244 return this->data; -245 } +252 { +253 return this->data; +254 } .fi .SS "\fBModule\fP * Request::GetDest ()" .PP -Fetch the request destination (should be 'this' in the receiving module). Definition at line 252 of file modules.cpp. +Fetch the request destination (should be 'this' in the receiving module). Definition at line 261 of file modules.cpp. .PP References dest. .PP .nf -253 { -254 return this->dest; -255 } +262 { +263 return this->dest; +264 } .fi .SS "\fBModule\fP * Request::GetSource ()" .PP -Fetch the request source. Definition at line 247 of file modules.cpp. +Fetch the request source. Definition at line 256 of file modules.cpp. .PP References source. .PP .nf -248 { -249 return this->source; -250 } +257 { +258 return this->source; +259 } .fi .SS "char * Request::Send ()\fC [virtual]\fP" .PP Send the Request. Upon returning the result will be arbitary data returned by the module you sent the request to. It is up to your module to know what this data is and how to deal with it. Implements \fBModuleMessage\fP. .PP -Definition at line 257 of file modules.cpp. +Definition at line 266 of file modules.cpp. .PP References dest, and Module::OnRequest(). .PP .nf -258 { -259 if (this->dest) -260 { -261 return dest->OnRequest(this); -262 } -263 else -264 { -265 return NULL; -266 } -267 } +267 { +268 if (this->dest) +269 { +270 return dest->OnRequest(this); +271 } +272 else +273 { +274 return NULL; +275 } +276 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/Server.3 b/docs/man/man3/Server.3 index 93daa2cc9..87891e19e 100644 --- a/docs/man/man3/Server.3 +++ b/docs/man/man3/Server.3 @@ -1,4 +1,4 @@ -.TH "Server" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Server" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -271,19 +271,19 @@ Definition at line 694 of file modules.h. .PP .SS "Server::Server ()" .PP -Default constructor. Creates a Server object.Definition at line 355 of file modules.cpp. +Default constructor. Creates a Server object.Definition at line 364 of file modules.cpp. .PP .nf -356 { -357 } +365 { +366 } .fi .SS "Server::~\fBServer\fP ()\fC [virtual]\fP" .PP -Default destructor. Destroys a Server object.Definition at line 359 of file modules.cpp. +Default destructor. Destroys a Server object.Definition at line 368 of file modules.cpp. .PP .nf -360 { -361 } +369 { +370 } .fi .SH "Member Function Documentation" .PP @@ -293,25 +293,25 @@ Adds a command to the command table. This allows modules to add extra commands i .PP typedef void (handlerfunc) (char**, int, userrec*); ... void \fBhandle_kill(char **parameters, int pcnt, userrec *user)\fP .PP -When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. 'm_blarp.so'. If you place the wrong identifier here, you can cause crashes if your module is unloaded.Definition at line 428 of file modules.cpp. +When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. 'm_blarp.so'. If you place the wrong identifier here, you can cause crashes if your module is unloaded.Definition at line 437 of file modules.cpp. .PP References createcommand(). .PP .nf -429 { -430 createcommand(cmd,f,flags,minparams,source); -431 } +438 { +439 createcommand(cmd,f,flags,minparams,source); +440 } .fi .SS "void Server::AddELine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a E-line The E-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 679 of file modules.cpp. +Adds a E-line The E-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 699 of file modules.cpp. .PP References add_eline(), and duration(). .PP .nf -680 { -681 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -682 } +700 { +701 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +702 } .fi .SS "bool Server::AddExtendedListMode (char modechar)\fC [virtual]\fP" .PP @@ -325,549 +325,549 @@ Adds an extended mode letter which is parsed by a module and handled in a list f .PP (4) The mode and its parameter are NOT stored in the channels modes structure .PP -It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.Definition at line 596 of file modules.cpp. +It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.Definition at line 605 of file modules.cpp. .PP References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL. .PP .nf -597 { -598 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); -599 if (res) -600 ModeMakeList(modechar); -601 return res; -602 } +606 { +607 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); +608 if (res) +609 ModeMakeList(modechar); +610 return res; +611 } .fi .SS "bool Server::AddExtendedMode (char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)\fC [virtual]\fP" .PP -Adds an extended mode letter which is parsed by a module. This allows modules to add extra mode letters, e.g. +x for hostcloak. the 'type' parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.Definition at line 568 of file modules.cpp. +Adds an extended mode letter which is parsed by a module. This allows modules to add extra mode letters, e.g. +x for hostcloak. the 'type' parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.Definition at line 577 of file modules.cpp. .PP References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. .PP .nf -569 { -570 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) -571 { -572 if (type == MT_SERVER) -573 { -574 log(DEBUG,'*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion'); -575 return false; -576 } -577 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) -578 { -579 log(DEBUG,'*** API ERROR *** Parameters on MT_CLIENT modes are not supported'); -580 return false; -581 } -582 if ((params_when_on>1) || (params_when_off>1)) -583 { -584 log(DEBUG,'*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported'); -585 return false; -586 } -587 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); -588 } -589 else -590 { -591 log(DEBUG,'*** API ERROR *** Muppet modechar detected.'); -592 } -593 return false; -594 } +578 { +579 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) +580 { +581 if (type == MT_SERVER) +582 { +583 log(DEBUG,'*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion'); +584 return false; +585 } +586 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) +587 { +588 log(DEBUG,'*** API ERROR *** Parameters on MT_CLIENT modes are not supported'); +589 return false; +590 } +591 if ((params_when_on>1) || (params_when_off>1)) +592 { +593 log(DEBUG,'*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported'); +594 return false; +595 } +596 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); +597 } +598 else +599 { +600 log(DEBUG,'*** API ERROR *** Muppet modechar detected.'); +601 } +602 return false; +603 } .fi .SS "void Server::AddGLine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.Definition at line 659 of file modules.cpp. +Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.Definition at line 679 of file modules.cpp. .PP References add_gline(), and duration(). .PP .nf -660 { -661 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -662 } +680 { +681 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +682 } .fi .SS "void Server::AddKLine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a K-line The K-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 674 of file modules.cpp. +Adds a K-line The K-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 694 of file modules.cpp. .PP References add_kline(), and duration(). .PP .nf -675 { -676 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -677 } +695 { +696 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +697 } .fi .SS "void Server::AddQLine (long duration, std::string source, std::string reason, std::string nickname)\fC [virtual]\fP" .PP -Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 664 of file modules.cpp. +Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 684 of file modules.cpp. .PP References add_qline(), and duration(). .PP .nf -665 { -666 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); -667 } +685 { +686 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); +687 } .fi .SS "void Server::AddZLine (long duration, std::string source, std::string reason, std::string ipaddr)\fC [virtual]\fP" .PP -Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 669 of file modules.cpp. +Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 689 of file modules.cpp. .PP References add_zline(), and duration(). .PP .nf -670 { -671 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); -672 } +690 { +691 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); +692 } .fi .SS "long Server::CalcDuration (std::string duration)\fC [virtual]\fP" .PP -Calculates a duration This method will take a string containing a formatted duration (e.g. '1w2d') and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.Definition at line 709 of file modules.cpp. +Calculates a duration This method will take a string containing a formatted duration (e.g. '1w2d') and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.Definition at line 729 of file modules.cpp. .PP References duration(). .PP .nf -710 { -711 return duration(delta.c_str()); -712 } +730 { +731 return duration(delta.c_str()); +732 } .fi .SS "void Server::CallCommandHandler (std::string commandname, char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP Calls the handler for a command, either implemented by the core or by another module. You can use this function to trigger other commands in the ircd, such as PRIVMSG, JOIN, KICK etc, or even as a method of callback. By defining command names that are untypeable for users on irc (e.g. those which contain a or .br -) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih \fBAddCommand()\fP. The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.Definition at line 418 of file modules.cpp. +) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih \fBAddCommand()\fP. The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.Definition at line 427 of file modules.cpp. .PP .nf -419 { -420 call_handler(commandname.c_str(),parameters,pcnt,user); -421 } +428 { +429 call_handler(commandname.c_str(),parameters,pcnt,user); +430 } .fi .SS "void Server::ChangeGECOS (\fBuserrec\fP * user, std::string gecos)\fC [virtual]\fP" .PP -Change GECOS (fullname) of a user. You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 511 of file modules.cpp. +Change GECOS (fullname) of a user. You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 520 of file modules.cpp. .PP References ChangeName(). .PP .nf -512 { -513 ChangeName(user,gecos.c_str()); -514 } +521 { +522 ChangeName(user,gecos.c_str()); +523 } .fi .SS "void Server::ChangeHost (\fBuserrec\fP * user, std::string host)\fC [virtual]\fP" .PP -Change displayed hostname of a user. You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 506 of file modules.cpp. +Change displayed hostname of a user. You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 515 of file modules.cpp. .PP References ChangeDisplayedHost(). .PP .nf -507 { -508 ChangeDisplayedHost(user,host.c_str()); -509 } +516 { +517 ChangeDisplayedHost(user,host.c_str()); +518 } .fi .SS "void Server::ChangeUserNick (\fBuserrec\fP * user, std::string nickname)\fC [virtual]\fP" .PP -Forces a user nickchange. This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.Definition at line 403 of file modules.cpp. +Forces a user nickchange. This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.Definition at line 412 of file modules.cpp. .PP .nf -404 { -405 force_nickchange(user,nickname.c_str()); -406 } +413 { +414 force_nickchange(user,nickname.c_str()); +415 } .fi .SS "std::string Server::ChanMode (\fBuserrec\fP * User, \fBchanrec\fP * Chan)\fC [virtual]\fP" .PP -Attempts to look up a user's privilages on a channel. This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.Definition at line 536 of file modules.cpp. +Attempts to look up a user's privilages on a channel. This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.Definition at line 545 of file modules.cpp. .PP References cmode(). .PP .nf -537 { -538 return cmode(User,Chan); -539 } +546 { +547 return cmode(User,Chan); +548 } .fi .SS "bool Server::CommonChannels (\fBuserrec\fP * u1, \fBuserrec\fP * u2)\fC [virtual]\fP" .PP -Returns true if two users share a common channel. This method is used internally by the NICK and QUIT commands, and the \fBServer::SendCommon\fP method.Definition at line 484 of file modules.cpp. +Returns true if two users share a common channel. This method is used internally by the NICK and QUIT commands, and the \fBServer::SendCommon\fP method.Definition at line 493 of file modules.cpp. .PP References common_channels(). .PP .nf -485 { -486 return (common_channels(u1,u2) != 0); -487 } +494 { +495 return (common_channels(u1,u2) != 0); +496 } .fi .SS "int Server::CountUsers (\fBchanrec\fP * c)\fC [virtual]\fP" .PP -Returns a count of the number of users on a channel. This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.Definition at line 604 of file modules.cpp. +Returns a count of the number of users on a channel. This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.Definition at line 613 of file modules.cpp. .PP .nf -605 { -606 return usercount(c); -607 } +614 { +615 return usercount(c); +616 } .fi .SS "bool Server::DelELine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a local E-Line. Definition at line 704 of file modules.cpp. +Deletes a local E-Line. Definition at line 724 of file modules.cpp. .PP References del_eline(). .PP .nf -705 { -706 del_eline(hostmask.c_str()); -707 } +725 { +726 del_eline(hostmask.c_str()); +727 } .fi .SS "bool Server::DelGLine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a G-Line from all servers on the mesh. Definition at line 684 of file modules.cpp. +Deletes a G-Line from all servers on the mesh. Definition at line 704 of file modules.cpp. .PP References del_gline(). .PP .nf -685 { -686 del_gline(hostmask.c_str()); -687 } +705 { +706 del_gline(hostmask.c_str()); +707 } .fi .SS "bool Server::DelKLine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a local K-Line. Definition at line 699 of file modules.cpp. +Deletes a local K-Line. Definition at line 719 of file modules.cpp. .PP References del_kline(). .PP .nf -700 { -701 del_kline(hostmask.c_str()); -702 } +720 { +721 del_kline(hostmask.c_str()); +722 } .fi .SS "bool Server::DelQLine (std::string nickname)\fC [virtual]\fP" .PP -Deletes a Q-Line from all servers on the mesh. Definition at line 689 of file modules.cpp. +Deletes a Q-Line from all servers on the mesh. Definition at line 709 of file modules.cpp. .PP References del_qline(). .PP .nf -690 { -691 del_qline(nickname.c_str()); -692 } +710 { +711 del_qline(nickname.c_str()); +712 } .fi .SS "bool Server::DelZLine (std::string ipaddr)\fC [virtual]\fP" .PP -Deletes a Z-Line from all servers on the mesh. Definition at line 694 of file modules.cpp. +Deletes a Z-Line from all servers on the mesh. Definition at line 714 of file modules.cpp. .PP References del_zline(). .PP .nf -695 { -696 del_zline(ipaddr.c_str()); -697 } +715 { +716 del_zline(ipaddr.c_str()); +717 } .fi .SS "\fBchanrec\fP * Server::FindChannel (std::string channel)\fC [virtual]\fP" .PP -Attempts to look up a channel and return a pointer to it. This function will return NULL if the channel does not exist.Definition at line 531 of file modules.cpp. +Attempts to look up a channel and return a pointer to it. This function will return NULL if the channel does not exist.Definition at line 540 of file modules.cpp. .PP .nf -532 { -533 return FindChan(channel.c_str()); -534 } +541 { +542 return FindChan(channel.c_str()); +543 } .fi .SS "\fBuserrec\fP * Server::FindDescriptor (int socket)\fC [virtual]\fP" .PP -Attempts to look up a nick using the file descriptor associated with that nick. This function will return NULL if the file descriptor is not associated with a valid user.Definition at line 526 of file modules.cpp. +Attempts to look up a nick using the file descriptor associated with that nick. This function will return NULL if the file descriptor is not associated with a valid user.Definition at line 535 of file modules.cpp. .PP References fd_ref_table. .PP .nf -527 { -528 return (socket < 65536 ? fd_ref_table[socket] : NULL); -529 } +536 { +537 return (socket < 65536 ? fd_ref_table[socket] : NULL); +538 } .fi .SS "\fBModule\fP * Server::FindModule (std::string name)\fC [virtual]\fP" .PP -This function finds a module by name. You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.Definition at line 787 of file modules.cpp. +This function finds a module by name. You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.Definition at line 807 of file modules.cpp. .PP References MODCOUNT, module_names, and modules. .PP .nf -788 { -789 for (int i = 0; i <= MODCOUNT; i++) -790 { -791 if (module_names[i] == name) -792 { -793 return modules[i]; -794 } -795 } -796 return NULL; -797 } +808 { +809 for (int i = 0; i <= MODCOUNT; i++) +810 { +811 if (module_names[i] == name) +812 { +813 return modules[i]; +814 } +815 } +816 return NULL; +817 } .fi .SS "\fBuserrec\fP * Server::FindNick (std::string nick)\fC [virtual]\fP" .PP -Attempts to look up a nick and return a pointer to it. This function will return NULL if the nick does not exist.Definition at line 521 of file modules.cpp. +Attempts to look up a nick and return a pointer to it. This function will return NULL if the nick does not exist.Definition at line 530 of file modules.cpp. .PP .nf -522 { -523 return Find(nick); -524 } +531 { +532 return Find(nick); +533 } .fi .SS "\fBAdmin\fP Server::GetAdmin ()\fC [virtual]\fP" .PP -Returns the information of the server as returned by the /ADMIN command. See the \fBAdmin\fP class for further information of the return value. The members \fBAdmin::Nick\fP, \fBAdmin::Email\fP and \fBAdmin::Name\fP contain the information for the server where the module is loaded.Definition at line 561 of file modules.cpp. +Returns the information of the server as returned by the /ADMIN command. See the \fBAdmin\fP class for further information of the return value. The members \fBAdmin::Nick\fP, \fBAdmin::Email\fP and \fBAdmin::Name\fP contain the information for the server where the module is loaded.Definition at line 570 of file modules.cpp. .PP .nf -562 { -563 return Admin(getadminname(),getadminemail(),getadminnick()); -564 } +571 { +572 return Admin(getadminname(),getadminemail(),getadminnick()); +573 } .fi .SS "std::string Server::GetNetworkName ()\fC [virtual]\fP" .PP -Returns the network name, global to all linked servers. Definition at line 551 of file modules.cpp. +Returns the network name, global to all linked servers. Definition at line 560 of file modules.cpp. .PP .nf -552 { -553 return getnetworkname(); -554 } +561 { +562 return getnetworkname(); +563 } .fi .SS "std::string Server::GetServerDescription ()\fC [virtual]\fP" .PP -Returns the server description string of the local server. Definition at line 556 of file modules.cpp. +Returns the server description string of the local server. Definition at line 565 of file modules.cpp. .PP .nf -557 { -558 return getserverdesc(); -559 } +566 { +567 return getserverdesc(); +568 } .fi .SS "std::string Server::GetServerName ()\fC [virtual]\fP" .PP -Returns the server name of the server where the module is loaded. Definition at line 546 of file modules.cpp. +Returns the server name of the server where the module is loaded. Definition at line 555 of file modules.cpp. .PP .nf -547 { -548 return getservername(); -549 } +556 { +557 return getservername(); +558 } .fi .SS "\fBchanuserlist\fP Server::GetUsers (\fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Fetches the userlist of a channel. This function must be here and not a member of userrec or chanrec due to include constraints.Definition at line 391 of file modules.cpp. +Fetches the userlist of a channel. This function must be here and not a member of userrec or chanrec due to include constraints.Definition at line 400 of file modules.cpp. .PP References chanuserlist, chanrec::GetUsers(), and list. .PP .nf -392 { -393 chanuserlist userl; -394 userl.clear(); -395 std::vector *list = chan->GetUsers(); -396 for (std::vector::iterator i = list->begin(); i != list->end(); i++) -397 { -398 char* o = *i; -399 userl.push_back((userrec*)o); -400 } -401 return userl; -402 } +401 { +402 chanuserlist userl; +403 userl.clear(); +404 std::vector *list = chan->GetUsers(); +405 for (std::vector::iterator i = list->begin(); i != list->end(); i++) +406 { +407 char* o = *i; +408 userl.push_back((userrec*)o); +409 } +410 return userl; +411 } .fi .SS "bool Server::IsNick (std::string nick)\fC [virtual]\fP" .PP -Returns true if a nick is valid. Nicks for unregistered connections will return false.Definition at line 516 of file modules.cpp. +Returns true if a nick is valid. Nicks for unregistered connections will return false.Definition at line 525 of file modules.cpp. .PP References isnick(). .PP .nf -517 { -518 return (isnick(nick.c_str()) != 0); -519 } +526 { +527 return (isnick(nick.c_str()) != 0); +528 } .fi .SS "bool Server::IsOnChannel (\fBuserrec\fP * User, \fBchanrec\fP * Chan)\fC [virtual]\fP" .PP -Checks if a user is on a channel. This function will return true or false to indicate if user 'User' is on channel 'Chan'.Definition at line 541 of file modules.cpp. +Checks if a user is on a channel. This function will return true or false to indicate if user 'User' is on channel 'Chan'.Definition at line 550 of file modules.cpp. .PP References has_channel(). .PP .nf -542 { -543 return has_channel(User,Chan); -544 } +551 { +552 return has_channel(User,Chan); +553 } .fi .SS "bool Server::IsUlined (std::string server)\fC [virtual]\fP" .PP -Returns true if the servername you give is ulined. ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.Definition at line 413 of file modules.cpp. +Returns true if the servername you give is ulined. ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.Definition at line 422 of file modules.cpp. .PP References is_uline(). .PP .nf -414 { -415 return is_uline(server.c_str()); -416 } +423 { +424 return is_uline(server.c_str()); +425 } .fi .SS "bool Server::IsValidMask (std::string mask)\fC [virtual]\fP" .PP -Returns true if a nick!ident string is correctly formatted, false if otherwise. Definition at line 714 of file modules.cpp. +Returns true if a nick!ident string is correctly formatted, false if otherwise. Definition at line 734 of file modules.cpp. .PP .nf -715 { -716 const char* dest = mask.c_str(); -717 if (strchr(dest,'!')==0) -718 return false; -719 if (strchr(dest,'@')==0) -720 return false; -721 for (int i = 0; i < strlen(dest); i++) -722 if (dest[i] < 32) -723 return false; -724 for (int i = 0; i < strlen(dest); i++) -725 if (dest[i] > 126) -726 return false; -727 int c = 0; -728 for (int i = 0; i < strlen(dest); i++) -729 if (dest[i] == '!') -730 c++; -731 if (c>1) -732 return false; -733 c = 0; -734 for (int i = 0; i < strlen(dest); i++) -735 if (dest[i] == '@') -736 c++; -737 if (c>1) +735 { +736 const char* dest = mask.c_str(); +737 if (strchr(dest,'!')==0) 738 return false; -739 -740 return true; -741 } +739 if (strchr(dest,'@')==0) +740 return false; +741 for (int i = 0; i < strlen(dest); i++) +742 if (dest[i] < 32) +743 return false; +744 for (int i = 0; i < strlen(dest); i++) +745 if (dest[i] > 126) +746 return false; +747 int c = 0; +748 for (int i = 0; i < strlen(dest); i++) +749 if (dest[i] == '!') +750 c++; +751 if (c>1) +752 return false; +753 c = 0; +754 for (int i = 0; i < strlen(dest); i++) +755 if (dest[i] == '@') +756 c++; +757 if (c>1) +758 return false; +759 +760 return true; +761 } .fi .SS "\fBchanrec\fP * Server::JoinUserToChannel (\fBuserrec\fP * user, std::string cname, std::string key)\fC [virtual]\fP" .PP -Forces a user to join a channel. This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.Definition at line 381 of file modules.cpp. +Forces a user to join a channel. This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.Definition at line 390 of file modules.cpp. .PP .nf -382 { -383 return add_channel(user,cname.c_str(),key.c_str(),false); -384 } +391 { +392 return add_channel(user,cname.c_str(),key.c_str(),false); +393 } .fi .SS "void Server::Log (int level, std::string s)\fC [virtual]\fP" .PP -Writes a log string. This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.Definition at line 423 of file modules.cpp. +Writes a log string. This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.Definition at line 432 of file modules.cpp. .PP .nf -424 { -425 log(level,'%s',s.c_str()); -426 } +433 { +434 log(level,'%s',s.c_str()); +435 } .fi .SS "bool Server::MatchText (std::string sliteral, std::string spattern)\fC [virtual]\fP" .PP -Matches text against a glob pattern. Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.Definition at line 368 of file modules.cpp. +Matches text against a glob pattern. Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.Definition at line 377 of file modules.cpp. .PP .nf -369 { -370 char literal[MAXBUF],pattern[MAXBUF]; -371 strlcpy(literal,sliteral.c_str(),MAXBUF); -372 strlcpy(pattern,spattern.c_str(),MAXBUF); -373 return match(literal,pattern); -374 } +378 { +379 char literal[MAXBUF],pattern[MAXBUF]; +380 strlcpy(literal,sliteral.c_str(),MAXBUF); +381 strlcpy(pattern,spattern.c_str(),MAXBUF); +382 return match(literal,pattern); +383 } .fi .SS "bool Server::MeshCheckChan (\fBchanrec\fP * c, std::string servername)\fC [virtual]\fP" .PP -This function is used to check if any users on channel c are on server servername. This is used internally by PRIVMSG etc. You should not need to use it.Definition at line 769 of file modules.cpp. +This function is used to check if any users on channel c are on server servername. This is used internally by PRIVMSG etc. You should not need to use it.Definition at line 789 of file modules.cpp. .PP .nf -770 { -771 if (c) -772 { -773 return ChanAnyOnThisServer(c,(char*)servername.c_str()); -774 } -775 else return false; -776 } +790 { +791 if (c) +792 { +793 return ChanAnyOnThisServer(c,(char*)servername.c_str()); +794 } +795 else return false; +796 } .fi .SS "bool Server::MeshCheckCommon (\fBuserrec\fP * u, std::string servername)\fC [virtual]\fP" .PP -This function is used to check if user u has any channels in common with users on servername. This is used internally by \fBServer::MeshSendCommon\fP. You should very rarely need to use it.Definition at line 778 of file modules.cpp. +This function is used to check if user u has any channels in common with users on servername. This is used internally by \fBServer::MeshSendCommon\fP. You should very rarely need to use it.Definition at line 798 of file modules.cpp. .PP .nf -779 { -780 if (u) -781 { -782 return CommonOnThisServer(u,(char*)servername.c_str()); -783 } -784 else return false; -785 } +799 { +800 if (u) +801 { +802 return CommonOnThisServer(u,(char*)servername.c_str()); +803 } +804 else return false; +805 } .fi .SS "void Server::MeshSendAll (std::string text)\fC [virtual]\fP" .PP -Sends a line of text to all connected servers. If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.Definition at line 743 of file modules.cpp. +Sends a line of text to all connected servers. If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.Definition at line 763 of file modules.cpp. .PP .nf -744 { -745 NetSendToAll((char*)text.c_str()); -746 } +764 { +765 NetSendToAll((char*)text.c_str()); +766 } .fi .SS "void Server::MeshSendAllAlive (std::string text)\fC [virtual]\fP" .PP -This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable. Definition at line 754 of file modules.cpp. +This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable. Definition at line 774 of file modules.cpp. .PP .nf -755 { -756 NetSendToAllAlive((char*)text.c_str()); -757 } +775 { +776 NetSendToAllAlive((char*)text.c_str()); +777 } .fi .SS "void Server::MeshSendAllExcept (std::string target, std::string text)\fC [virtual]\fP" .PP -This function sends to all servers EXCEPT the one you specify. You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.Definition at line 764 of file modules.cpp. +This function sends to all servers EXCEPT the one you specify. You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.Definition at line 784 of file modules.cpp. .PP .nf -765 { -766 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); -767 } +785 { +786 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); +787 } .fi .SS "void Server::MeshSendCommon (\fBuserrec\fP * user, std::string text)\fC [virtual]\fP" .PP -This method sends a line of text to all servers who have users which share common channels with the user you provide. For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)Definition at line 748 of file modules.cpp. +This method sends a line of text to all servers who have users which share common channels with the user you provide. For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)Definition at line 768 of file modules.cpp. .PP .nf -749 { -750 if (user) -751 NetSendToCommon(user,(char*)text.c_str()); -752 } +769 { +770 if (user) +771 NetSendToCommon(user,(char*)text.c_str()); +772 } .fi .SS "void Server::MeshSendUnicast (std::string destination, std::string text)\fC [virtual]\fP" .PP -This function sends a line of text directly to a server. If the server is not directly routable at this time, the server attempts to route text through the mesh.Definition at line 759 of file modules.cpp. +This function sends a line of text directly to a server. If the server is not directly routable at this time, the server attempts to route text through the mesh.Definition at line 779 of file modules.cpp. .PP .nf -760 { -761 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); -762 } +780 { +781 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); +782 } .fi .SS "\fBchanrec\fP * Server::PartUserFromChannel (\fBuserrec\fP * user, std::string cname, std::string reason)\fC [virtual]\fP" .PP -Forces a user to part a channel. This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.Definition at line 386 of file modules.cpp. +Forces a user to part a channel. This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.Definition at line 395 of file modules.cpp. .PP .nf -387 { -388 return del_channel(user,cname.c_str(),reason.c_str(),false); -389 } +396 { +397 return del_channel(user,cname.c_str(),reason.c_str(),false); +398 } .fi .SS "bool Server::PseudoToUser (\fBuserrec\fP * alive, \fBuserrec\fP * zombie, std::string message)\fC [virtual]\fP" .PP -This user takes one user, and switches their file descriptor with another user, so that one user 'becomes' the other. The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.Definition at line 629 of file modules.cpp. +This user takes one user, and switches their file descriptor with another user, so that one user 'becomes' the other. The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.Definition at line 649 of file modules.cpp. .PP References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. .PP .nf -630 { -631 zombie->fd = alive->fd; -632 alive->fd = FD_MAGIC_NUMBER; -633 alive->ClearBuffer(); -634 Write(zombie->fd,':%s!%s@%s NICK %s',alive->nick,alive->ident,alive->host,zombie->nick); -635 kill_link(alive,message.c_str()); -636 fd_ref_table[zombie->fd] = zombie; -637 for (int i = 0; i != MAXCHANS; i++) -638 { -639 if (zombie->chans[i].channel != NULL) -640 { -641 if (zombie->chans[i].channel->name) -642 { -643 chanrec* Ptr = zombie->chans[i].channel; -644 WriteFrom(zombie->fd,zombie,'JOIN %s',Ptr->name); -645 if (Ptr->topicset) -646 { -647 WriteServ(zombie->fd,'332 %s %s :%s', zombie->nick, Ptr->name, Ptr->topic); -648 WriteServ(zombie->fd,'333 %s %s %s %d', zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); -649 } -650 userlist(zombie,Ptr); -651 WriteServ(zombie->fd,'366 %s %s :End of /NAMES list.', zombie->nick, Ptr->name); -652 -653 } -654 } -655 } -656 -657 } +650 { +651 zombie->fd = alive->fd; +652 alive->fd = FD_MAGIC_NUMBER; +653 alive->ClearBuffer(); +654 Write(zombie->fd,':%s!%s@%s NICK %s',alive->nick,alive->ident,alive->host,zombie->nick); +655 kill_link(alive,message.c_str()); +656 fd_ref_table[zombie->fd] = zombie; +657 for (int i = 0; i != MAXCHANS; i++) +658 { +659 if (zombie->chans[i].channel != NULL) +660 { +661 if (zombie->chans[i].channel->name) +662 { +663 chanrec* Ptr = zombie->chans[i].channel; +664 WriteFrom(zombie->fd,zombie,'JOIN %s',Ptr->name); +665 if (Ptr->topicset) +666 { +667 WriteServ(zombie->fd,'332 %s %s :%s', zombie->nick, Ptr->name, Ptr->topic); +668 WriteServ(zombie->fd,'333 %s %s %s %d', zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); +669 } +670 userlist(zombie,Ptr); +671 WriteServ(zombie->fd,'366 %s %s :End of /NAMES list.', zombie->nick, Ptr->name); +672 +673 } +674 } +675 } +676 +677 } .fi .SS "void Server::QuitUser (\fBuserrec\fP * user, std::string reason)\fC [virtual]\fP" .PP @@ -875,71 +875,71 @@ Forces a user to quit with the specified reason. To the user, it will appear as .PP WARNING! .PP -Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.Definition at line 408 of file modules.cpp. +Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.Definition at line 417 of file modules.cpp. .PP .nf -409 { -410 kill_link(user,reason.c_str()); -411 } +418 { +419 kill_link(user,reason.c_str()); +420 } .fi .SS "void Server::Send (int Socket, std::string s)\fC [virtual]\fP" .PP -Sends a line of text down a TCP/IP socket. This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.Definition at line 438 of file modules.cpp. +Sends a line of text down a TCP/IP socket. This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.Definition at line 447 of file modules.cpp. .PP .nf -439 { -440 Write(Socket,'%s',s.c_str()); -441 } +448 { +449 Write(Socket,'%s',s.c_str()); +450 } .fi .SS "void Server::SendChannel (\fBuserrec\fP * User, \fBchanrec\fP * Channel, std::string s, bool IncludeSender)\fC [virtual]\fP" .PP -Sends text from a user to a channel (mulicast). This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).Definition at line 472 of file modules.cpp. +Sends text from a user to a channel (mulicast). This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).Definition at line 481 of file modules.cpp. .PP .nf -473 { -474 if (IncludeSender) -475 { -476 WriteChannel(Channel,User,'%s',s.c_str()); -477 } -478 else -479 { -480 ChanExceptSender(Channel,User,'%s',s.c_str()); -481 } -482 } +482 { +483 if (IncludeSender) +484 { +485 WriteChannel(Channel,User,'%s',s.c_str()); +486 } +487 else +488 { +489 ChanExceptSender(Channel,User,'%s',s.c_str()); +490 } +491 } .fi .SS "void Server::SendChannelServerNotice (std::string ServName, \fBchanrec\fP * Channel, std::string text)\fC [virtual]\fP" .PP -Writes text to a channel, but from a server, including all. This can be used to send server notices to a group of users.Definition at line 467 of file modules.cpp. +Writes text to a channel, but from a server, including all. This can be used to send server notices to a group of users.Definition at line 476 of file modules.cpp. .PP .nf -468 { -469 WriteChannelWithServ((char*)ServName.c_str(), Channel, '%s', text.c_str()); -470 } +477 { +478 WriteChannelWithServ((char*)ServName.c_str(), Channel, '%s', text.c_str()); +479 } .fi .SS "void Server::SendCommon (\fBuserrec\fP * User, std::string text, bool IncludeSender)\fC [virtual]\fP" .PP -Sends text from a user to one or more channels (mulicast). This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.Definition at line 489 of file modules.cpp. +Sends text from a user to one or more channels (mulicast). This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.Definition at line 498 of file modules.cpp. .PP .nf -490 { -491 if (IncludeSender) -492 { -493 WriteCommon(User,'%s',text.c_str()); -494 } -495 else -496 { -497 WriteCommonExcept(User,'%s',text.c_str()); -498 } -499 } +499 { +500 if (IncludeSender) +501 { +502 WriteCommon(User,'%s',text.c_str()); +503 } +504 else +505 { +506 WriteCommonExcept(User,'%s',text.c_str()); +507 } +508 } .fi .SS "void Server::SendFrom (int Socket, \fBuserrec\fP * User, std::string s)\fC [virtual]\fP" .PP -Sends text from a user to a socket. This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)Definition at line 448 of file modules.cpp. +Sends text from a user to a socket. This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)Definition at line 457 of file modules.cpp. .PP .nf -449 { -450 WriteFrom(Socket,User,'%s',s.c_str()); -451 } +458 { +459 WriteFrom(Socket,User,'%s',s.c_str()); +460 } .fi .SS "void Server::SendMode (char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP @@ -957,32 +957,32 @@ modes[2] = user->nick; .PP Srv->SendMode(modes,3,user); .PP -The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!Definition at line 433 of file modules.cpp. +The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!Definition at line 442 of file modules.cpp. .PP References server_mode(). .PP .nf -434 { -435 server_mode(parameters,pcnt,user); -436 } +443 { +444 server_mode(parameters,pcnt,user); +445 } .fi .SS "void Server::SendOpers (std::string s)\fC [virtual]\fP" .PP -Sends text to all opers. This method sends a server notice to all opers with the usermode +s.Definition at line 363 of file modules.cpp. +Sends text to all opers. This method sends a server notice to all opers with the usermode +s.Definition at line 372 of file modules.cpp. .PP .nf -364 { -365 WriteOpers('%s',s.c_str()); -366 } +373 { +374 WriteOpers('%s',s.c_str()); +375 } .fi .SS "void Server::SendServ (int Socket, std::string s)\fC [virtual]\fP" .PP -Sends text from the server to a socket. This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)Definition at line 443 of file modules.cpp. +Sends text from the server to a socket. This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)Definition at line 452 of file modules.cpp. .PP .nf -444 { -445 WriteServ(Socket,'%s',s.c_str()); -446 } +453 { +454 WriteServ(Socket,'%s',s.c_str()); +455 } .fi .SS "void Server::SendTo (\fBuserrec\fP * Source, \fBuserrec\fP * Dest, std::string s)\fC [virtual]\fP" .PP @@ -994,23 +994,23 @@ The format will become: .PP :localserver TEXT .PP -Which is useful for numerics and server notices to single users, etc.Definition at line 453 of file modules.cpp. +Which is useful for numerics and server notices to single users, etc.Definition at line 462 of file modules.cpp. .PP References connection::fd. .PP .nf -454 { -455 if (!Source) -456 { -457 // if source is NULL, then the message originates from the local server -458 Write(Dest->fd,':%s %s',this->GetServerName().c_str(),s.c_str()); -459 } -460 else -461 { -462 // otherwise it comes from the user specified -463 WriteTo(Source,Dest,'%s',s.c_str()); -464 } -465 } +463 { +464 if (!Source) +465 { +466 // if source is NULL, then the message originates from the local server +467 Write(Dest->fd,':%s %s',this->GetServerName().c_str(),s.c_str()); +468 } +469 else +470 { +471 // otherwise it comes from the user specified +472 WriteTo(Source,Dest,'%s',s.c_str()); +473 } +474 } .fi .SS "void Server::SendToModeMask (std::string modes, int flags, std::string text)\fC [virtual]\fP" .PP @@ -1018,46 +1018,57 @@ Sends to all users matching a mode mask You must specify one or more usermodes a .PP Serv->SendToModeMask('xi', WM_OR, 'm00'); .PP -Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.Definition at line 376 of file modules.cpp. +Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.Definition at line 385 of file modules.cpp. .PP .nf -377 { -378 WriteMode(modes.c_str(),flags,'%s',text.c_str()); -379 } +386 { +387 WriteMode(modes.c_str(),flags,'%s',text.c_str()); +388 } .fi .SS "void Server::SendWallops (\fBuserrec\fP * User, std::string text)\fC [virtual]\fP" .PP -Sends a WALLOPS message. This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.Definition at line 501 of file modules.cpp. +Sends a WALLOPS message. This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.Definition at line 510 of file modules.cpp. .PP .nf -502 { -503 WriteWallOps(User,false,'%s',text.c_str()); -504 } +511 { +512 WriteWallOps(User,false,'%s',text.c_str()); +513 } .fi .SS "bool Server::UserToPseudo (\fBuserrec\fP * user, std::string message)\fC [virtual]\fP" .PP -Remove a user's connection to the irc server, but leave their client in existence in the user hash. When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.Definition at line 610 of file modules.cpp. +Remove a user's connection to the irc server, but leave their client in existence in the user hash. When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.Definition at line 619 of file modules.cpp. .PP References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. .PP .nf -611 { -612 unsigned int old_fd = user->fd; -613 user->fd = FD_MAGIC_NUMBER; -614 user->ClearBuffer(); -615 Write(old_fd,'ERROR :Closing link (%s@%s) [%s]',user->ident,user->host,message.c_str()); -616 #ifdef USE_KQUEUE -617 struct kevent ke; -618 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); -619 int i = kevent(kq, &ke, 1, 0, 0, NULL); -620 if (i == -1) -621 { -622 log(DEBUG,'kqueue: Failed to remove user from queue!'); -623 } -624 #endif -625 shutdown(old_fd,2); -626 close(old_fd); -627 } +620 { +621 unsigned int old_fd = user->fd; +622 user->fd = FD_MAGIC_NUMBER; +623 user->ClearBuffer(); +624 Write(old_fd,'ERROR :Closing link (%s@%s) [%s]',user->ident,user->host,message.c_str()); +625 #ifdef USE_KQUEUE +626 struct kevent ke; +627 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); +628 int i = kevent(kq, &ke, 1, 0, 0, NULL); +629 if (i == -1) +630 { +631 log(DEBUG,'kqueue: Failed to remove user from queue!'); +632 } +633 #endif +634 #ifdef USE_EPOLL +635 struct epoll_event ev; +636 ev.events = EPOLLIN | EPOLLET; +637 ev.data.fd = old_fd; +638 int i = epoll_ctl(ep, EPOLL_CTL_DEL, old_fd, &ev); +639 if (i < 0) +640 { +641 log(DEBUG,'epoll: List deletion failure!'); +642 } +643 #endif +644 +645 shutdown(old_fd,2); +646 close(old_fd); +647 } .fi diff --git a/docs/man/man3/Version.3 b/docs/man/man3/Version.3 index b553e9e20..aeea8964f 100644 --- a/docs/man/man3/Version.3 +++ b/docs/man/man3/Version.3 @@ -1,4 +1,4 @@ -.TH "Version" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Version" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -49,10 +49,10 @@ Definition at line 111 of file modules.h. .PP .SS "Version::Version (int major, int minor, int revision, int build, int flags)" .PP -Definition at line 234 of file modules.cpp. +Definition at line 243 of file modules.cpp. .PP .nf -234 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; +243 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/WhoWasUser.3 b/docs/man/man3/WhoWasUser.3 index a6d45973f..8e60d5b21 100644 --- a/docs/man/man3/WhoWasUser.3 +++ b/docs/man/man3/WhoWasUser.3 @@ -1,4 +1,4 @@ -.TH "WhoWasUser" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "WhoWasUser" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -37,30 +37,30 @@ WhoWasUser \- A lightweight userrec used by WHOWAS. .in -1c .SH "Detailed Description" .PP -A lightweight userrec used by WHOWAS. Definition at line 318 of file users.h. +A lightweight userrec used by WHOWAS. Definition at line 326 of file users.h. .SH "Member Data Documentation" .PP .SS "char \fBWhoWasUser::dhost\fP[160]" .PP -Definition at line 323 of file users.h. +Definition at line 331 of file users.h. .SS "char \fBWhoWasUser::fullname\fP[128]" .PP -Definition at line 325 of file users.h. +Definition at line 333 of file users.h. .SS "char \fBWhoWasUser::host\fP[160]" .PP -Definition at line 324 of file users.h. +Definition at line 332 of file users.h. .SS "char \fBWhoWasUser::ident\fP[16]" .PP -Definition at line 322 of file users.h. +Definition at line 330 of file users.h. .SS "char \fBWhoWasUser::nick\fP[NICKMAX]" .PP -Definition at line 321 of file users.h. +Definition at line 329 of file users.h. .SS "char \fBWhoWasUser::server\fP[256]" .PP -Definition at line 326 of file users.h. +Definition at line 334 of file users.h. .SS "time_t \fBWhoWasUser::signon\fP" .PP -Definition at line 327 of file users.h. +Definition at line 335 of file users.h. .SH "Author" .PP diff --git a/docs/man/man3/XLine.3 b/docs/man/man3/XLine.3 index 8cd21fa0c..3745f1f06 100644 --- a/docs/man/man3/XLine.3 +++ b/docs/man/man3/XLine.3 @@ -1,4 +1,4 @@ -.TH "XLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "XLine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ZLine.3 b/docs/man/man3/ZLine.3 index 916e3681f..9a0d1a77a 100644 --- a/docs/man/man3/ZLine.3 +++ b/docs/man/man3/ZLine.3 @@ -1,4 +1,4 @@ -.TH "ZLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ZLine" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/base.h.3 b/docs/man/man3/base.h.3 index d3d7d4065..cab63c1bb 100644 --- a/docs/man/man3/base.h.3 +++ b/docs/man/man3/base.h.3 @@ -1,4 +1,4 @@ -.TH "base.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "base.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/channels.cpp.3 b/docs/man/man3/channels.cpp.3 index 1b0bc51c5..dfcb792ac 100644 --- a/docs/man/man3/channels.cpp.3 +++ b/docs/man/man3/channels.cpp.3 @@ -1,4 +1,4 @@ -.TH "channels.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "channels.cpp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -156,9 +156,6 @@ channels.cpp \- .RI "time_t \fBnb_start\fP" .br .ti -1c -.RI "std::vector< int > \fBfd_reap\fP" -.br -.ti -1c .RI "std::vector< std::string > \fBmodule_names\fP" .br .ti -1c @@ -199,7 +196,7 @@ channels.cpp \- .PP .SS "#define nspace std" .PP -Definition at line 53 of file channels.cpp. +Definition at line 55 of file channels.cpp. .SH "Variable Documentation" .PP .SS "char \fBAdminEmail\fP[MAXBUF]" @@ -213,18 +210,18 @@ Definition at line 66 of file channels.cpp. Definition at line 68 of file channels.cpp. .SS "std::vector \fBauth_cookies\fP" .PP -Definition at line 95 of file channels.cpp. +Definition at line 94 of file channels.cpp. .SS "int \fBboundPortCount\fP" .PP -Definition at line 89 of file channels.cpp. +Definition at line 88 of file channels.cpp. .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 96 of file channels.cpp. +Definition at line 95 of file channels.cpp. .PP Referenced by userrec::HasPermission(). .SS "std::vector<\fBModeParameter\fP> \fBcustom_mode_params\fP" .PP -Definition at line 106 of file channels.cpp. +Definition at line 105 of file channels.cpp. .PP Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam(). .SS "int \fBdebugging\fP" @@ -232,7 +229,7 @@ Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam(). Definition at line 77 of file channels.cpp. .SS "int \fBdefaultRoute\fP" .PP -Definition at line 93 of file channels.cpp. +Definition at line 92 of file channels.cpp. .SS "int \fBDieDelay\fP" .PP Definition at line 80 of file channels.cpp. @@ -245,9 +242,6 @@ Definition at line 75 of file channels.cpp. .SS "std::vector<\fBircd_module\fP*> factory" .PP Definition at line 60 of file channels.cpp. -.SS "std::vector \fBfd_reap\fP" -.PP -Definition at line 86 of file channels.cpp. .SS "char \fBlist\fP[MAXBUF]" .PP Definition at line 73 of file channels.cpp. @@ -255,7 +249,7 @@ Definition at line 73 of file channels.cpp. Referenced by Server::GetUsers(). .SS "FILE* \fBlog_file\fP" .PP -Definition at line 100 of file channels.cpp. +Definition at line 99 of file channels.cpp. .SS "int \fBLogLevel\fP" .PP Definition at line 62 of file channels.cpp. @@ -264,15 +258,15 @@ Definition at line 62 of file channels.cpp. Definition at line 83 of file channels.cpp. .SS "\fBserverrec\fP* \fBme\fP[32]" .PP -Definition at line 98 of file channels.cpp. +Definition at line 97 of file channels.cpp. .SS "int \fBMODCOUNT\fP = -1" .PP -Definition at line 996 of file modules.cpp. +Definition at line 1016 of file modules.cpp. .PP Referenced by Server::FindModule(). .SS "std::vector \fBmodule_names\fP" .PP -Definition at line 87 of file channels.cpp. +Definition at line 86 of file channels.cpp. .PP Referenced by Server::FindModule(). .SS "std::vector<\fBModule\fP*> modules" @@ -294,10 +288,10 @@ Definition at line 82 of file channels.cpp. Definition at line 64 of file channels.cpp. .SS "int \fBportCount\fP" .PP -Definition at line 90 of file channels.cpp. +Definition at line 89 of file channels.cpp. .SS "int \fBports\fP[MAXSOCKS]" .PP -Definition at line 92 of file channels.cpp. +Definition at line 91 of file channels.cpp. .SS "char \fBPrefixQuit\fP[MAXBUF]" .PP Definition at line 74 of file channels.cpp. @@ -315,13 +309,13 @@ Definition at line 65 of file channels.cpp. Definition at line 63 of file channels.cpp. .SS "int \fBSERVERportCount\fP" .PP -Definition at line 91 of file channels.cpp. +Definition at line 90 of file channels.cpp. .SS "time_t \fBstartup_time\fP" .PP Definition at line 81 of file channels.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 102 of file channels.cpp. +Definition at line 101 of file channels.cpp. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). .SS "int \fBWHOWAS_MAX\fP" diff --git a/docs/man/man3/channels.h.3 b/docs/man/man3/channels.h.3 index 0609a03e6..66b0c8044 100644 --- a/docs/man/man3/channels.h.3 +++ b/docs/man/man3/channels.h.3 @@ -1,4 +1,4 @@ -.TH "channels.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "channels.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/chanrec.3 b/docs/man/man3/chanrec.3 index 0831e46b3..69ac8c35d 100644 --- a/docs/man/man3/chanrec.3 +++ b/docs/man/man3/chanrec.3 @@ -1,4 +1,4 @@ -.TH "chanrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "chanrec" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -114,21 +114,21 @@ Definition at line 101 of file channels.h. .PP .SS "chanrec::chanrec ()" .PP -Creates a channel record and initialises it with default values. Definition at line 108 of file channels.cpp. +Creates a channel record and initialises it with default values. Definition at line 107 of file channels.cpp. .PP References binarymodes, created, custom_modes, internal_userlist, key, limit, name, setby, topic, and topicset. .PP .nf -109 { -110 strcpy(name,''); -111 strcpy(custom_modes,''); -112 strcpy(topic,''); -113 strcpy(setby,''); -114 strcpy(key,''); -115 created = topicset = limit = 0; -116 binarymodes = 0; -117 internal_userlist.clear(); -118 } +108 { +109 strcpy(name,''); +110 strcpy(custom_modes,''); +111 strcpy(topic,''); +112 strcpy(setby,''); +113 strcpy(key,''); +114 created = topicset = limit = 0; +115 binarymodes = 0; +116 internal_userlist.clear(); +117 } .fi .SS "virtual chanrec::~\fBchanrec\fP ()\fC [inline, virtual]\fP" .PP @@ -141,161 +141,161 @@ Definition at line 205 of file channels.h. .PP .SS "void chanrec::AddUser (char * castuser)" .PP -Add a user pointer to the internal reference list The data inserted into the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 202 of file channels.cpp. +Add a user pointer to the internal reference list The data inserted into the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 201 of file channels.cpp. .PP References DEBUG, and internal_userlist. .PP .nf -203 { -204 internal_userlist.push_back(castuser); -205 log(DEBUG,'Added casted user to channel's internal list'); -206 } +202 { +203 internal_userlist.push_back(castuser); +204 log(DEBUG,'Added casted user to channel's internal list'); +205 } .fi .SS "void chanrec::DelUser (char * castuser)" .PP -Delete a user pointer to the internal reference list The data removed from the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 208 of file channels.cpp. +Delete a user pointer to the internal reference list The data removed from the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 207 of file channels.cpp. .PP References DEBUG, internal_userlist, and name. .PP .nf -209 { -210 for (std::vector::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) -211 { -212 if (*a == castuser) -213 { -214 log(DEBUG,'Removed casted user from channel's internal list'); -215 internal_userlist.erase(a); -216 return; -217 } -218 } -219 log(DEBUG,'BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!',name); -220 } +208 { +209 for (std::vector::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) +210 { +211 if (*a == castuser) +212 { +213 log(DEBUG,'Removed casted user from channel's internal list'); +214 internal_userlist.erase(a); +215 return; +216 } +217 } +218 log(DEBUG,'BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!',name); +219 } .fi .SS "std::string chanrec::GetModeParameter (char mode)" .PP -Returns the parameter for a custom mode on a channel. For example if '+L #foo' is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.Definition at line 182 of file channels.cpp. +Returns the parameter for a custom mode on a channel. For example if '+L #foo' is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.Definition at line 181 of file channels.cpp. .PP References custom_mode_params. .PP .nf -183 { -184 if (custom_mode_params.size()) -185 { -186 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -187 { -188 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -189 { -190 return i->parameter; -191 } -192 } -193 } -194 return ''; -195 } +182 { +183 if (custom_mode_params.size()) +184 { +185 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +186 { +187 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +188 { +189 return i->parameter; +190 } +191 } +192 } +193 return ''; +194 } .fi .SS "long chanrec::GetUserCounter ()" .PP -Obtain the channel 'user counter' This returns the channel reference counter, which is initialized to 0 when the channel is created and incremented/decremented upon joins, parts quits and kicks. Definition at line 197 of file channels.cpp. +Obtain the channel 'user counter' This returns the channel reference counter, which is initialized to 0 when the channel is created and incremented/decremented upon joins, parts quits and kicks. Definition at line 196 of file channels.cpp. .PP References internal_userlist. .PP .nf -198 { -199 return (this->internal_userlist.size()); -200 } +197 { +198 return (this->internal_userlist.size()); +199 } .fi .SS "std::vector< char * > * chanrec::GetUsers ()" .PP -Obrain the internal reference list The internal reference list contains a list of userrec* cast to char*. These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.Definition at line 222 of file channels.cpp. +Obrain the internal reference list The internal reference list contains a list of userrec* cast to char*. These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.Definition at line 221 of file channels.cpp. .PP References internal_userlist. .PP Referenced by Server::GetUsers(). .PP .nf -223 { -224 return &internal_userlist; -225 } +222 { +223 return &internal_userlist; +224 } .fi .SS "bool chanrec::IsCustomModeSet (char mode)" .PP -Returns true if a custom mode is set on a channel. Definition at line 176 of file channels.cpp. +Returns true if a custom mode is set on a channel. Definition at line 175 of file channels.cpp. .PP References DEBUG. .PP .nf -177 { -178 log(DEBUG,'Checking ISCustomModeSet: %c %s',mode,this->custom_modes); -179 return (strchr(this->custom_modes,mode) != 0); -180 } +176 { +177 log(DEBUG,'Checking ISCustomModeSet: %c %s',mode,this->custom_modes); +178 return (strchr(this->custom_modes,mode) != 0); +179 } .fi .SS "void chanrec::SetCustomMode (char mode, bool mode_on)" .PP -Sets or unsets a custom mode in the channels info. Definition at line 120 of file channels.cpp. +Sets or unsets a custom mode in the channels info. Definition at line 119 of file channels.cpp. .PP References custom_modes, DEBUG, and SetCustomModeParam(). .PP .nf -121 { -122 if (mode_on) { -123 static char m[3]; -124 m[0] = mode; -125 m[1] = '\0'; -126 if (!strchr(this->custom_modes,mode)) -127 { -128 strlcat(custom_modes,m,MAXMODES); -129 } -130 log(DEBUG,'Custom mode %c set',mode); -131 } -132 else { -133 -134 std::string a = this->custom_modes; -135 int pos = a.find(mode); -136 a.erase(pos,1); -137 strncpy(this->custom_modes,a.c_str(),MAXMODES); -138 -139 log(DEBUG,'Custom mode %c removed: modelist='%s'',mode,this->custom_modes); -140 this->SetCustomModeParam(mode,'',false); -141 } -142 } +120 { +121 if (mode_on) { +122 static char m[3]; +123 m[0] = mode; +124 m[1] = '\0'; +125 if (!strchr(this->custom_modes,mode)) +126 { +127 strlcat(custom_modes,m,MAXMODES); +128 } +129 log(DEBUG,'Custom mode %c set',mode); +130 } +131 else { +132 +133 std::string a = this->custom_modes; +134 int pos = a.find(mode); +135 a.erase(pos,1); +136 strncpy(this->custom_modes,a.c_str(),MAXMODES); +137 +138 log(DEBUG,'Custom mode %c removed: modelist='%s'',mode,this->custom_modes); +139 this->SetCustomModeParam(mode,'',false); +140 } +141 } .fi .SS "void chanrec::SetCustomModeParam (char mode, char * parameter, bool mode_on)" .PP -Sets or unsets the parameters for a custom mode in a channels info. Definition at line 145 of file channels.cpp. +Sets or unsets the parameters for a custom mode in a channels info. Definition at line 144 of file channels.cpp. .PP References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter. .PP Referenced by SetCustomMode(). .PP .nf -146 { -147 -148 log(DEBUG,'SetCustomModeParam called'); -149 ModeParameter M; -150 M.mode = mode; -151 strlcpy(M.channel,this->name,CHANMAX); -152 strlcpy(M.parameter,parameter,MAXBUF); -153 if (mode_on) -154 { -155 log(DEBUG,'Custom mode parameter %c %s added',mode,parameter); -156 custom_mode_params.push_back(M); -157 } -158 else -159 { -160 if (custom_mode_params.size()) -161 { -162 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -163 { -164 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -165 { -166 log(DEBUG,'Custom mode parameter %c %s removed',mode,parameter); -167 custom_mode_params.erase(i); -168 return; -169 } -170 } -171 } -172 log(DEBUG,'*** BUG *** Attempt to remove non-existent mode parameter!'); -173 } -174 } +145 { +146 +147 log(DEBUG,'SetCustomModeParam called'); +148 ModeParameter M; +149 M.mode = mode; +150 strlcpy(M.channel,this->name,CHANMAX); +151 strlcpy(M.parameter,parameter,MAXBUF); +152 if (mode_on) +153 { +154 log(DEBUG,'Custom mode parameter %c %s added',mode,parameter); +155 custom_mode_params.push_back(M); +156 } +157 else +158 { +159 if (custom_mode_params.size()) +160 { +161 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +162 { +163 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +164 { +165 log(DEBUG,'Custom mode parameter %c %s removed',mode,parameter); +166 custom_mode_params.erase(i); +167 return; +168 } +169 } +170 } +171 log(DEBUG,'*** BUG *** Attempt to remove non-existent mode parameter!'); +172 } +173 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/classbase.3 b/docs/man/man3/classbase.3 index 9530bb7c8..bdadeea07 100644 --- a/docs/man/man3/classbase.3 +++ b/docs/man/man3/classbase.3 @@ -1,4 +1,4 @@ -.TH "classbase" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "classbase" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/command_t.3 b/docs/man/man3/command_t.3 index 8309583b7..17e768025 100644 --- a/docs/man/man3/command_t.3 +++ b/docs/man/man3/command_t.3 @@ -1,4 +1,4 @@ -.TH "command_t" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "command_t" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/commands.h.3 b/docs/man/man3/commands.h.3 index c13b7bd21..5b95d45a8 100644 --- a/docs/man/man3/commands.h.3 +++ b/docs/man/man3/commands.h.3 @@ -1,4 +1,4 @@ -.TH "commands.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "commands.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -178,6 +178,9 @@ commands.h \- .RI "void \fBhandle_unloadmodule\fP (char **parameters, int pcnt, \fBuserrec\fP *user)" .br .ti -1c +.RI "void \fBhandle_commands\fP (char **parameters, int pcnt, \fBuserrec\fP *user)" +.br +.ti -1c .RI "void \fBhandle_link_packet\fP (char *tcp_msg, char *tcp_host, \fBserverrec\fP *serv, char *tcp_sum)" .br .RI "\fISpecial functions for processing server to server traffic. \fP" @@ -278,6 +281,8 @@ These are the handlers for server commands (tokens). .PP .SS "void handle_b (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP +.SS "void handle_commands (char ** parameters, int pcnt, \fBuserrec\fP * user)" +.PP .SS "void handle_connect (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP .SS "void handle_die (char ** parameters, int pcnt, \fBuserrec\fP * user)" diff --git a/docs/man/man3/connection.3 b/docs/man/man3/connection.3 index e21a84b8d..e492e0b8b 100644 --- a/docs/man/man3/connection.3 +++ b/docs/man/man3/connection.3 @@ -1,4 +1,4 @@ -.TH "connection" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "connection" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -21,38 +21,6 @@ Inherited by \fBserverrec\fP, and \fBuserrec\fP. .RI "\fBconnection\fP ()" .br .RI "\fIDefault constructor. \fP" -.ti -1c -.RI "bool \fBCreateListener\fP (char *\fBhost\fP, int p)" -.br -.RI "\fICreate a listening socket on 'host' using port number 'p'. \fP" -.ti -1c -.RI "bool \fBBeginLink\fP (char *targethost, int \fBport\fP, char *password, char *servername, int myport)" -.br -.RI "\fIBegin an outbound link to another ircd at targethost. \fP" -.ti -1c -.RI "bool \fBMeshCookie\fP (char *targethost, int \fBport\fP, unsigned long cookie, char *servername)" -.br -.RI "\fIBegin an outbound mesh link to another ircd on a network you are already an authenticated member of. \fP" -.ti -1c -.RI "void \fBTerminateLink\fP (char *targethost)" -.br -.RI "\fITerminate a link to 'targethost' by calling the \fBircd_connector::CloseConnection\fP method. \fP" -.ti -1c -.RI "bool \fBSendPacket\fP (char *message, const char *\fBhost\fP)" -.br -.RI "\fISend a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. \fP" -.ti -1c -.RI "bool \fBRecvPacket\fP (std::deque< std::string > &messages, char *\fBhost\fP, std::deque< std::string > &sums)" -.br -.RI "\fIReturns the next available packet and returns true if data is available. \fP" -.ti -1c -.RI "\fBircd_connector\fP * \fBFindHost\fP (std::string \fBhost\fP)" -.br -.RI "\fIFind the \fBircd_connector\fP oject related to a certain servername given in 'host'. \fP" -.ti -1c -.RI "bool \fBAddIncoming\fP (int \fBfd\fP, char *targethost, int sourceport)" -.br -.RI "\fIAdd an incoming connection to the connection pool. \fP" .in -1c .SS "Public Attributes" @@ -70,19 +38,19 @@ Inherited by \fBserverrec\fP, and \fBuserrec\fP. .br .RI "\fIIP of connection. \fP" .ti -1c -.RI "long \fBbytes_in\fP" +.RI "int \fBbytes_in\fP" .br .RI "\fIStats counter for bytes inbound. \fP" .ti -1c -.RI "long \fBbytes_out\fP" +.RI "int \fBbytes_out\fP" .br .RI "\fIStats counter for bytes outbound. \fP" .ti -1c -.RI "long \fBcmds_in\fP" +.RI "int \fBcmds_in\fP" .br .RI "\fIStats counter for commands inbound. \fP" .ti -1c -.RI "long \fBcmds_out\fP" +.RI "int \fBcmds_out\fP" .br .RI "\fIStats counter for commands outbound. \fP" .ti -1c @@ -113,118 +81,85 @@ Inherited by \fBserverrec\fP, and \fBuserrec\fP. .RI "time_t \fBnping\fP" .br .RI "\fIUsed by PING checks with clients. \fP" -.ti -1c -.RI "std::vector< \fBircd_connector\fP > \fBconnectors\fP" -.br -.RI "\fIWith a serverrec, this is a list of all established server connections. \fP" .in -1c .SH "Detailed Description" .PP -Please note: classes serverrec and userrec both inherit from class connection. Definition at line 212 of file connection.h. +Please note: classes serverrec and userrec both inherit from class connection. Definition at line 261 of file connection.h. .SH "Constructor & Destructor Documentation" .PP .SS "connection::connection ()" .PP Default constructor. -.SH "Member Function Documentation" -.PP -.SS "bool connection::AddIncoming (int fd, char * targethost, int sourceport)" -.PP -Add an incoming connection to the connection pool. (reserved for core use) -.SS "bool connection::BeginLink (char * targethost, int port, char * password, char * servername, int myport)" -.PP -Begin an outbound link to another ircd at targethost. -.SS "bool connection::CreateListener (char * host, int p)" -.PP -Create a listening socket on 'host' using port number 'p'. -.SS "\fBircd_connector\fP* connection::FindHost (std::string host)" -.PP -Find the \fBircd_connector\fP oject related to a certain servername given in 'host'. -.SS "bool connection::MeshCookie (char * targethost, int port, unsigned long cookie, char * servername)" -.PP -Begin an outbound mesh link to another ircd on a network you are already an authenticated member of. -.SS "bool connection::RecvPacket (std::deque< std::string > & messages, char * host, std::deque< std::string > & sums)" -.PP -Returns the next available packet and returns true if data is available. Writes the servername the data came from to 'host'. If no data is available this function returns false. This function will automatically close broken links and reroute pathways, generating split messages on the network. -.SS "bool connection::SendPacket (char * message, const char * host)" -.PP -Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. -.SS "void connection::TerminateLink (char * targethost)" -.PP -Terminate a link to 'targethost' by calling the \fBircd_connector::CloseConnection\fP method. .SH "Member Data Documentation" .PP -.SS "long \fBconnection::bytes_in\fP" +.SS "int \fBconnection::bytes_in\fP" .PP -Stats counter for bytes inbound. Definition at line 229 of file connection.h. +Stats counter for bytes inbound. Definition at line 278 of file connection.h. .PP Referenced by userrec::userrec(). -.SS "long \fBconnection::bytes_out\fP" +.SS "int \fBconnection::bytes_out\fP" .PP -Stats counter for bytes outbound. Definition at line 233 of file connection.h. +Stats counter for bytes outbound. Definition at line 282 of file connection.h. .PP Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). -.SS "long \fBconnection::cmds_in\fP" +.SS "int \fBconnection::cmds_in\fP" .PP -Stats counter for commands inbound. Definition at line 237 of file connection.h. +Stats counter for commands inbound. Definition at line 286 of file connection.h. .PP Referenced by userrec::userrec(). -.SS "long \fBconnection::cmds_out\fP" +.SS "int \fBconnection::cmds_out\fP" .PP -Stats counter for commands outbound. Definition at line 241 of file connection.h. +Stats counter for commands outbound. Definition at line 290 of file connection.h. .PP Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). -.SS "std::vector<\fBircd_connector\fP> \fBconnection::connectors\fP" -.PP -With a serverrec, this is a list of all established server connections. With a userrec this is unused.Definition at line 276 of file connection.h. .SS "int \fBconnection::fd\fP" .PP -File descriptor of the connection. Definition at line 217 of file connection.h. +File descriptor of the connection. Definition at line 266 of file connection.h. .PP -Referenced by ConfigReader::DumpErrors(), Server::PseudoToUser(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo(). +Referenced by serverrec::BeginLink(), serverrec::CreateListener(), ConfigReader::DumpErrors(), serverrec::MeshCookie(), Server::PseudoToUser(), userrec::ReadData(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo(). .SS "bool \fBconnection::haspassed\fP" .PP -True if server/user has authenticated, false if otherwise. Definition at line 245 of file connection.h. +True if server/user has authenticated, false if otherwise. Definition at line 294 of file connection.h. .PP Referenced by userrec::userrec(). .SS "char \fBconnection::host\fP[160]" .PP -Hostname of connection. Not used if this is a serverrecDefinition at line 221 of file connection.h. +Hostname of connection. Not used if this is a serverrecDefinition at line 270 of file connection.h. .PP Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo(). .SS "time_t \fBconnection::idle_lastmsg\fP" .PP -Time that the connection last sent data, used to calculate idle time. Definition at line 267 of file connection.h. +Time that the connection last sent data, used to calculate idle time. Definition at line 316 of file connection.h. .PP Referenced by userrec::userrec(). .SS "char \fBconnection::ip\fP[16]" .PP -IP of connection. Definition at line 225 of file connection.h. +IP of connection. Definition at line 274 of file connection.h. .PP Referenced by userrec::userrec(). .SS "time_t \fBconnection::lastping\fP" .PP -Time the connection was last pinged. Definition at line 259 of file connection.h. +Time the connection was last pinged. Definition at line 308 of file connection.h. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). .SS "time_t \fBconnection::nping\fP" .PP -Used by PING checks with clients. Definition at line 271 of file connection.h. +Used by PING checks with clients. Definition at line 320 of file connection.h. .PP Referenced by userrec::userrec(). .SS "int \fBconnection::port\fP" .PP -Port number For a userrec, this is the port they connected to the network on. For a serverrec this is the current listening port of the serverrec object.Definition at line 251 of file connection.h. +Port number For a userrec, this is the port they connected to the network on. For a serverrec this is the current listening port of the serverrec object.Definition at line 300 of file connection.h. .PP -Referenced by userrec::userrec(). +Referenced by serverrec::CreateListener(), and userrec::userrec(). .SS "char \fBconnection::registered\fP" .PP -Used by userrec to indicate the registration status of the connection. Definition at line 255 of file connection.h. +Used by userrec to indicate the registration status of the connection. Definition at line 304 of file connection.h. .PP Referenced by userrec::userrec(). .SS "time_t \fBconnection::signon\fP" .PP -Time the connection was created, set in the constructor. Definition at line 263 of file connection.h. +Time the connection was created, set in the constructor. Definition at line 312 of file connection.h. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). diff --git a/docs/man/man3/connection.h.3 b/docs/man/man3/connection.h.3 index 2bd9c858a..b8ddeddf6 100644 --- a/docs/man/man3/connection.h.3 +++ b/docs/man/man3/connection.h.3 @@ -1,4 +1,4 @@ -.TH "connection.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "connection.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -81,15 +81,23 @@ connection.h \- .SS "#define STATE_CONNECTED 1" .PP Definition at line 36 of file connection.h. +.PP +Referenced by serverrec::MeshCookie(). .SS "#define STATE_DISCONNECTED 0" .PP Definition at line 35 of file connection.h. +.PP +Referenced by serverrec::BeginLink(), serverrec::FlushWriteBuffers(), serverrec::MeshCookie(), serverrec::RecvPacket(), and serverrec::SendPacket(). .SS "#define STATE_NOAUTH_INBOUND 3" .PP Definition at line 38 of file connection.h. +.PP +Referenced by serverrec::AddIncoming(). .SS "#define STATE_NOAUTH_OUTBOUND 4" .PP Definition at line 39 of file connection.h. +.PP +Referenced by serverrec::BeginLink(), and serverrec::MeshCookie(). .SS "#define STATE_SERVICES 5" .PP Definition at line 40 of file connection.h. diff --git a/docs/man/man3/ctables.h.3 b/docs/man/man3/ctables.h.3 index 2d7eb05c9..c13d28638 100644 --- a/docs/man/man3/ctables.h.3 +++ b/docs/man/man3/ctables.h.3 @@ -1,4 +1,4 @@ -.TH "ctables.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ctables.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/dns.h.3 b/docs/man/man3/dns.h.3 index aca6fe856..a570c881a 100644 --- a/docs/man/man3/dns.h.3 +++ b/docs/man/man3/dns.h.3 @@ -1,4 +1,4 @@ -.TH "dns.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "dns.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/dns_ip4list.3 b/docs/man/man3/dns_ip4list.3 index a3835ec7f..00ed1737e 100644 --- a/docs/man/man3/dns_ip4list.3 +++ b/docs/man/man3/dns_ip4list.3 @@ -1,4 +1,4 @@ -.TH "dns_ip4list" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "dns_ip4list" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/hashcomp.h.3 b/docs/man/man3/hashcomp.h.3 index 91b45a530..6fe823fe7 100644 --- a/docs/man/man3/hashcomp.h.3 +++ b/docs/man/man3/hashcomp.h.3 @@ -1,4 +1,4 @@ -.TH "hashcomp.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "hashcomp.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -32,7 +32,7 @@ hashcomp.h \- .PP .SS "#define nspace __gnu_cxx" .PP -Definition at line 29 of file hashcomp.h. +Definition at line 44 of file hashcomp.h. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/irc.3 b/docs/man/man3/irc.3 index c1bcb5dfc..2431dfda3 100644 --- a/docs/man/man3/irc.3 +++ b/docs/man/man3/irc.3 @@ -1,4 +1,4 @@ -.TH "irc" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "irc" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -38,7 +38,7 @@ The irc namespace contains a number of helper classes. .PP .SS "typedef basic_string > \fBirc::string\fP" .PP -This typedef declares \fBirc::string\fP based upon \fBirc_char_traits\fP. Definition at line 114 of file hashcomp.h. +This typedef declares \fBirc::string\fP based upon \fBirc_char_traits\fP. Definition at line 129 of file hashcomp.h. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/irc_InAddr_HashComp.3 b/docs/man/man3/irc_InAddr_HashComp.3 index 5127b013b..cf5d69b5a 100644 --- a/docs/man/man3/irc_InAddr_HashComp.3 +++ b/docs/man/man3/irc_InAddr_HashComp.3 @@ -1,4 +1,4 @@ -.TH "irc::InAddr_HashComp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "irc::InAddr_HashComp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -24,7 +24,7 @@ This class returns true if two in_addr structs match. Checking is done by copying both into a size_t then doing a numeric comparison of the two. .PP -Definition at line 77 of file hashcomp.h. +Definition at line 92 of file hashcomp.h. .SH "Member Function Documentation" .PP .SS "bool irc::InAddr_HashComp::operator() (const in_addr & s1, const in_addr & s2) const" diff --git a/docs/man/man3/irc_StrHashComp.3 b/docs/man/man3/irc_StrHashComp.3 index a6b8036e1..316b5ee4e 100644 --- a/docs/man/man3/irc_StrHashComp.3 +++ b/docs/man/man3/irc_StrHashComp.3 @@ -1,4 +1,4 @@ -.TH "irc::StrHashComp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "irc::StrHashComp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -24,7 +24,7 @@ This class returns true if two strings match. Case sensitivity is ignored, and the RFC 'character set' is adhered to .PP -Definition at line 65 of file hashcomp.h. +Definition at line 80 of file hashcomp.h. .SH "Member Function Documentation" .PP .SS "bool irc::StrHashComp::operator() (const std::string & s1, const std::string & s2) const" diff --git a/docs/man/man3/irc_irc_char_traits.3 b/docs/man/man3/irc_irc_char_traits.3 index d9ea0b512..037a35707 100644 --- a/docs/man/man3/irc_irc_char_traits.3 +++ b/docs/man/man3/irc_irc_char_traits.3 @@ -1,4 +1,4 @@ -.TH "irc::irc_char_traits" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "irc::irc_char_traits" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -42,7 +42,7 @@ The \fBirc_char_traits\fP class is used for RFC-style comparison of strings. This class is used to implement \fBirc::string\fP, a case-insensitive, RFC- comparing string class. .PP -Definition at line 89 of file hashcomp.h. +Definition at line 104 of file hashcomp.h. .SH "Member Function Documentation" .PP .SS "int irc::irc_char_traits::compare (const char * str1, const char * str2, size_t n)\fC [static]\fP" diff --git a/docs/man/man3/ircd_connector.3 b/docs/man/man3/ircd_connector.3 index 226b6797e..aae366a68 100644 --- a/docs/man/man3/ircd_connector.3 +++ b/docs/man/man3/ircd_connector.3 @@ -1,4 +1,4 @@ -.TH "ircd_connector" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ircd_connector" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -16,6 +16,10 @@ Inherits \fBExtensible\fP. .in +1c .ti -1c +.RI "\fBircd_connector\fP ()" +.br +.RI "\fIConstructor clears the sendq and initialises the fd to -1. \fP" +.ti -1c .RI "bool \fBMakeOutboundConnection\fP (char *newhost, int newport)" .br .RI "\fICreate an outbound connection to a listening socket. \fP" @@ -72,9 +76,9 @@ Inherits \fBExtensible\fP. .br .RI "\fIClose the connection by calling close() on its file descriptor This function call updates no other data. \fP" .ti -1c -.RI "void \fBAddBuffer\fP (std::string a)" +.RI "bool \fBAddBuffer\fP (std::string a)" .br -.RI "\fIThis method adds text to the ircd connection's buffer There is no limitation on how much text of what line width may be added to this buffer. \fP" +.RI "\fIThis method adds text to the ircd connection's buffer This buffer's maximum size is one megabyte, the method returning false if the buffer is full. \fP" .ti -1c .RI "bool \fBBufferIsComplete\fP ()" .br @@ -95,6 +99,34 @@ Inherits \fBExtensible\fP. .RI "std::string \fBGetVersionString\fP ()" .br .RI "\fIThis method returns the version string of the remote server. \fP" +.ti -1c +.RI "bool \fBAddWriteBuf\fP (std::string data)" +.br +.RI "\fIAdds data to the connection's sendQ to be flushed later Fails if there is an error pending on the connection. \fP" +.ti -1c +.RI "bool \fBFlushWriteBuf\fP ()" +.br +.RI "\fIFlushes as much of the data from the buffer as possible, and advances the queue pointer to what is left. \fP" +.ti -1c +.RI "void \fBSetWriteError\fP (std::string error)" +.br +.RI "\fISets the error string for this connection. \fP" +.ti -1c +.RI "std::string \fBGetWriteError\fP ()" +.br +.RI "\fIGets the error string for this connection. \fP" +.ti -1c +.RI "bool \fBHasBufferedOutput\fP ()" +.br +.RI "\fIReturns true if there is data to be written that hasn't been sent yet. \fP" +.ti -1c +.RI "bool \fBCheckPing\fP ()" +.br +.RI "\fIChecks if the connection replied to its last ping, and if it did sends another and returns true, if not, returns false. \fP" +.ti -1c +.RI "void \fBResetPing\fP ()" +.br +.RI "\fIResets the ping counter. \fP" .in -1c .SS "Public Attributes" @@ -153,6 +185,22 @@ Inherits \fBExtensible\fP. .RI "std::string \fBversion\fP" .br .RI "\fIThis string holds the ircd's version response. \fP" +.ti -1c +.RI "std::string \fBsendq\fP" +.br +.RI "\fISendQ of the outbound connector, does not have a limit. \fP" +.ti -1c +.RI "std::string \fBWriteError\fP" +.br +.RI "\fIWrite error of connection. \fP" +.ti -1c +.RI "time_t \fBnextping\fP" +.br +.RI "\fITime this connection was last pinged. \fP" +.ti -1c +.RI "bool \fBreplied\fP" +.br +.RI "\fIDid this connection reply to its last ping? \fP" .in -1c .SH "Detailed Description" .PP @@ -161,20 +209,34 @@ Each connection has one or more of these each represents ONE outbound connection A listening socket that accepts server type connections is represented by one class serverrec. Class serverrec will instantiate several objects of type ircd_connector to represent each established connection, inbound or outbound. So, to determine all linked servers you must walk through all the serverrecs that the core defines, and in each one iterate through until you find connection(s) relating to the server you want information on. The core and module API provide functions for this. .PP Definition at line 56 of file connection.h. +.SH "Constructor & Destructor Documentation" +.PP +.SS "ircd_connector::ircd_connector ()" +.PP +Constructor clears the sendq and initialises the fd to -1. .SH "Member Function Documentation" .PP -.SS "void ircd_connector::AddBuffer (std::string a)" +.SS "bool ircd_connector::AddBuffer (std::string a)" .PP -This method adds text to the ircd connection's buffer There is no limitation on how much text of what line width may be added to this buffer. It is the sending server's responsibility to ensure sent data is kept within reasonable quanities. +This method adds text to the ircd connection's buffer This buffer's maximum size is one megabyte, the method returning false if the buffer is full. +.SS "bool ircd_connector::AddWriteBuf (std::string data)" +.PP +Adds data to the connection's sendQ to be flushed later Fails if there is an error pending on the connection. Referenced by serverrec::SendPacket(). .SS "bool ircd_connector::BufferIsComplete ()" .PP This method returns true if the buffer contains at least one carriage return character, e.g. one line can be read from the buffer successfully. +.SS "bool ircd_connector::CheckPing ()" +.PP +Checks if the connection replied to its last ping, and if it did sends another and returns true, if not, returns false. .SS "void ircd_connector::ClearBuffer ()" .PP This method clears the server's buffer by setting it to an empty string. .SS "void ircd_connector::CloseConnection ()" .PP -Close the connection by calling close() on its file descriptor This function call updates no other data. +Close the connection by calling close() on its file descriptor This function call updates no other data. Referenced by serverrec::SendPacket(). +.SS "bool ircd_connector::FlushWriteBuf ()" +.PP +Flushes as much of the data from the buffer as possible, and advances the queue pointer to what is left. Referenced by serverrec::SendPacket(). .SS "std::string ircd_connector::GetBuffer ()" .PP This method retrieves the first string from the tail end of the buffer and advances the tail end of the buffer past the returned string, in a similar manner to strtok(). @@ -189,43 +251,55 @@ Get the file descriptor associated with this connection. Get the ip address (not servername) associated with this connection. .SS "std::string ircd_connector::GetServerName ()" .PP -Return the servername on this established connection. +Return the servername on this established connection. Referenced by serverrec::SendPacket(). .SS "int ircd_connector::GetServerPort ()" .PP Get the port number being used for this connection If the connection is outbound this will be the remote port otherwise it will be the local port, so it can always be gautanteed as open at the address given in \fBGetServerIP()\fP. .SS "int ircd_connector::GetState ()" .PP -Get the state flags for this connection. +Get the state flags for this connection. Referenced by serverrec::SendPacket(). .SS "std::string ircd_connector::GetVersionString ()" .PP This method returns the version string of the remote server. If the server has no version string an empty string is returned. +.SS "std::string ircd_connector::GetWriteError ()" +.PP +Gets the error string for this connection. Referenced by serverrec::SendPacket(). +.SS "bool ircd_connector::HasBufferedOutput ()" +.PP +Returns true if there is data to be written that hasn't been sent yet. .SS "bool ircd_connector::MakeOutboundConnection (char * newhost, int newport)" .PP -Create an outbound connection to a listening socket. +Create an outbound connection to a listening socket. Referenced by serverrec::BeginLink(), and serverrec::MeshCookie(). +.SS "void ircd_connector::ResetPing ()" +.PP +Resets the ping counter. .SS "void ircd_connector::SetDescription (std::string desc)" .PP Set the server description of this connection. .SS "void ircd_connector::SetDescriptor (int fd)" .PP -Set the file descriptor for this connection. +Set the file descriptor for this connection. Referenced by serverrec::AddIncoming(). .SS "bool ircd_connector::SetHostAddress (char * host, int port)\fC [private]\fP" .PP PRIVATE function to set the host address and port to connect to. .SS "bool ircd_connector::SetHostAndPort (char * newhost, int newport)" .PP -Set both the host and the port in one operation for this connection. +Set both the host and the port in one operation for this connection. Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), and serverrec::MeshCookie(). .SS "void ircd_connector::SetServerName (std::string serv)" .PP -Set the server name of this connection. +Set the server name of this connection. Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), and serverrec::MeshCookie(). .SS "void ircd_connector::SetServerPort (int p)" .PP Set the port used by this connection. .SS "void ircd_connector::SetState (int state)" .PP -Set the state flags for this connection. +Set the state flags for this connection. Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), serverrec::MeshCookie(), and serverrec::SendPacket(). .SS "void ircd_connector::SetVersionString (std::string newversion)" .PP This method sets the version string of the remote server. +.SS "void ircd_connector::SetWriteError (std::string error)" +.PP +Sets the error string for this connection. .SH "Member Data Documentation" .PP .SS "sockaddr_in \fBircd_connector::addr\fP\fC [private]\fP" @@ -239,18 +313,27 @@ Sockaddr of the outbound ip and port. Definition at line 61 of file connection.h File descriptor of the connection. Definition at line 65 of file connection.h. .SS "char \fBircd_connector::host\fP[MAXBUF]" .PP -When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 101 of file connection.h. +When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 117 of file connection.h. .SS "std::string \fBircd_connector::ircdbuffer\fP" .PP IRCD Buffer for input characters, holds as many lines as are pending - Note that the final line may not be complete and should only be read when there is a .br - seperator. Definition at line 94 of file connection.h. + seperator. Definition at line 110 of file connection.h. +.SS "time_t \fBircd_connector::nextping\fP\fC [private]\fP" +.PP +Time this connection was last pinged. Definition at line 98 of file connection.h. .SS "int \fBircd_connector::port\fP" .PP -When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 107 of file connection.h. +When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 123 of file connection.h. +.SS "bool \fBircd_connector::replied\fP\fC [private]\fP" +.PP +Did this connection reply to its last ping? Definition at line 102 of file connection.h. .SS "std::vector \fBircd_connector::routes\fP" .PP -\fBServer\fP names of servers that this server is linked to So for A->B->C, if this was the record for B it would contain A and C whilever both servers are connected to B. Definition at line 113 of file connection.h. +\fBServer\fP names of servers that this server is linked to So for A->B->C, if this was the record for B it would contain A and C whilever both servers are connected to B. Definition at line 129 of file connection.h. +.SS "std::string \fBircd_connector::sendq\fP\fC [private]\fP" +.PP +SendQ of the outbound connector, does not have a limit. Definition at line 90 of file connection.h. .SS "std::string \fBircd_connector::servername\fP\fC [private]\fP" .PP \fBServer\fP name. Definition at line 69 of file connection.h. @@ -260,6 +343,9 @@ State. STATE_NOAUTH_INBOUND, STATE_NOAUTH_OUTBOUND STATE_SYNC, STATE_DISCONNECTE .SS "std::string \fBircd_connector::version\fP\fC [private]\fP" .PP This string holds the ircd's version response. Definition at line 86 of file connection.h. +.SS "std::string \fBircd_connector::WriteError\fP\fC [private]\fP" +.PP +Write error of connection. Definition at line 94 of file connection.h. .SH "Author" .PP diff --git a/docs/man/man3/message.h.3 b/docs/man/man3/message.h.3 index 5b7529f6c..9d9feb812 100644 --- a/docs/man/man3/message.h.3 +++ b/docs/man/man3/message.h.3 @@ -1,4 +1,4 @@ -.TH "message.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "message.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -36,12 +36,6 @@ message.h \- .RI "void \fBtidystring\fP (char *str)" .br .ti -1c -.RI "void \fBsafedelete\fP (\fBchanrec\fP *p)" -.br -.ti -1c -.RI "void \fBsafedelete\fP (\fBuserrec\fP *p)" -.br -.ti -1c .RI "void \fBBlocking\fP (int s)" .br .ti -1c @@ -125,10 +119,6 @@ Referenced by Server::IsOnChannel(). Referenced by Server::IsNick(). .SS "void NonBlocking (int s)" .PP -.SS "void safedelete (\fBuserrec\fP * p)" -.PP -.SS "void safedelete (\fBchanrec\fP * p)" -.PP .SS "void send_network_quit (const char * nick, const char * reason)" .PP .SS "void TidyBan (char * ban)" diff --git a/docs/man/man3/mode.h.3 b/docs/man/man3/mode.h.3 index 51981f20d..fdf3e5628 100644 --- a/docs/man/man3/mode.h.3 +++ b/docs/man/man3/mode.h.3 @@ -1,4 +1,4 @@ -.TH "mode.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "mode.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/modules.cpp.3 b/docs/man/man3/modules.cpp.3 index 1c92ebe6c..1048e84e1 100644 --- a/docs/man/man3/modules.cpp.3 +++ b/docs/man/man3/modules.cpp.3 @@ -1,4 +1,4 @@ -.TH "modules.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "modules.cpp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -208,9 +208,6 @@ modules.cpp \- .RI "time_t \fBnb_start\fP" .br .ti -1c -.RI "std::vector< int > \fBfd_reap\fP" -.br -.ti -1c .RI "std::vector< std::string > \fBmodule_names\fP" .br .ti -1c @@ -272,160 +269,160 @@ modules.cpp \- .PP .SS "typedef nspace::hash_map, \fBirc::InAddr_HashComp\fP> \fBaddress_cache\fP" .PP -Definition at line 111 of file modules.cpp. +Definition at line 120 of file modules.cpp. .SS "typedef nspace::hash_map, \fBirc::StrHashComp\fP> \fBchan_hash\fP" .PP -Definition at line 110 of file modules.cpp. +Definition at line 119 of file modules.cpp. .SS "typedef std::deque<\fBcommand_t\fP> \fBcommand_table\fP" .PP -Definition at line 113 of file modules.cpp. +Definition at line 122 of file modules.cpp. .SS "typedef std::vector<\fBExtMode\fP> \fBExtModeList\fP" .PP -Definition at line 139 of file modules.cpp. +Definition at line 148 of file modules.cpp. .SS "typedef ExtModeList::iterator \fBExtModeListIter\fP" .PP -Definition at line 140 of file modules.cpp. +Definition at line 149 of file modules.cpp. .PP Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). .SS "typedef nspace::hash_map, \fBirc::StrHashComp\fP> \fBuser_hash\fP" .PP -Definition at line 109 of file modules.cpp. +Definition at line 118 of file modules.cpp. .SS "typedef nspace::hash_map, \fBirc::StrHashComp\fP> \fBwhowas_hash\fP" .PP -Definition at line 112 of file modules.cpp. +Definition at line 121 of file modules.cpp. .SH "Function Documentation" .PP .SS "bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off)" .PP -Definition at line 209 of file modules.cpp. +Definition at line 218 of file modules.cpp. .PP References EMode, and ModeDefined(). .PP Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode(). .PP .nf -210 { -211 if (ModeDefined(modechar,type)) { -212 return false; -213 } -214 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); -215 return true; -216 } +219 { +220 if (ModeDefined(modechar,type)) { +221 return false; +222 } +223 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); +224 return true; +225 } .fi .SS "std::vector<\fBircd_module\fP*> factory (255)" .PP .SS "bool ModeDefined (char modechar, int type)" .PP -Definition at line 146 of file modules.cpp. +Definition at line 155 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP Referenced by DoAddExtendedMode(). .PP .nf -147 { -148 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -149 { -150 if ((i->modechar == modechar) && (i->type == type)) -151 { -152 return true; -153 } -154 } -155 return false; -156 } +156 { +157 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +158 { +159 if ((i->modechar == modechar) && (i->type == type)) +160 { +161 return true; +162 } +163 } +164 return false; +165 } .fi .SS "int ModeDefinedOff (char modechar, int type)" .PP -Definition at line 196 of file modules.cpp. +Definition at line 205 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -197 { -198 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -199 { -200 if ((i->modechar == modechar) && (i->type == type)) -201 { -202 return i->params_when_off; -203 } -204 } -205 return 0; -206 } +206 { +207 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +208 { +209 if ((i->modechar == modechar) && (i->type == type)) +210 { +211 return i->params_when_off; +212 } +213 } +214 return 0; +215 } .fi .SS "int ModeDefinedOn (char modechar, int type)" .PP -Definition at line 183 of file modules.cpp. +Definition at line 192 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -184 { -185 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -186 { -187 if ((i->modechar == modechar) && (i->type == type)) -188 { -189 return i->params_when_on; -190 } -191 } -192 return 0; -193 } +193 { +194 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +195 { +196 if ((i->modechar == modechar) && (i->type == type)) +197 { +198 return i->params_when_on; +199 } +200 } +201 return 0; +202 } .fi .SS "bool ModeDefinedOper (char modechar, int type)" .PP -Definition at line 170 of file modules.cpp. +Definition at line 179 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -171 { -172 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -173 { -174 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) -175 { -176 return true; -177 } -178 } -179 return false; -180 } +180 { +181 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +182 { +183 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) +184 { +185 return true; +186 } +187 } +188 return false; +189 } .fi .SS "bool ModeIsListMode (char modechar, int type)" .PP -Definition at line 158 of file modules.cpp. +Definition at line 167 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -159 { -160 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -161 { -162 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) -163 { -164 return true; -165 } -166 } -167 return false; -168 } +168 { +169 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +170 { +171 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) +172 { +173 return true; +174 } +175 } +176 return false; +177 } .fi .SS "void ModeMakeList (char modechar)" .PP -Definition at line 219 of file modules.cpp. +Definition at line 228 of file modules.cpp. .PP References EMode, ExtModeListIter, and MT_CHANNEL. .PP Referenced by Server::AddExtendedListMode(). .PP .nf -220 { -221 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -222 { -223 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) -224 { -225 i->list = true; -226 return; -227 } -228 } -229 return; -230 } +229 { +230 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +231 { +232 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) +233 { +234 i->list = true; +235 return; +236 } +237 } +238 return; +239 } .fi .SS "std::vector<\fBModule\fP*> modules (255)" .PP @@ -433,146 +430,143 @@ Referenced by Server::AddExtendedListMode(). .PP .SS "char \fBAdminEmail\fP[MAXBUF]" .PP -Definition at line 72 of file modules.cpp. +Definition at line 82 of file modules.cpp. .SS "char \fBAdminName\fP[MAXBUF]" .PP -Definition at line 71 of file modules.cpp. +Definition at line 81 of file modules.cpp. .SS "char \fBAdminNick\fP[MAXBUF]" .PP -Definition at line 73 of file modules.cpp. +Definition at line 83 of file modules.cpp. .SS "std::vector \fBauth_cookies\fP" .PP -Definition at line 100 of file modules.cpp. +Definition at line 109 of file modules.cpp. .SS "int \fBboundPortCount\fP" .PP -Definition at line 94 of file modules.cpp. +Definition at line 103 of file modules.cpp. .SS "\fBchan_hash\fP \fBchanlist\fP" .PP -Definition at line 117 of file modules.cpp. +Definition at line 126 of file modules.cpp. .SS "\fBuser_hash\fP \fBclientlist\fP" .PP -Definition at line 116 of file modules.cpp. +Definition at line 125 of file modules.cpp. .SS "\fBcommand_table\fP \fBcmdlist\fP" .PP -Definition at line 119 of file modules.cpp. +Definition at line 128 of file modules.cpp. .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 101 of file modules.cpp. +Definition at line 110 of file modules.cpp. .SS "int \fBdebugging\fP" .PP -Definition at line 82 of file modules.cpp. +Definition at line 92 of file modules.cpp. .SS "int \fBdefaultRoute\fP" .PP -Definition at line 98 of file modules.cpp. +Definition at line 107 of file modules.cpp. .SS "int \fBDieDelay\fP" .PP -Definition at line 85 of file modules.cpp. +Definition at line 95 of file modules.cpp. .SS "char \fBdiepass\fP[MAXBUF]" .PP -Definition at line 74 of file modules.cpp. +Definition at line 84 of file modules.cpp. .SS "char \fBDieValue\fP[MAXBUF]" .PP -Definition at line 80 of file modules.cpp. +Definition at line 90 of file modules.cpp. .SS "\fBExtModeList\fP \fBEMode\fP" .PP -Definition at line 143 of file modules.cpp. +Definition at line 152 of file modules.cpp. .PP Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). .SS "std::vector<\fBircd_module\fP*> factory" .PP -Definition at line 63 of file modules.cpp. -.SS "std::vector \fBfd_reap\fP" -.PP -Definition at line 91 of file modules.cpp. +Definition at line 73 of file modules.cpp. .SS "\fBuserrec\fP* \fBfd_ref_table\fP[65536]" .PP -Definition at line 107 of file modules.cpp. +Definition at line 116 of file modules.cpp. .PP Referenced by Server::FindDescriptor(), and Server::PseudoToUser(). .SS "\fBaddress_cache\fP \fBIP\fP" .PP -Definition at line 122 of file modules.cpp. +Definition at line 131 of file modules.cpp. .SS "char \fBlist\fP[MAXBUF]" .PP -Definition at line 78 of file modules.cpp. +Definition at line 88 of file modules.cpp. .SS "FILE* \fBlog_file\fP" .PP -Definition at line 105 of file modules.cpp. +Definition at line 114 of file modules.cpp. .SS "int \fBLogLevel\fP" .PP -Definition at line 67 of file modules.cpp. +Definition at line 77 of file modules.cpp. .SS "int \fBMaxWhoResults\fP" .PP -Definition at line 88 of file modules.cpp. +Definition at line 98 of file modules.cpp. .SS "\fBserverrec\fP* \fBme\fP[32]" .PP -Definition at line 103 of file modules.cpp. +Definition at line 112 of file modules.cpp. .SS "int \fBMODCOUNT\fP = -1" .PP -Definition at line 996 of file modules.cpp. +Definition at line 1016 of file modules.cpp. .SS "std::vector \fBmodule_names\fP" .PP -Definition at line 92 of file modules.cpp. +Definition at line 101 of file modules.cpp. .SS "std::vector<\fBModule\fP*> modules" .PP -Definition at line 62 of file modules.cpp. +Definition at line 72 of file modules.cpp. .SS "\fBfile_cache\fP \fBMOTD\fP" .PP -Definition at line 120 of file modules.cpp. +Definition at line 129 of file modules.cpp. .SS "char \fBmotd\fP[MAXBUF]" .PP -Definition at line 76 of file modules.cpp. +Definition at line 86 of file modules.cpp. .SS "time_t \fBnb_start\fP" .PP -Definition at line 89 of file modules.cpp. +Definition at line 99 of file modules.cpp. .SS "int \fBNetBufferSize\fP" .PP -Definition at line 87 of file modules.cpp. +Definition at line 97 of file modules.cpp. .SS "char \fBNetwork\fP[MAXBUF]" .PP -Definition at line 69 of file modules.cpp. +Definition at line 79 of file modules.cpp. .SS "int \fBportCount\fP" .PP -Definition at line 95 of file modules.cpp. +Definition at line 104 of file modules.cpp. .SS "int \fBports\fP[MAXSOCKS]" .PP -Definition at line 97 of file modules.cpp. +Definition at line 106 of file modules.cpp. .SS "char \fBPrefixQuit\fP[MAXBUF]" .PP -Definition at line 79 of file modules.cpp. +Definition at line 89 of file modules.cpp. .SS "char \fBrestartpass\fP[MAXBUF]" .PP -Definition at line 75 of file modules.cpp. +Definition at line 85 of file modules.cpp. .SS "\fBfile_cache\fP \fBRULES\fP" .PP -Definition at line 121 of file modules.cpp. +Definition at line 130 of file modules.cpp. .SS "char \fBrules\fP[MAXBUF]" .PP -Definition at line 77 of file modules.cpp. +Definition at line 87 of file modules.cpp. .SS "char \fBServerDesc\fP[MAXBUF]" .PP -Definition at line 70 of file modules.cpp. +Definition at line 80 of file modules.cpp. .SS "char \fBServerName\fP[MAXBUF]" .PP -Definition at line 68 of file modules.cpp. +Definition at line 78 of file modules.cpp. .SS "int \fBSERVERportCount\fP" .PP -Definition at line 96 of file modules.cpp. +Definition at line 105 of file modules.cpp. .SS "time_t \fBstartup_time\fP" .PP -Definition at line 86 of file modules.cpp. +Definition at line 96 of file modules.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 65 of file modules.cpp. +Definition at line 75 of file modules.cpp. .SS "\fBwhowas_hash\fP \fBwhowas\fP" .PP -Definition at line 118 of file modules.cpp. +Definition at line 127 of file modules.cpp. .SS "int \fBWHOWAS_MAX\fP" .PP -Definition at line 84 of file modules.cpp. +Definition at line 94 of file modules.cpp. .SS "int \fBWHOWAS_STALE\fP" .PP -Definition at line 83 of file modules.cpp. +Definition at line 93 of file modules.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/modules.h.3 b/docs/man/man3/modules.h.3 index 38bf3733a..d33285313 100644 --- a/docs/man/man3/modules.h.3 +++ b/docs/man/man3/modules.h.3 @@ -1,4 +1,4 @@ -.TH "modules.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "modules.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -252,7 +252,7 @@ Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigR .PP Definition at line 23 of file modules.h. .PP -Referenced by Server::AddExtendedMode(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), userrec::RemoveInvite(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo(). +Referenced by Server::AddExtendedMode(), serverrec::AddIncoming(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), serverrec::RecvPacket(), userrec::RemoveInvite(), serverrec::SendPacket(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo(). .SS "#define DEFAULT 30" .PP Definition at line 25 of file modules.h. diff --git a/docs/man/man3/nspace.3 b/docs/man/man3/nspace.3 index cbe375840..ef0f57177 100644 --- a/docs/man/man3/nspace.3 +++ b/docs/man/man3/nspace.3 @@ -1,4 +1,4 @@ -.TH "nspace" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/nspace_nspace_hash_ in_addr _.3 b/docs/man/man3/nspace_nspace_hash_ in_addr _.3 index a21b8fa75..3cb96ec0c 100644 --- a/docs/man/man3/nspace_nspace_hash_ in_addr _.3 +++ b/docs/man/man3/nspace_nspace_hash_ in_addr _.3 @@ -1,4 +1,4 @@ -.TH "nspace::nspace::hash< in_addr >" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace::nspace::hash< in_addr >" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/nspace_nspace_hash_ string _.3 b/docs/man/man3/nspace_nspace_hash_ string _.3 index 58c32c257..4821ed0a5 100644 --- a/docs/man/man3/nspace_nspace_hash_ string _.3 +++ b/docs/man/man3/nspace_nspace_hash_ string _.3 @@ -1,4 +1,4 @@ -.TH "nspace::nspace::hash< string >" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace::nspace::hash< string >" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/serverrec.3 b/docs/man/man3/serverrec.3 index 6dd9d4387..128d70f37 100644 --- a/docs/man/man3/serverrec.3 +++ b/docs/man/man3/serverrec.3 @@ -1,4 +1,4 @@ -.TH "serverrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "serverrec" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -27,6 +27,42 @@ Inherits \fBconnection\fP. .RI "\fB~serverrec\fP ()" .br .RI "\fIDestructor. \fP" +.ti -1c +.RI "bool \fBCreateListener\fP (char *\fBhost\fP, int p)" +.br +.RI "\fICreate a listening socket on 'host' using port number 'p'. \fP" +.ti -1c +.RI "bool \fBBeginLink\fP (char *targethost, int \fBport\fP, char *password, char *servername, int myport)" +.br +.RI "\fIBegin an outbound link to another ircd at targethost. \fP" +.ti -1c +.RI "bool \fBMeshCookie\fP (char *targethost, int \fBport\fP, unsigned long cookie, char *servername)" +.br +.RI "\fIBegin an outbound mesh link to another ircd on a network you are already an authenticated member of. \fP" +.ti -1c +.RI "void \fBTerminateLink\fP (char *targethost)" +.br +.RI "\fITerminate a link to 'targethost' by calling the \fBircd_connector::CloseConnection\fP method. \fP" +.ti -1c +.RI "bool \fBSendPacket\fP (char *message, const char *\fBhost\fP)" +.br +.RI "\fISend a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. \fP" +.ti -1c +.RI "bool \fBRecvPacket\fP (std::deque< std::string > &messages, char *\fBhost\fP, std::deque< std::string > &sums)" +.br +.RI "\fIReturns the next available packet and returns true if data is available. \fP" +.ti -1c +.RI "\fBircd_connector\fP * \fBFindHost\fP (std::string \fBhost\fP)" +.br +.RI "\fIFind the \fBircd_connector\fP oject related to a certain servername given in 'host'. \fP" +.ti -1c +.RI "bool \fBAddIncoming\fP (int \fBfd\fP, char *targethost, int sourceport)" +.br +.RI "\fIAdd an incoming connection to the connection pool. \fP" +.ti -1c +.RI "void \fBFlushWriteBuffers\fP ()" +.br +.RI "\fIFlushes all data waiting to be written for all of this server's connections. \fP" .in -1c .SS "Public Attributes" @@ -74,6 +110,10 @@ Inherits \fBconnection\fP. .ti -1c .RI "bool \fBsync_soon\fP" .br +.ti -1c +.RI "std::vector< \fBircd_connector\fP > \fBconnectors\fP" +.br +.RI "\fIWith a serverrec, this is a list of all established server connections. \fP" .in -1c .SH "Detailed Description" .PP @@ -82,54 +122,476 @@ A class that defines the local server or a remote server. Definition at line 30 .PP .SS "serverrec::serverrec ()" .PP -Constructor. Definition at line 27 of file servers.cpp. +Constructor. Definition at line 42 of file servers.cpp. .PP -References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connectors, connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. .PP .nf -28 { -29 strlcpy(name,'',256); -30 pingtime = 0; -31 lastping = TIME; -32 usercount_i = usercount = opercount = version = 0; -33 hops_away = 1; -34 signon = TIME; -35 jupiter = false; -36 fd = 0; -37 sync_soon = false; -38 strlcpy(nickserv,'',NICKMAX); -39 } +43 { +44 strlcpy(name,'',256); +45 pingtime = 0; +46 lastping = TIME; +47 usercount_i = usercount = opercount = version = 0; +48 hops_away = 1; +49 signon = TIME; +50 jupiter = false; +51 fd = 0; +52 sync_soon = false; +53 strlcpy(nickserv,'',NICKMAX); +54 connectors.clear(); +55 } .fi .SS "serverrec::serverrec (char * n, long ver, bool jupe)" .PP -Constructor which initialises some of the main variables. Definition at line 46 of file servers.cpp. +Constructor which initialises some of the main variables. Definition at line 62 of file servers.cpp. .PP -References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connectors, connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. .PP .nf -47 { -48 strlcpy(name,n,256); -49 lastping = TIME; -50 usercount_i = usercount = opercount = 0; -51 version = ver; -52 hops_away = 1; -53 signon = TIME; -54 jupiter = jupe; -55 fd = 0; -56 sync_soon = false; -57 strlcpy(nickserv,'',NICKMAX); -58 } +63 { +64 strlcpy(name,n,256); +65 lastping = TIME; +66 usercount_i = usercount = opercount = 0; +67 version = ver; +68 hops_away = 1; +69 signon = TIME; +70 jupiter = jupe; +71 fd = 0; +72 sync_soon = false; +73 strlcpy(nickserv,'',NICKMAX); +74 connectors.clear(); +75 } .fi .SS "serverrec::~\fBserverrec\fP ()" .PP -Destructor. Definition at line 42 of file servers.cpp. +Destructor. Definition at line 58 of file servers.cpp. .PP .nf -43 { -44 } +59 { +60 } +.fi +.SH "Member Function Documentation" +.PP +.SS "bool serverrec::AddIncoming (int fd, char * targethost, int sourceport)" +.PP +Add an incoming connection to the connection pool. (reserved for core use) Definition at line 207 of file servers.cpp. +.PP +References connectors, DEBUG, ircd_connector::SetDescriptor(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), and STATE_NOAUTH_INBOUND. +.PP +.nf +208 { +209 ircd_connector connector; +210 +211 // targethost has been turned into an ip... +212 // we dont want this as the server name. +213 connector.SetServerName(targethost); +214 connector.SetDescriptor(newfd); +215 connector.SetState(STATE_NOAUTH_INBOUND); +216 int flags = fcntl(newfd, F_GETFL, 0); +217 fcntl(newfd, F_SETFL, flags | O_NONBLOCK); +218 int sendbuf = 32768; +219 int recvbuf = 32768; +220 setsockopt(newfd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf)); +221 setsockopt(newfd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf)); +222 connector.SetHostAndPort(targethost, sourceport); +223 connector.SetState(STATE_NOAUTH_INBOUND); +224 log(DEBUG,'serverrec::AddIncoming() Added connection: %s:%d',targethost,sourceport); +225 this->connectors.push_back(connector); +226 return true; +227 } +.fi +.SS "bool serverrec::BeginLink (char * targethost, int port, char * password, char * servername, int myport)" +.PP +Begin an outbound link to another ircd at targethost. Definition at line 138 of file servers.cpp. +.PP +References connectors, connection::fd, FindHost(), ircd_connector::MakeOutboundConnection(), SendPacket(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), STATE_DISCONNECTED, and STATE_NOAUTH_OUTBOUND. +.PP +.nf +139 { +140 char connect[MAXBUF]; +141 +142 ircd_connector connector; +143 ircd_connector *cn = this->FindHost(servername); +144 +145 +146 if (cn) +147 { +148 WriteOpers('CONNECT aborted: Server %s already exists',servername); +149 return false; +150 } +151 +152 +153 if (this->fd) +154 { +155 if (connector.MakeOutboundConnection(targethost,newport)) +156 { +157 // targethost has been turned into an ip... +158 // we dont want this as the server name. +159 connector.SetServerName(servername); +160 snprintf(connect,MAXBUF,'S %s %s %lu %s :%s',getservername().c_str(),password,(unsigned long)myport,GetRevision().c_str(),getserverdesc().c_str()); +161 connector.SetState(STATE_NOAUTH_OUTBOUND); +162 connector.SetHostAndPort(targethost, newport); +163 this->connectors.push_back(connector); +164 return this->SendPacket(connect, servername); +165 } +166 else +167 { +168 connector.SetState(STATE_DISCONNECTED); +169 WriteOpers('Could not create outbound connection to %s:%d',targethost,newport); +170 } +171 } +172 return false; +173 } +.fi +.SS "bool serverrec::CreateListener (char * host, int p)" +.PP +Create a listening socket on 'host' using port number 'p'. Definition at line 77 of file servers.cpp. +.PP +References connection::fd, MaxConn, and connection::port. +.PP +.nf +78 { +79 sockaddr_in host_address; +80 int flags; +81 in_addr addy; +82 int on = 0; +83 struct linger linger = { 0 }; +84 +85 this->port = p; +86 +87 fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); +88 if (fd <= 0) +89 { +90 return false; +91 } +92 +93 setsockopt(fd,SOL_SOCKET,SO_REUSEADDR,(const char*)&on,sizeof(on)); +94 linger.l_onoff = 1; +95 linger.l_linger = 1; +96 setsockopt(fd,SOL_SOCKET,SO_LINGER,(const char*)&linger,sizeof(linger)); +97 +98 // attempt to increase socket sendq and recvq as high as its possible +99 // to get them on linux. +100 int sendbuf = 32768; +101 int recvbuf = 32768; +102 setsockopt(fd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf)); +103 setsockopt(fd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf)); +104 +105 memset((void*)&host_address, 0, sizeof(host_address)); +106 +107 host_address.sin_family = AF_INET; +108 +109 if (!strcmp(newhost,'')) +110 { +111 host_address.sin_addr.s_addr = htonl(INADDR_ANY); +112 } +113 else +114 { +115 inet_aton(newhost,&addy); +116 host_address.sin_addr = addy; +117 } +118 +119 host_address.sin_port = htons(p); +120 +121 if (bind(fd,(sockaddr*)&host_address,sizeof(host_address))<0) +122 { +123 return false; +124 } +125 +126 // make the socket non-blocking +127 flags = fcntl(fd, F_GETFL, 0); +128 fcntl(fd, F_SETFL, flags | O_NONBLOCK); +129 +130 this->port = p; +131 +132 listen(this->fd, MaxConn); +133 +134 return true; +135 } +.fi +.SS "\fBircd_connector\fP * serverrec::FindHost (std::string host)" +.PP +Find the \fBircd_connector\fP oject related to a certain servername given in 'host'. Definition at line 237 of file servers.cpp. +.PP +References connectors. +.PP +Referenced by BeginLink(), and SendPacket(). +.PP +.nf +238 { +239 for (int i = 0; i < this->connectors.size(); i++) +240 { +241 if (this->connectors[i].GetServerName() == findhost) +242 { +243 return &this->connectors[i]; +244 } +245 } +246 return NULL; +247 } +.fi +.SS "void serverrec::FlushWriteBuffers ()" +.PP +Flushes all data waiting to be written for all of this server's connections. Definition at line 249 of file servers.cpp. +.PP +References connectors, and STATE_DISCONNECTED. +.PP +.nf +250 { +251 for (int i = 0; i < this->connectors.size(); i++) +252 { +253 if (this->connectors[i].GetState() != STATE_DISCONNECTED) +254 { +255 if (!this->connectors[i].CheckPing()) +256 { +257 WriteOpers('*** Lost single connection to %s: Ping timeout',this->connectors[i].GetServerName().c_str()); +258 this->connectors[i].CloseConnection(); +259 this->connectors[i].SetState(STATE_DISCONNECTED); +260 } +261 } +262 if (this->connectors[i].HasBufferedOutput()) +263 { +264 if (!this->connectors[i].FlushWriteBuf()) +265 { +266 // if we're here the write() caused an error, we cannot proceed +267 WriteOpers('*** Lost single connection to %s, link inactive and retrying: %s',this->connectors[i].GetServerName().c_str(),this->connectors[i].GetWriteError().c_str()); +268 this->connectors[i].CloseConnection(); +269 this->connectors[i].SetState(STATE_DISCONNECTED); +270 } +271 } +272 } +273 } +.fi +.SS "bool serverrec::MeshCookie (char * targethost, int port, unsigned long cookie, char * servername)" +.PP +Begin an outbound mesh link to another ircd on a network you are already an authenticated member of. Definition at line 176 of file servers.cpp. +.PP +References connectors, connection::fd, ircd_connector::MakeOutboundConnection(), SendPacket(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), STATE_CONNECTED, STATE_DISCONNECTED, and STATE_NOAUTH_OUTBOUND. +.PP +.nf +177 { +178 char connect[MAXBUF]; +179 +180 ircd_connector connector; +181 +182 WriteOpers('Establishing meshed link to %s:%d',servername,newport); +183 +184 if (this->fd) +185 { +186 if (connector.MakeOutboundConnection(targethost,newport)) +187 { +188 // targethost has been turned into an ip... +189 // we dont want this as the server name. +190 connector.SetServerName(servername); +191 snprintf(connect,MAXBUF,'- %lu %s :%s',cookie,getservername().c_str(),getserverdesc().c_str()); +192 connector.SetState(STATE_NOAUTH_OUTBOUND); +193 connector.SetHostAndPort(targethost, newport); +194 connector.SetState(STATE_CONNECTED); +195 this->connectors.push_back(connector); +196 return this->SendPacket(connect, servername); +197 } +198 else +199 { +200 connector.SetState(STATE_DISCONNECTED); +201 WriteOpers('Could not create outbound connection to %s:%d',targethost,newport); +202 } +203 } +204 return false; +205 } +.fi +.SS "bool serverrec::RecvPacket (std::deque< std::string > & messages, char * host, std::deque< std::string > & sums)" +.PP +Returns the next available packet and returns true if data is available. Writes the servername the data came from to 'host'. If no data is available this function returns false. This function will automatically close broken links and reroute pathways, generating split messages on the network. Definition at line 370 of file servers.cpp. +.PP +References already_have_sum(), connectors, DEBUG, and STATE_DISCONNECTED. +.PP +.nf +371 { +372 char data[65536]; +373 memset(data, 0, 65536); +374 for (int i = 0; i < this->connectors.size(); i++) +375 { +376 if (this->connectors[i].GetState() != STATE_DISCONNECTED) +377 { +378 // returns false if the packet could not be sent (e.g. target host down) +379 int rcvsize = 0; +380 +381 // check if theres any data on this socket +382 // if not, continue onwards to the next. +383 pollfd polls; +384 polls.fd = this->connectors[i].GetDescriptor(); +385 polls.events = POLLIN; +386 int ret = poll(&polls,1,1); +387 if (ret <= 0) continue; +388 +389 rcvsize = recv(this->connectors[i].GetDescriptor(),data,65000,0); +390 data[rcvsize] = '\0'; +391 if (rcvsize == -1) +392 { +393 if (errno != EAGAIN) +394 { +395 log(DEBUG,'recv() failed for serverrec::RecvPacket(): %s',strerror(errno)); +396 log(DEBUG,'Disabling connector: %s',this->connectors[i].GetServerName().c_str()); +397 this->connectors[i].CloseConnection(); +398 this->connectors[i].SetState(STATE_DISCONNECTED); +399 } +400 } +401 int pushed = 0; +402 if (rcvsize > 0) +403 { +404 if (!this->connectors[i].AddBuffer(data)) +405 { +406 WriteOpers('*** Read buffer for %s exceeds maximum, closing connection!',this->connectors[i].GetServerName().c_str()); +407 this->connectors[i].CloseConnection(); +408 this->connectors[i].SetState(STATE_DISCONNECTED); +409 } +410 if (this->connectors[i].BufferIsComplete()) +411 { +412 this->connectors[i].ResetPing(); +413 while (this->connectors[i].BufferIsComplete()) +414 { +415 std::string text = this->connectors[i].GetBuffer(); +416 if (text != '') +417 { +418 if ((text[0] == ':') && (text.find(' ') != std::string::npos)) +419 { +420 std::string orig = text; +421 log(DEBUG,'Original: %s',text.c_str()); +422 std::string sum = text.substr(1,text.find(' ')-1); +423 text = text.substr(text.find(' ')+1,text.length()); +424 std::string possible_token = text.substr(1,text.find(' ')-1); +425 if (possible_token.length() > 1) +426 { +427 sums.push_back('*'); +428 text = orig; +429 log(DEBUG,'Non-mesh, non-tokenized string passed up the chain'); +430 } +431 else +432 { +433 log(DEBUG,'Packet sum: '%s'',sum.c_str()); +434 if ((already_have_sum(sum)) && (sum != '*')) +435 { +436 // we don't accept dupes +437 continue; +438 } +439 sums.push_back(sum.c_str()); +440 } +441 } +442 else sums.push_back('*'); +443 messages.push_back(text.c_str()); +444 strlcpy(recvhost,this->connectors[i].GetServerName().c_str(),160); +445 log(DEBUG,'serverrec::RecvPacket() %d:%s->%s',pushed++,recvhost,text.c_str()); +446 } +447 } +448 return true; +449 } +450 } +451 } +452 } +453 // nothing new yet -- message and host will be undefined +454 return false; +455 } +.fi +.SS "bool serverrec::SendPacket (char * message, const char * host)" +.PP +Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. Definition at line 275 of file servers.cpp. +.PP +References ircd_connector::AddWriteBuf(), ircd_connector::CloseConnection(), connectors, DEBUG, FindHost(), ircd_connector::FlushWriteBuf(), ircd_connector::GetServerName(), ircd_connector::GetState(), ircd_connector::GetWriteError(), ircd_connector::SetState(), and STATE_DISCONNECTED. +.PP +Referenced by BeginLink(), and MeshCookie(). +.PP +.nf +276 { +277 if ((!message) || (!sendhost)) +278 return true; +279 +280 ircd_connector* cn = this->FindHost(sendhost); +281 +282 if (!strchr(message,'\n')) +283 { +284 strlcat(message,'\n',MAXBUF); +285 } +286 +287 if (cn) +288 { +289 log(DEBUG,'main: serverrec::SendPacket() sent '%s' to %s',message,cn->GetServerName().c_str()); +290 +291 if (cn->GetState() == STATE_DISCONNECTED) +292 { +293 // fix: can only route one hop to avoid a loop +294 if (strncmp(message,'R ',2)) +295 { +296 log(DEBUG,'Not a double reroute'); +297 // this route is down, we must re-route the packet through an available point in the mesh. +298 for (int k = 0; k < this->connectors.size(); k++) +299 { +300 log(DEBUG,'Check connector %d: %s',k,this->connectors[k].GetServerName().c_str()); +301 // search for another point in the mesh which can 'reach' where we want to go +302 for (int m = 0; m < this->connectors[k].routes.size(); m++) +303 { +304 if (!strcasecmp(this->connectors[k].routes[m].c_str(),sendhost)) +305 { +306 log(DEBUG,'Found alternative route for packet: %s',this->connectors[k].GetServerName().c_str()); +307 char buffer[MAXBUF]; +308 snprintf(buffer,MAXBUF,'R %s %s',sendhost,message); +309 this->SendPacket(buffer,this->connectors[k].GetServerName().c_str()); +310 return true; +311 } +312 } +313 } +314 } +315 char buffer[MAXBUF]; +316 snprintf(buffer,MAXBUF,'& %s',sendhost); +317 WriteOpers('*** All connections to %s lost.',sendhost); +318 NetSendToAllExcept(sendhost,buffer); +319 DoSplit(sendhost); +320 return false; +321 } +322 +323 // returns false if the packet could not be sent (e.g. target host down) +324 if (!cn->AddWriteBuf(message)) +325 { +326 // if we're here, there was an error pending, and the send cannot proceed +327 log(DEBUG,'cn->AddWriteBuf() failed for serverrec::SendPacket(): %s',cn->GetWriteError().c_str()); +328 log(DEBUG,'Disabling connector: %s',cn->GetServerName().c_str()); +329 cn->CloseConnection(); +330 cn->SetState(STATE_DISCONNECTED); +331 WriteOpers('*** Lost single connection to %s, link inactive and retrying: %s',cn->GetServerName().c_str(),cn->GetWriteError().c_str()); +332 // retry the packet along a new route so either arrival OR failure are gauranteed (bugfix) +333 return this->SendPacket(message,sendhost); +334 } +335 if (!cn->FlushWriteBuf()) +336 { +337 // if we're here the write() caused an error, we cannot proceed +338 log(DEBUG,'cn->FlushWriteBuf() failed for serverrec::SendPacket(): %s',cn->GetWriteError().c_str()); +339 log(DEBUG,'Disabling connector: %s',cn->GetServerName().c_str()); +340 cn->CloseConnection(); +341 cn->SetState(STATE_DISCONNECTED); +342 WriteOpers('*** Lost single connection to %s, link inactive and retrying: %s',cn->GetServerName().c_str(),cn->GetWriteError().c_str()); +343 // retry the packet along a new route so either arrival OR failure are gauranteed +344 return this->SendPacket(message,sendhost); +345 } +346 return true; +347 } +348 } +.fi +.SS "void serverrec::TerminateLink (char * targethost)" +.PP +Terminate a link to 'targethost' by calling the \fBircd_connector::CloseConnection\fP method. Definition at line 229 of file servers.cpp. +.PP +.nf +230 { +231 // this locates the targethost in the serverrec::connectors vector of the class, +232 // and terminates it by sending it an SQUIT token and closing its descriptor. +233 // TerminateLink with a null string causes a terminate of ALL links +234 } .fi .SH "Member Data Documentation" .PP +.SS "std::vector<\fBircd_connector\fP> \fBserverrec::connectors\fP" +.PP +With a serverrec, this is a list of all established server connections. Definition at line 81 of file servers.h. +.PP +Referenced by AddIncoming(), BeginLink(), FindHost(), FlushWriteBuffers(), MeshCookie(), RecvPacket(), SendPacket(), and serverrec(). .SS "char \fBserverrec::description\fP[MAXBUF]" .PP Description of the server. Definition at line 61 of file servers.h. diff --git a/docs/man/man3/servers.cpp.3 b/docs/man/man3/servers.cpp.3 index af036f7c6..02500d311 100644 --- a/docs/man/man3/servers.cpp.3 +++ b/docs/man/man3/servers.cpp.3 @@ -1,4 +1,4 @@ -.TH "servers.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "servers.cpp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -12,7 +12,25 @@ servers.cpp \- .br \fC#include 'inspircd.h'\fP .br -\fC#include \fP +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP +.br +\fC#include \fP .br \fC#include \fP .br @@ -20,19 +38,71 @@ servers.cpp \- .br \fC#include 'helperfuncs.h'\fP .br +\fC#include 'connection.h'\fP +.br + +.SS "Functions" +.in +1c +.ti -1c +.RI "bool \fBalready_have_sum\fP (std::string sum)" +.br +.in -1c .SS "Variables" .in +1c .ti -1c .RI "time_t \fBTIME\fP" .br +.ti -1c +.RI "int \fBMaxConn\fP" +.br +.ti -1c +.RI "std::deque< std::string > \fBxsums\fP" +.br .in -1c +.SH "Function Documentation" +.PP +.SS "bool already_have_sum (std::string sum)" +.PP +Definition at line 350 of file servers.cpp. +.PP +References xsums. +.PP +Referenced by serverrec::RecvPacket(). +.PP +.nf +351 { +352 for (int i = 0; i < xsums.size(); i++) +353 { +354 if (xsums[i] == sum) +355 { +356 return true; +357 } +358 } +359 if (xsums.size() >= 128) +360 { +361 xsums.pop_front(); +362 } +363 xsums.push_back(sum); +364 return false; +365 } +.fi .SH "Variable Documentation" .PP +.SS "int \fBMaxConn\fP" +.PP +Definition at line 38 of file servers.cpp. +.PP +Referenced by serverrec::CreateListener(). .SS "time_t \fBTIME\fP" .PP -Definition at line 25 of file servers.cpp. +Definition at line 37 of file servers.cpp. +.SS "std::deque \fBxsums\fP" +.PP +Definition at line 40 of file servers.cpp. +.PP +Referenced by already_have_sum(). .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/servers.h.3 b/docs/man/man3/servers.h.3 index a048d2a6e..19096a747 100644 --- a/docs/man/man3/servers.h.3 +++ b/docs/man/man3/servers.h.3 @@ -1,4 +1,4 @@ -.TH "servers.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "servers.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/std.3 b/docs/man/man3/std.3 index 6d1a2ae72..3299bba05 100644 --- a/docs/man/man3/std.3 +++ b/docs/man/man3/std.3 @@ -1,4 +1,4 @@ -.TH "std" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "std" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/std_char_traits.3 b/docs/man/man3/std_char_traits.3 index 64a98bafc..b53703016 100644 --- a/docs/man/man3/std_char_traits.3 +++ b/docs/man/man3/std_char_traits.3 @@ -1,4 +1,4 @@ -.TH "std::char_traits" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "std::char_traits" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ucrec.3 b/docs/man/man3/ucrec.3 index efe396234..7a868658d 100644 --- a/docs/man/man3/ucrec.3 +++ b/docs/man/man3/ucrec.3 @@ -1,4 +1,4 @@ -.TH "ucrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ucrec" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/userrec.3 b/docs/man/man3/userrec.3 index 61e70f590..427011fd8 100644 --- a/docs/man/man3/userrec.3 +++ b/docs/man/man3/userrec.3 @@ -1,4 +1,4 @@ -.TH "userrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "userrec" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -46,6 +46,10 @@ Inherits \fBconnection\fP. .br .RI "\fIReturns true or false for if a user can execute a privilaged oper command. \fP" .ti -1c +.RI "int \fBReadData\fP (void *buffer, size_t size)" +.br +.RI "\fICalls read() to read some data for this user using their fd. \fP" +.ti -1c .RI "bool \fBAddBuffer\fP (std::string a)" .br .RI "\fIThis method adds data to the buffer of the user. \fP" @@ -81,6 +85,10 @@ Inherits \fBconnection\fP. .RI "\fBInvitedList\fP * \fBGetInviteList\fP ()" .br .RI "\fIReturns the list of channels this user has been invited to but has not yet joined. \fP" +.ti -1c +.RI "void \fBCloseSocket\fP ()" +.br +.RI "\fIShuts down and closes the user's socket. \fP" .in -1c .SS "Public Attributes" @@ -193,40 +201,40 @@ Definition at line 108 of file users.h. .PP .SS "userrec::userrec ()" .PP -Definition at line 29 of file users.cpp. +Definition at line 31 of file users.cpp. .PP References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. .PP .nf -30 { -31 // the PROPER way to do it, AVOID bzero at *ALL* costs -32 strcpy(nick,''); -33 strcpy(ip,'127.0.0.1'); -34 timeout = 0; -35 strcpy(ident,''); -36 strcpy(host,''); -37 strcpy(dhost,''); -38 strcpy(fullname,''); -39 strcpy(modes,''); -40 strcpy(server,''); -41 strcpy(awaymsg,''); -42 strcpy(oper,''); -43 reset_due = TIME; -44 lines_in = 0; -45 fd = lastping = signon = idle_lastmsg = nping = registered = 0; -46 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; -47 haspassed = false; -48 dns_done = false; -49 recvq = ''; -50 sendq = ''; -51 strcpy(result,''); -52 for (int i = 0; i < MAXCHANS; i++) -53 { -54 this->chans[i].channel = NULL; -55 this->chans[i].uc_modes = 0; -56 } -57 invites.clear(); -58 } +32 { +33 // the PROPER way to do it, AVOID bzero at *ALL* costs +34 strcpy(nick,''); +35 strcpy(ip,'127.0.0.1'); +36 timeout = 0; +37 strcpy(ident,''); +38 strcpy(host,''); +39 strcpy(dhost,''); +40 strcpy(fullname,''); +41 strcpy(modes,''); +42 strcpy(server,''); +43 strcpy(awaymsg,''); +44 strcpy(oper,''); +45 reset_due = TIME; +46 lines_in = 0; +47 fd = lastping = signon = idle_lastmsg = nping = registered = 0; +48 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; +49 haspassed = false; +50 dns_done = false; +51 recvq = ''; +52 sendq = ''; +53 strcpy(result,''); +54 for (int i = 0; i < MAXCHANS; i++) +55 { +56 this->chans[i].channel = NULL; +57 this->chans[i].uc_modes = 0; +58 } +59 invites.clear(); +60 } .fi .SS "virtual userrec::~\fBuserrec\fP ()\fC [inline, virtual]\fP" .PP @@ -239,316 +247,341 @@ Definition at line 222 of file users.h. .PP .SS "bool userrec::AddBuffer (std::string a)" .PP -This method adds data to the buffer of the user. The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.Definition at line 175 of file users.cpp. +This method adds data to the buffer of the user. The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.Definition at line 190 of file users.cpp. .PP References recvq, recvqmax, and SetWriteError(). .PP .nf -176 { -177 std::string b = ''; -178 for (int i = 0; i < a.length(); i++) -179 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) -180 b = b + a[i]; -181 std::stringstream stream(recvq); -182 stream << b; -183 recvq = stream.str(); -184 int i = 0; -185 // count the size of the first line in the buffer. -186 while (i < recvq.length()) -187 { -188 if (recvq[i++] == '\n') -189 break; -190 } -191 if (recvq.length() > this->recvqmax) -192 { -193 this->SetWriteError('RecvQ exceeded'); -194 WriteOpers('*** User %s RecvQ of %d exceeds connect class maximum of %d',this->nick,recvq.length(),this->recvqmax); -195 } -196 // return false if we've had more than 600 characters WITHOUT -197 // a carriage return (this is BAD, drop the socket) -198 return (i < 600); -199 } +191 { +192 std::string b = ''; +193 for (int i = 0; i < a.length(); i++) +194 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) +195 b = b + a[i]; +196 std::stringstream stream(recvq); +197 stream << b; +198 recvq = stream.str(); +199 int i = 0; +200 // count the size of the first line in the buffer. +201 while (i < recvq.length()) +202 { +203 if (recvq[i++] == '\n') +204 break; +205 } +206 if (recvq.length() > this->recvqmax) +207 { +208 this->SetWriteError('RecvQ exceeded'); +209 WriteOpers('*** User %s RecvQ of %d exceeds connect class maximum of %d',this->nick,recvq.length(),this->recvqmax); +210 } +211 // return false if we've had more than 600 characters WITHOUT +212 // a carriage return (this is BAD, drop the socket) +213 return (i < 600); +214 } .fi .SS "void userrec::AddWriteBuf (std::string data)" .PP -Adds to the user's write buffer. You may add any amount of text up to this users sendq value, if you exceed the sendq value, \fBSetWriteError()\fP will be called to set the users error string to 'SendQ exceeded', and further buffer adds will be dropped.Definition at line 231 of file users.cpp. +Adds to the user's write buffer. You may add any amount of text up to this users sendq value, if you exceed the sendq value, \fBSetWriteError()\fP will be called to set the users error string to 'SendQ exceeded', and further buffer adds will be dropped.Definition at line 246 of file users.cpp. .PP References GetWriteError(), sendq, sendqmax, and SetWriteError(). .PP .nf -232 { -233 if (this->GetWriteError() != '') -234 return; -235 if (sendq.length() + data.length() > this->sendqmax) -236 { -237 WriteOpers('*** User %s SendQ of %d exceeds connect class maximum of %d',this->nick,sendq.length() + data.length(),this->sendqmax); -238 this->SetWriteError('SendQ exceeded'); -239 return; -240 } -241 std::stringstream stream; -242 stream << sendq << data; -243 sendq = stream.str(); -244 } +247 { +248 if (this->GetWriteError() != '') +249 return; +250 if (sendq.length() + data.length() > this->sendqmax) +251 { +252 WriteOpers('*** User %s SendQ of %d exceeds connect class maximum of %d',this->nick,sendq.length() + data.length(),this->sendqmax); +253 this->SetWriteError('SendQ exceeded'); +254 return; +255 } +256 std::stringstream stream; +257 stream << sendq << data; +258 sendq = stream.str(); +259 } .fi .SS "bool userrec::BufferIsReady ()" .PP -This method returns true if the buffer contains at least one carriage return character (e.g. one complete line may be read)Definition at line 201 of file users.cpp. +This method returns true if the buffer contains at least one carriage return character (e.g. one complete line may be read)Definition at line 216 of file users.cpp. .PP References recvq. .PP .nf -202 { -203 for (int i = 0; i < recvq.length(); i++) -204 if (recvq[i] == '\n') -205 return true; -206 return false; -207 } +217 { +218 for (int i = 0; i < recvq.length(); i++) +219 if (recvq[i] == '\n') +220 return true; +221 return false; +222 } .fi .SS "void userrec::ClearBuffer ()" .PP -This function clears the entire buffer by setting it to an empty string. Definition at line 209 of file users.cpp. +This function clears the entire buffer by setting it to an empty string. Definition at line 224 of file users.cpp. .PP References recvq. .PP Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). .PP .nf -210 { -211 recvq = ''; -212 } +225 { +226 recvq = ''; +227 } +.fi +.SS "void userrec::CloseSocket ()" +.PP +Shuts down and closes the user's socket. Definition at line 62 of file users.cpp. +.PP +.nf +63 { +64 shutdown(this->fd,2); +65 close(this->fd); +66 } .fi .SS "void userrec::FlushWriteBuf ()" .PP -Flushes as much of the user's buffer to the file descriptor as possible. This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.Definition at line 247 of file users.cpp. +Flushes as much of the user's buffer to the file descriptor as possible. This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.Definition at line 262 of file users.cpp. .PP References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). .PP .nf -248 { -249 if (sendq.length()) -250 { -251 char* tb = (char*)this->sendq.c_str(); -252 int n_sent = write(this->fd,tb,this->sendq.length()); -253 if (n_sent == -1) -254 { -255 this->SetWriteError(strerror(errno)); -256 } -257 else -258 { -259 // advance the queue -260 tb += n_sent; -261 this->sendq = tb; -262 // update the user's stats counters -263 this->bytes_out += n_sent; -264 this->cmds_out++; -265 } -266 } -267 } +263 { +264 if (sendq.length()) +265 { +266 char* tb = (char*)this->sendq.c_str(); +267 int n_sent = write(this->fd,tb,this->sendq.length()); +268 if (n_sent == -1) +269 { +270 this->SetWriteError(strerror(errno)); +271 } +272 else +273 { +274 // advance the queue +275 tb += n_sent; +276 this->sendq = tb; +277 // update the user's stats counters +278 this->bytes_out += n_sent; +279 this->cmds_out++; +280 } +281 } +282 } .fi .SS "std::string userrec::GetBuffer ()" .PP -This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string. This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use \fBBufferIsReady()\fP to check if it is ok to read the buffer before calling \fBGetBuffer()\fP.Definition at line 214 of file users.cpp. +This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string. This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use \fBBufferIsReady()\fP to check if it is ok to read the buffer before calling \fBGetBuffer()\fP.Definition at line 229 of file users.cpp. .PP References recvq. .PP .nf -215 { -216 if (recvq == '') -217 return ''; -218 char* line = (char*)recvq.c_str(); -219 std::string ret = ''; -220 while ((*line != '\n') && (strlen(line))) -221 { -222 ret = ret + *line; -223 line++; -224 } -225 if ((*line == '\n') || (*line == '\r')) -226 line++; -227 recvq = line; -228 return ret; -229 } +230 { +231 if (recvq == '') +232 return ''; +233 char* line = (char*)recvq.c_str(); +234 std::string ret = ''; +235 while ((*line != '\n') && (strlen(line))) +236 { +237 ret = ret + *line; +238 line++; +239 } +240 if ((*line == '\n') || (*line == '\r')) +241 line++; +242 recvq = line; +243 return ret; +244 } .fi .SS "char * userrec::GetFullHost ()\fC [virtual]\fP" .PP -Returns the full displayed host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. Definition at line 62 of file users.cpp. +Returns the full displayed host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. Definition at line 68 of file users.cpp. .PP References dhost, ident, nick, and result. .PP .nf -63 { -64 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,dhost); -65 return result; -66 } +69 { +70 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,dhost); +71 return result; +72 } .fi .SS "char * userrec::GetFullRealHost ()\fC [virtual]\fP" .PP -Returns the full real host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.Definition at line 69 of file users.cpp. +Returns the full real host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.Definition at line 84 of file users.cpp. .PP References connection::host, ident, nick, and result. .PP .nf -70 { -71 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,host); -72 return result; -73 } +85 { +86 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,host); +87 return result; +88 } .fi .SS "\fBInvitedList\fP * userrec::GetInviteList ()" .PP -Returns the list of channels this user has been invited to but has not yet joined. Definition at line 89 of file users.cpp. +Returns the list of channels this user has been invited to but has not yet joined. Definition at line 104 of file users.cpp. .PP References InvitedList, and invites. .PP .nf -90 { -91 return &invites; -92 } +105 { +106 return &invites; +107 } .fi .SS "std::string userrec::GetWriteError ()" .PP -Returns the write error which last occured on this connection or an empty string if none occured. Definition at line 277 of file users.cpp. +Returns the write error which last occured on this connection or an empty string if none occured. Definition at line 292 of file users.cpp. .PP References WriteError. .PP Referenced by AddWriteBuf(). .PP .nf -278 { -279 return this->WriteError; -280 } +293 { +294 return this->WriteError; +295 } .fi .SS "bool userrec::HasPermission (char * command)" .PP -Returns true or false for if a user can execute a privilaged oper command. This is done by looking up their oper type from \fBuserrec::oper\fP, then referencing this to their oper classes and checking the commands they can execute.Definition at line 123 of file users.cpp. +Returns true or false for if a user can execute a privilaged oper command. This is done by looking up their oper type from \fBuserrec::oper\fP, then referencing this to their oper classes and checking the commands they can execute.Definition at line 138 of file users.cpp. .PP References config_f, and DEBUG. .PP .nf -124 { -125 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; -126 char* mycmd; -127 char* savept; -128 char* savept2; -129 -130 // are they even an oper at all? -131 if (strchr(this->modes,'o')) -132 { -133 log(DEBUG,'*** HasPermission: %s is an oper',this->nick); -134 for (int j =0; j < ConfValueEnum('type',&config_f); j++) -135 { -136 ConfValue('type','name',j,TypeName,&config_f); -137 if (!strcmp(TypeName,this->oper)) -138 { -139 log(DEBUG,'*** HasPermission: %s is an oper of type '%s'',this->nick,this->oper); -140 ConfValue('type','classes',j,Classes,&config_f); -141 char* myclass = strtok_r(Classes,' ',&savept); -142 while (myclass) -143 { -144 log(DEBUG,'*** HasPermission: checking classtype '%s'',myclass); -145 for (int k =0; k < ConfValueEnum('class',&config_f); k++) -146 { -147 ConfValue('class','name',k,ClassName,&config_f); -148 if (!strcmp(ClassName,myclass)) -149 { -150 ConfValue('class','commands',k,CommandList,&config_f); -151 log(DEBUG,'*** HasPermission: found class named %s with commands: '%s'',ClassName,CommandList); -152 -153 -154 mycmd = strtok_r(CommandList,' ',&savept2); -155 while (mycmd) -156 { -157 if (!strcasecmp(mycmd,command)) -158 { -159 log(DEBUG,'*** Command %s found, returning true',command); -160 return true; -161 } -162 mycmd = strtok_r(NULL,' ',&savept2); -163 } -164 } -165 } -166 myclass = strtok_r(NULL,' ',&savept); -167 } -168 } -169 } -170 } -171 return false; -172 } +139 { +140 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; +141 char* mycmd; +142 char* savept; +143 char* savept2; +144 +145 // are they even an oper at all? +146 if (strchr(this->modes,'o')) +147 { +148 log(DEBUG,'*** HasPermission: %s is an oper',this->nick); +149 for (int j =0; j < ConfValueEnum('type',&config_f); j++) +150 { +151 ConfValue('type','name',j,TypeName,&config_f); +152 if (!strcmp(TypeName,this->oper)) +153 { +154 log(DEBUG,'*** HasPermission: %s is an oper of type '%s'',this->nick,this->oper); +155 ConfValue('type','classes',j,Classes,&config_f); +156 char* myclass = strtok_r(Classes,' ',&savept); +157 while (myclass) +158 { +159 log(DEBUG,'*** HasPermission: checking classtype '%s'',myclass); +160 for (int k =0; k < ConfValueEnum('class',&config_f); k++) +161 { +162 ConfValue('class','name',k,ClassName,&config_f); +163 if (!strcmp(ClassName,myclass)) +164 { +165 ConfValue('class','commands',k,CommandList,&config_f); +166 log(DEBUG,'*** HasPermission: found class named %s with commands: '%s'',ClassName,CommandList); +167 +168 +169 mycmd = strtok_r(CommandList,' ',&savept2); +170 while (mycmd) +171 { +172 if (!strcasecmp(mycmd,command)) +173 { +174 log(DEBUG,'*** Command %s found, returning true',command); +175 return true; +176 } +177 mycmd = strtok_r(NULL,' ',&savept2); +178 } +179 } +180 } +181 myclass = strtok_r(NULL,' ',&savept); +182 } +183 } +184 } +185 } +186 return false; +187 } .fi .SS "void userrec::InviteTo (char * channel)\fC [virtual]\fP" .PP -Adds a channel to a users invite list (invites them to a channel). Definition at line 94 of file users.cpp. +Adds a channel to a users invite list (invites them to a channel). Definition at line 109 of file users.cpp. .PP References Invited::channel, and invites. .PP .nf -95 { -96 Invited i; -97 strlcpy(i.channel,channel,CHANMAX); -98 invites.push_back(i); -99 } +110 { +111 Invited i; +112 strlcpy(i.channel,channel,CHANMAX); +113 invites.push_back(i); +114 } .fi .SS "bool userrec::IsInvited (char * channel)\fC [virtual]\fP" .PP -Returns true if a user is invited to a channel. Definition at line 75 of file users.cpp. +Returns true if a user is invited to a channel. Definition at line 90 of file users.cpp. .PP References invites. .PP .nf -76 { -77 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -78 { -79 if (i->channel) { -80 if (!strcasecmp(i->channel,channel)) -81 { -82 return true; -83 } -84 } -85 } -86 return false; -87 } +91 { +92 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +93 { +94 if (i->channel) { +95 if (!strcasecmp(i->channel,channel)) +96 { +97 return true; +98 } +99 } +100 } +101 return false; +102 } +.fi +.SS "int userrec::ReadData (void * buffer, size_t size)" +.PP +Calls read() to read some data for this user using their fd. Definition at line 74 of file users.cpp. +.PP +References connection::fd. +.PP +.nf +75 { +76 if (this->fd > -1) +77 { +78 return read(this->fd, buffer, size); +79 } +80 else return 0; +81 } .fi .SS "void userrec::RemoveInvite (char * channel)\fC [virtual]\fP" .PP -Removes a channel from a users invite list. This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.Definition at line 101 of file users.cpp. +Removes a channel from a users invite list. This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.Definition at line 116 of file users.cpp. .PP References DEBUG, and invites. .PP .nf -102 { -103 log(DEBUG,'Removing invites'); -104 if (channel) -105 { -106 if (invites.size()) -107 { -108 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -109 { -110 if (i->channel) -111 { -112 if (!strcasecmp(i->channel,channel)) -113 { -114 invites.erase(i); -115 return; -116 } -117 } -118 } -119 } -120 } -121 } +117 { +118 log(DEBUG,'Removing invites'); +119 if (channel) +120 { +121 if (invites.size()) +122 { +123 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +124 { +125 if (i->channel) +126 { +127 if (!strcasecmp(i->channel,channel)) +128 { +129 invites.erase(i); +130 return; +131 } +132 } +133 } +134 } +135 } +136 } .fi .SS "void userrec::SetWriteError (std::string error)" .PP -Sets the write error for a connection. This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.Definition at line 269 of file users.cpp. +Sets the write error for a connection. This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.Definition at line 284 of file users.cpp. .PP References DEBUG, and WriteError. .PP Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf(). .PP .nf -270 { -271 log(DEBUG,'Setting error string for %s to '%s'',this->nick,error.c_str()); -272 // don't try to set the error twice, its already set take the first string. -273 if (this->WriteError == '') -274 this->WriteError = error; -275 } +285 { +286 log(DEBUG,'Setting error string for %s to '%s'',this->nick,error.c_str()); +287 // don't try to set the error twice, its already set take the first string. +288 if (this->WriteError == '') +289 this->WriteError = error; +290 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/users.cpp.3 b/docs/man/man3/users.cpp.3 index e8d74655d..e8d42c52b 100644 --- a/docs/man/man3/users.cpp.3 +++ b/docs/man/man3/users.cpp.3 @@ -1,4 +1,4 @@ -.TH "users.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "users.cpp" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -35,10 +35,10 @@ users.cpp \- .PP .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 25 of file users.cpp. +Definition at line 27 of file users.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 27 of file users.cpp. +Definition at line 29 of file users.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/users.h.3 b/docs/man/man3/users.h.3 index 234320343..99912b9fe 100644 --- a/docs/man/man3/users.h.3 +++ b/docs/man/man3/users.h.3 @@ -1,4 +1,4 @@ -.TH "users.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "users.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/xline.h.3 b/docs/man/man3/xline.h.3 index 65e55d871..3320bdcb6 100644 --- a/docs/man/man3/xline.h.3 +++ b/docs/man/man3/xline.h.3 @@ -1,4 +1,4 @@ -.TH "xline.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "xline.h" 3 "24 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/module-doc/annotated.html b/docs/module-doc/annotated.html index b5e35d1d8..0a0622e75 100644 --- a/docs/module-doc/annotated.html +++ b/docs/module-doc/annotated.html @@ -49,7 +49,7 @@ XLineXLine is the base class for ban lines such as G lines and K lines ZLineZLine class -
Generated on Sun May 15 18:37:36 2005 for InspIRCd by +
Generated on Tue May 24 02:31:27 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/base_8h-source.html b/docs/module-doc/base_8h-source.html index bbd044b1e..c9c396f9d 100644 --- a/docs/module-doc/base_8h-source.html +++ b/docs/module-doc/base_8h-source.html @@ -55,7 +55,7 @@ 00079 00080 #endif 00081 -
Generated on Sun May 15 18:36:01 2005 for InspIRCd by +
Generated on Tue May 24 02:30:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/base_8h.html b/docs/module-doc/base_8h.html index 351e487c5..0e7108ff0 100644 --- a/docs/module-doc/base_8h.html +++ b/docs/module-doc/base_8h.html @@ -61,7 +61,7 @@ This graph shows which files directly or indirectly include this file:

25 of file base.h. -
Generated on Sun May 15 18:36:08 2005 for InspIRCd by +
Generated on Tue May 24 02:30:12 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8cpp-source.html b/docs/module-doc/channels_8cpp-source.html index 24bbd5415..0d5733feb 100644 --- a/docs/module-doc/channels_8cpp-source.html +++ b/docs/module-doc/channels_8cpp-source.html @@ -21,47 +21,47 @@ 00014 * --------------------------------------------------- 00015 */ 00016 -00017 #include "inspircd.h" -00018 #include "inspircd_io.h" -00019 #include "inspircd_util.h" -00020 #include "inspircd_config.h" -00021 #include <unistd.h> -00022 #include <sys/errno.h> -00023 #include <sys/ioctl.h> -00024 #include <sys/utsname.h> -00025 #include <time.h> -00026 #include <string> -00027 #ifdef GCC3 -00028 #include <ext/hash_map> -00029 #else -00030 #include <hash_map> -00031 #endif -00032 #include <map> -00033 #include <sstream> -00034 #include <vector> -00035 #include <deque> -00036 #include "connection.h" -00037 #include "users.h" -00038 #include "servers.h" -00039 #include "ctables.h" -00040 #include "globals.h" -00041 #include "modules.h" -00042 #include "dynamic.h" -00043 #include "wildcard.h" -00044 #include "message.h" -00045 #include "mode.h" -00046 #include "xline.h" -00047 #include "inspstring.h" -00048 #include "helperfuncs.h" -00049 -00050 #ifdef GCC3 -00051 #define nspace __gnu_cxx -00052 #else -00053 #define nspace std -00054 #endif -00055 -00056 using namespace std; -00057 +00017 using namespace std; +00018 +00019 #include "inspircd.h" +00020 #include "inspircd_io.h" +00021 #include "inspircd_util.h" +00022 #include "inspircd_config.h" +00023 #include <unistd.h> +00024 #include <sys/errno.h> +00025 #include <sys/ioctl.h> +00026 #include <sys/utsname.h> +00027 #include <time.h> +00028 #include <string> +00029 #ifdef GCC3 +00030 #include <ext/hash_map> +00031 #else +00032 #include <hash_map> +00033 #endif +00034 #include <map> +00035 #include <sstream> +00036 #include <vector> +00037 #include <deque> +00038 #include "connection.h" +00039 #include "users.h" +00040 #include "servers.h" +00041 #include "ctables.h" +00042 #include "globals.h" +00043 #include "modules.h" +00044 #include "dynamic.h" +00045 #include "wildcard.h" +00046 #include "message.h" +00047 #include "mode.h" +00048 #include "xline.h" +00049 #include "inspstring.h" +00050 #include "helperfuncs.h" +00051 +00052 #ifdef GCC3 +00053 #define nspace __gnu_cxx +00054 #else +00055 #define nspace std +00056 #endif +00057 00058 extern int MODCOUNT; 00059 extern std::vector<Module*> modules; 00060 extern std::vector<ircd_module*> factory; @@ -90,147 +90,146 @@ 00083 int MaxWhoResults; 00084 extern time_t nb_start; 00085 -00086 extern std::vector<int> fd_reap; -00087 extern std::vector<std::string> module_names; -00088 -00089 extern int boundPortCount; -00090 extern int portCount; -00091 extern int SERVERportCount; -00092 extern int ports[MAXSOCKS]; -00093 extern int defaultRoute; -00094 -00095 extern std::vector<long> auth_cookies; -00096 extern std::stringstream config_f; -00097 -00098 extern serverrec* me[32]; -00099 -00100 extern FILE *log_file; -00101 -00102 extern time_t TIME; -00103 -00104 using namespace std; -00105 -00106 std::vector<ModeParameter> custom_mode_params; -00107 -00108 chanrec::chanrec() -00109 { -00110 strcpy(name,""); -00111 strcpy(custom_modes,""); -00112 strcpy(topic,""); -00113 strcpy(setby,""); -00114 strcpy(key,""); -00115 created = topicset = limit = 0; -00116 binarymodes = 0; -00117 internal_userlist.clear(); -00118 } -00119 -00120 void chanrec::SetCustomMode(char mode,bool mode_on) -00121 { -00122 if (mode_on) { -00123 static char m[3]; -00124 m[0] = mode; -00125 m[1] = '\0'; -00126 if (!strchr(this->custom_modes,mode)) -00127 { -00128 strlcat(custom_modes,m,MAXMODES); -00129 } -00130 log(DEBUG,"Custom mode %c set",mode); -00131 } -00132 else { -00133 -00134 std::string a = this->custom_modes; -00135 int pos = a.find(mode); -00136 a.erase(pos,1); -00137 strncpy(this->custom_modes,a.c_str(),MAXMODES); -00138 -00139 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes); -00140 this->SetCustomModeParam(mode,"",false); -00141 } -00142 } +00086 extern std::vector<std::string> module_names; +00087 +00088 extern int boundPortCount; +00089 extern int portCount; +00090 extern int SERVERportCount; +00091 extern int ports[MAXSOCKS]; +00092 extern int defaultRoute; +00093 +00094 extern std::vector<long> auth_cookies; +00095 extern std::stringstream config_f; +00096 +00097 extern serverrec* me[32]; +00098 +00099 extern FILE *log_file; +00100 +00101 extern time_t TIME; +00102 +00103 using namespace std; +00104 +00105 std::vector<ModeParameter> custom_mode_params; +00106 +00107 chanrec::chanrec() +00108 { +00109 strcpy(name,""); +00110 strcpy(custom_modes,""); +00111 strcpy(topic,""); +00112 strcpy(setby,""); +00113 strcpy(key,""); +00114 created = topicset = limit = 0; +00115 binarymodes = 0; +00116 internal_userlist.clear(); +00117 } +00118 +00119 void chanrec::SetCustomMode(char mode,bool mode_on) +00120 { +00121 if (mode_on) { +00122 static char m[3]; +00123 m[0] = mode; +00124 m[1] = '\0'; +00125 if (!strchr(this->custom_modes,mode)) +00126 { +00127 strlcat(custom_modes,m,MAXMODES); +00128 } +00129 log(DEBUG,"Custom mode %c set",mode); +00130 } +00131 else { +00132 +00133 std::string a = this->custom_modes; +00134 int pos = a.find(mode); +00135 a.erase(pos,1); +00136 strncpy(this->custom_modes,a.c_str(),MAXMODES); +00137 +00138 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes); +00139 this->SetCustomModeParam(mode,"",false); +00140 } +00141 } +00142 00143 -00144 -00145 void chanrec::SetCustomModeParam(char mode,char* parameter,bool mode_on) -00146 { -00147 -00148 log(DEBUG,"SetCustomModeParam called"); -00149 ModeParameter M; -00150 M.mode = mode; -00151 strlcpy(M.channel,this->name,CHANMAX); -00152 strlcpy(M.parameter,parameter,MAXBUF); -00153 if (mode_on) -00154 { -00155 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter); -00156 custom_mode_params.push_back(M); -00157 } -00158 else -00159 { -00160 if (custom_mode_params.size()) -00161 { -00162 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -00163 { -00164 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -00165 { -00166 log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter); -00167 custom_mode_params.erase(i); -00168 return; -00169 } -00170 } -00171 } -00172 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!"); -00173 } -00174 } -00175 -00176 bool chanrec::IsCustomModeSet(char mode) -00177 { -00178 log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes); -00179 return (strchr(this->custom_modes,mode) != 0); -00180 } -00181 -00182 std::string chanrec::GetModeParameter(char mode) -00183 { -00184 if (custom_mode_params.size()) -00185 { -00186 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -00187 { -00188 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -00189 { -00190 return i->parameter; -00191 } -00192 } -00193 } -00194 return ""; -00195 } -00196 -00197 long chanrec::GetUserCounter() -00198 { -00199 return (this->internal_userlist.size()); -00200 } -00201 -00202 void chanrec::AddUser(char* castuser) -00203 { -00204 internal_userlist.push_back(castuser); -00205 log(DEBUG,"Added casted user to channel's internal list"); -00206 } -00207 -00208 void chanrec::DelUser(char* castuser) -00209 { -00210 for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) -00211 { -00212 if (*a == castuser) -00213 { -00214 log(DEBUG,"Removed casted user from channel's internal list"); -00215 internal_userlist.erase(a); -00216 return; -00217 } -00218 } -00219 log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name); -00220 } -00221 -00222 std::vector<char*> *chanrec::GetUsers() -00223 { -00224 return &internal_userlist; -00225 } -
Generated on Sun May 15 18:36:01 2005 for InspIRCd by +00144 void chanrec::SetCustomModeParam(char mode,char* parameter,bool mode_on) +00145 { +00146 +00147 log(DEBUG,"SetCustomModeParam called"); +00148 ModeParameter M; +00149 M.mode = mode; +00150 strlcpy(M.channel,this->name,CHANMAX); +00151 strlcpy(M.parameter,parameter,MAXBUF); +00152 if (mode_on) +00153 { +00154 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter); +00155 custom_mode_params.push_back(M); +00156 } +00157 else +00158 { +00159 if (custom_mode_params.size()) +00160 { +00161 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +00162 { +00163 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +00164 { +00165 log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter); +00166 custom_mode_params.erase(i); +00167 return; +00168 } +00169 } +00170 } +00171 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!"); +00172 } +00173 } +00174 +00175 bool chanrec::IsCustomModeSet(char mode) +00176 { +00177 log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes); +00178 return (strchr(this->custom_modes,mode) != 0); +00179 } +00180 +00181 std::string chanrec::GetModeParameter(char mode) +00182 { +00183 if (custom_mode_params.size()) +00184 { +00185 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +00186 { +00187 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +00188 { +00189 return i->parameter; +00190 } +00191 } +00192 } +00193 return ""; +00194 } +00195 +00196 long chanrec::GetUserCounter() +00197 { +00198 return (this->internal_userlist.size()); +00199 } +00200 +00201 void chanrec::AddUser(char* castuser) +00202 { +00203 internal_userlist.push_back(castuser); +00204 log(DEBUG,"Added casted user to channel's internal list"); +00205 } +00206 +00207 void chanrec::DelUser(char* castuser) +00208 { +00209 for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) +00210 { +00211 if (*a == castuser) +00212 { +00213 log(DEBUG,"Removed casted user from channel's internal list"); +00214 internal_userlist.erase(a); +00215 return; +00216 } +00217 } +00218 log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name); +00219 } +00220 +00221 std::vector<char*> *chanrec::GetUsers() +00222 { +00223 return &internal_userlist; +00224 } +
Generated on Tue May 24 02:30:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8cpp.html b/docs/module-doc/channels_8cpp.html index faf42d329..aefb0e58e 100644 --- a/docs/module-doc/channels_8cpp.html +++ b/docs/module-doc/channels_8cpp.html @@ -107,31 +107,29 @@ Include dependency graph for channels.cpp:

time_t nb_start -std::vector< int > fd_reap +std::vector< std::string > module_names -std::vector< std::string > module_names +int boundPortCount -int boundPortCount +int portCount -int portCount +int SERVERportCount -int SERVERportCount +int ports [MAXSOCKS] -int ports [MAXSOCKS] +int defaultRoute -int defaultRoute +std::vector< long > auth_cookies -std::vector< long > auth_cookies +std::stringstream config_f -std::stringstream config_f +serverrecme [32] -serverrecme [32] +FILE * log_file -FILE * log_file +time_t TIME -time_t TIME - -std::vector< ModeParametercustom_mode_params +std::vector< ModeParametercustom_mode_params

Define Documentation

@@ -156,7 +154,7 @@ Include dependency graph for channels.cpp:

53 of file channels.cpp. +Definition at line 55 of file channels.cpp.

Variable Documentation

@@ -232,13 +230,13 @@ Definition at line 66 Definition at line 68 of file channels.cpp. -

+

@@ -253,16 +251,16 @@ Definition at line 68

-Definition at line 95 of file channels.cpp. +Definition at line 94 of file channels.cpp.

-
std::vector<long> auth_cookies + std::vector<long> auth_cookies
-

+

@@ -277,10 +275,10 @@ Definition at line 95

-Definition at line 89 of file channels.cpp. +Definition at line 88 of file channels.cpp.

-
int boundPortCount + int boundPortCount
-

+

+Referenced by userrec::HasPermission().
@@ -301,18 +299,18 @@ Definition at line 89

-Definition at line 96 of file channels.cpp. +Definition at line 95 of file channels.cpp.

-Referenced by userrec::HasPermission().

-

+

@@ -327,9 +325,9 @@ Referenced by userrec::HasPer

-Definition at line 106 of file channels.cpp. +Definition at line 105 of file channels.cpp.

-Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam(). +Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam().

-
std::vector<ModeParameter> custom_mode_params + std::vector<ModeParameter> custom_mode_params

@@ -356,13 +354,13 @@ Referenced by chanrec::Get Definition at line 77 of file channels.cpp. -

+

@@ -377,7 +375,7 @@ Definition at line 77

-Definition at line 93 of file channels.cpp. +Definition at line 92 of file channels.cpp.

-
int defaultRoute + int defaultRoute

@@ -476,30 +474,6 @@ Definition at line 75 Definition at line 60 of file channels.cpp. -

- - - - -
- - -
std::vector<int> fd_reap -
-
- - - - - -
-   - - -

- -

-Definition at line 86 of file channels.cpp.

@@ -523,16 +497,16 @@ Definition at line 86

Definition at line 73 of file channels.cpp.

-Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

-

+

@@ -547,7 +521,7 @@ Referenced by Server::GetUs

-Definition at line 100 of file channels.cpp. +Definition at line 99 of file channels.cpp.

-
FILE* log_file + FILE* log_file

@@ -598,13 +572,13 @@ Definition at line 62 Definition at line 83 of file channels.cpp. -

+

@@ -619,7 +593,7 @@ Definition at line 83

-Definition at line 98 of file channels.cpp. +Definition at line 97 of file channels.cpp.

-
serverrec* me[32] + serverrec* me[32]

@@ -643,18 +617,18 @@ Definition at line 98

-Definition at line 996 of file modules.cpp. +Definition at line 1016 of file modules.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule(). -

+

@@ -669,9 +643,9 @@ Referenced by Server::FindM

-Definition at line 87 of file channels.cpp. +Definition at line 86 of file channels.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule().

-
std::vector<std::string> module_names + std::vector<std::string> module_names

@@ -697,7 +671,7 @@ Referenced by Server::FindM

Definition at line 59 of file channels.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule().

@@ -796,13 +770,13 @@ Definition at line 82 Definition at line 64 of file channels.cpp. -

+

@@ -817,16 +791,16 @@ Definition at line 64

-Definition at line 90 of file channels.cpp. +Definition at line 89 of file channels.cpp.

-
int portCount + int portCount
-

+

@@ -841,7 +815,7 @@ Definition at line 90

-Definition at line 92 of file channels.cpp. +Definition at line 91 of file channels.cpp.

-
int ports[MAXSOCKS] + int ports[MAXSOCKS]

@@ -964,13 +938,13 @@ Definition at line 65 Definition at line 63 of file channels.cpp. -

+

@@ -985,7 +959,7 @@ Definition at line 63

-Definition at line 91 of file channels.cpp. +Definition at line 90 of file channels.cpp.

-
int SERVERportCount + int SERVERportCount

@@ -1012,7 +986,7 @@ Definition at line 91 Definition at line 81 of file channels.cpp. -

+

+Referenced by serverrec::serverrec(), and userrec::userrec().
@@ -1033,9 +1007,9 @@ Definition at line 81

-Definition at line 102 of file channels.cpp. +Definition at line 101 of file channels.cpp.

-Referenced by serverrec::serverrec(), and userrec::userrec().

@@ -1086,7 +1060,7 @@ Definition at line 79 Definition at line 78 of file channels.cpp. -


Generated on Sun May 15 18:36:30 2005 for InspIRCd by +
Generated on Tue May 24 02:30:29 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8h-source.html b/docs/module-doc/channels_8h-source.html index 8a0f88319..d705ff120 100644 --- a/docs/module-doc/channels_8h-source.html +++ b/docs/module-doc/channels_8h-source.html @@ -146,7 +146,7 @@ 00238 00239 #endif 00240 -
Generated on Sun May 15 18:36:01 2005 for InspIRCd by +
Generated on Tue May 24 02:30:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8h.html b/docs/module-doc/channels_8h.html index cbf82ab42..a9e550bcc 100644 --- a/docs/module-doc/channels_8h.html +++ b/docs/module-doc/channels_8h.html @@ -433,7 +433,7 @@ Holds a complete invite list. Definition at line 95 of file channels.h. -
Generated on Sun May 15 18:36:36 2005 for InspIRCd by +
Generated on Tue May 24 02:30:33 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classAdmin-members.html b/docs/module-doc/classAdmin-members.html index d2e27712e..13330b1fb 100644 --- a/docs/module-doc/classAdmin-members.html +++ b/docs/module-doc/classAdmin-members.html @@ -13,7 +13,7 @@ NameAdmin NickAdmin ~classbase()classbase [inline] -
Generated on Sun May 15 18:37:39 2005 for InspIRCd by +
Generated on Tue May 24 02:31:29 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classAdmin.html b/docs/module-doc/classAdmin.html index 734b7d8c6..3f2929f5f 100644 --- a/docs/module-doc/classAdmin.html +++ b/docs/module-doc/classAdmin.html @@ -82,9 +82,9 @@ Definition at line 123 of

-Definition at line 238 of file modules.cpp. +Definition at line 247 of file modules.cpp.

-

00238 : Name(name), Email(email), Nick(nick) { };
+
00247 : Name(name), Email(email), Nick(nick) { };
 
@@ -163,7 +163,7 @@ Definition at line 126 of
The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:37:39 2005 for InspIRCd by +
Generated on Tue May 24 02:31:29 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classBanItem-members.html b/docs/module-doc/classBanItem-members.html index 852dfb761..7fa50962d 100644 --- a/docs/module-doc/classBanItem-members.html +++ b/docs/module-doc/classBanItem-members.html @@ -14,7 +14,7 @@ set_timeHostItem ~classbase()classbase [inline] ~HostItem()HostItem [inline, virtual] -
Generated on Sun May 15 18:37:42 2005 for InspIRCd by +
Generated on Tue May 24 02:31:31 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classBanItem.html b/docs/module-doc/classBanItem.html index d6d634337..ce1134122 100644 --- a/docs/module-doc/classBanItem.html +++ b/docs/module-doc/classBanItem.html @@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 52 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:37:42 2005 for InspIRCd by +
Generated on Tue May 24 02:31:31 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConfigReader-members.html b/docs/module-doc/classConfigReader-members.html index 2c218e8f9..50dfb9871 100644 --- a/docs/module-doc/classConfigReader-members.html +++ b/docs/module-doc/classConfigReader-members.html @@ -24,7 +24,7 @@ Verify()ConfigReader ~classbase()classbase [inline] ~ConfigReader()ConfigReader -
Generated on Sun May 15 18:37:55 2005 for InspIRCd by +
Generated on Tue May 24 02:31:43 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConfigReader.html b/docs/module-doc/classConfigReader.html index be9363d30..12a432ec7 100644 --- a/docs/module-doc/classConfigReader.html +++ b/docs/module-doc/classConfigReader.html @@ -103,17 +103,17 @@ Default constructor.

This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.

-Definition at line 799 of file modules.cpp. +Definition at line 819 of file modules.cpp.

References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror.

-

00800 {
-00801         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00802         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00803         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
-00804         if (!this->readerror)
-00805                 this->error = CONF_FILE_NOT_FOUND;
-00806 }
+
00820 {
+00821         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00822         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00823         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
+00824         if (!this->readerror)
+00825                 this->error = CONF_FILE_NOT_FOUND;
+00826 }
 
@@ -147,17 +147,17 @@ Overloaded constructor.

This constructor initialises the ConfigReader class to read a user-specified config file

-Definition at line 818 of file modules.cpp. +Definition at line 838 of file modules.cpp.

References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror.

-

00819 {
-00820         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00821         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00822         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
-00823         if (!this->readerror)
-00824                 this->error = CONF_FILE_NOT_FOUND;
-00825 };
+
00839 {
+00840         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00841         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00842         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
+00843         if (!this->readerror)
+00844                 this->error = CONF_FILE_NOT_FOUND;
+00845 };
 
@@ -190,16 +190,16 @@ Default destructor.

This method destroys the ConfigReader class.

-Definition at line 809 of file modules.cpp. +Definition at line 829 of file modules.cpp.

References cache, and errorlog.

-

00810 {
-00811         if (this->cache)
-00812                 delete this->cache;
-00813         if (this->errorlog)
-00814                 delete this->errorlog;
-00815 }
+
00830 {
+00831         if (this->cache)
+00832                 delete this->cache;
+00833         if (this->errorlog)
+00834                 delete this->errorlog;
+00835 }
 
@@ -243,40 +243,40 @@ Dumps the list of errors in a config file to an output location.

If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.

-Definition at line 896 of file modules.cpp. -

-References errorlog, connection::fd, and userrec::nick. -

-

00897 {
-00898         if (bail)
-00899         {
-00900                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
-00901                 exit(0);
-00902         }
-00903         else
-00904         {
-00905                 char dataline[1024];
-00906                 if (user)
-00907                 {
-00908                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
-00909                         while (!errorlog->eof())
-00910                         {
-00911                                 errorlog->getline(dataline,1024);
-00912                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
-00913                         }
-00914                 }
-00915                 else
-00916                 {
-00917                         WriteOpers("There were errors in the configuration file:",user->nick);
-00918                         while (!errorlog->eof())
-00919                         {
-00920                                 errorlog->getline(dataline,1024);
-00921                                 WriteOpers(dataline);
-00922                         }
-00923                 }
-00924                 return;
-00925         }
-00926 }
+Definition at line 916 of file modules.cpp.
+

+References errorlog, connection::fd, and userrec::nick. +

+

00917 {
+00918         if (bail)
+00919         {
+00920                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
+00921                 exit(0);
+00922         }
+00923         else
+00924         {
+00925                 char dataline[1024];
+00926                 if (user)
+00927                 {
+00928                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
+00929                         while (!errorlog->eof())
+00930                         {
+00931                                 errorlog->getline(dataline,1024);
+00932                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
+00933                         }
+00934                 }
+00935                 else
+00936                 {
+00937                         WriteOpers("There were errors in the configuration file:",user->nick);
+00938                         while (!errorlog->eof())
+00939                         {
+00940                                 errorlog->getline(dataline,1024);
+00941                                 WriteOpers(dataline);
+00942                         }
+00943                 }
+00944                 return;
+00945         }
+00946 }
 
@@ -310,13 +310,13 @@ Counts the number of times a given tag appears in the config file.

This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of ConfigReader::ReadValue to loop through all copies of a multiple instance tag.

-Definition at line 929 of file modules.cpp. +Definition at line 949 of file modules.cpp.

References cache.

-

00930 {
-00931         return EnumConf(cache,tag.c_str());
-00932 }
+
00950 {
+00951         return EnumConf(cache,tag.c_str());
+00952 }
 
@@ -359,13 +359,13 @@ Returns the number of items within a tag.

For example if the tag was <test tag="blah" data="foo"> then this function would return 2. Spaces and newlines both qualify as valid seperators between values.

-Definition at line 934 of file modules.cpp. +Definition at line 954 of file modules.cpp.

References cache.

-

00935 {
-00936         return EnumValues(cache, tag.c_str(), index);
-00937 }
+
00955 {
+00956         return EnumValues(cache, tag.c_str(), index);
+00957 }
 
@@ -398,15 +398,15 @@ Returns the last error to occur.

Valid errors can be found by looking in modules.h. Any nonzero value indicates an error condition. A call to GetError() resets the error flag back to 0.

-Definition at line 889 of file modules.cpp. +Definition at line 909 of file modules.cpp.

References error.

-

00890 {
-00891         long olderr = this->error;
-00892         this->error = 0;
-00893         return olderr;
-00894 }
+
00910 {
+00911         long olderr = this->error;
+00912         this->error = 0;
+00913         return olderr;
+00914 }
 
@@ -455,25 +455,25 @@ Retrieves a boolean value from the config file.

This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values "1", "yes" and "true" in the config file count as true to ReadFlag, and any other value counts as false.

-Definition at line 843 of file modules.cpp. +Definition at line 863 of file modules.cpp.

References cache, CONF_VALUE_NOT_FOUND, and error.

-

00844 {
-00845         char val[MAXBUF];
-00846         char t[MAXBUF];
-00847         char n[MAXBUF];
-00848         strlcpy(t,tag.c_str(),MAXBUF);
-00849         strlcpy(n,name.c_str(),MAXBUF);
-00850         int res = ReadConf(cache,t,n,index,val);
-00851         if (!res)
-00852         {
-00853                 this->error = CONF_VALUE_NOT_FOUND;
-00854                 return false;
-00855         }
-00856         std::string s = val;
-00857         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
-00858 }
+
00864 {
+00865         char val[MAXBUF];
+00866         char t[MAXBUF];
+00867         char n[MAXBUF];
+00868         strlcpy(t,tag.c_str(),MAXBUF);
+00869         strlcpy(n,name.c_str(),MAXBUF);
+00870         int res = ReadConf(cache,t,n,index,val);
+00871         if (!res)
+00872         {
+00873                 this->error = CONF_VALUE_NOT_FOUND;
+00874                 return false;
+00875         }
+00876         std::string s = val;
+00877         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
+00878 }
 
@@ -528,37 +528,37 @@ Retrieves an integer value from the config file.

This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to GetError() will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and GetError() will return CONF_NOT_UNSIGNED

-Definition at line 860 of file modules.cpp. +Definition at line 880 of file modules.cpp.

References cache, CONF_NOT_A_NUMBER, CONF_NOT_UNSIGNED, CONF_VALUE_NOT_FOUND, and error.

-

00861 {
-00862         char val[MAXBUF];
-00863         char t[MAXBUF];
-00864         char n[MAXBUF];
-00865         strlcpy(t,tag.c_str(),MAXBUF);
-00866         strlcpy(n,name.c_str(),MAXBUF);
-00867         int res = ReadConf(cache,t,n,index,val);
-00868         if (!res)
-00869         {
-00870                 this->error = CONF_VALUE_NOT_FOUND;
-00871                 return 0;
-00872         }
-00873         for (int i = 0; i < strlen(val); i++)
-00874         {
-00875                 if (!isdigit(val[i]))
-00876                 {
-00877                         this->error = CONF_NOT_A_NUMBER;
-00878                         return 0;
-00879                 }
-00880         }
-00881         if ((needs_unsigned) && (atoi(val)<0))
-00882         {
-00883                 this->error = CONF_NOT_UNSIGNED;
-00884                 return 0;
-00885         }
-00886         return atoi(val);
-00887 }
+
00881 {
+00882         char val[MAXBUF];
+00883         char t[MAXBUF];
+00884         char n[MAXBUF];
+00885         strlcpy(t,tag.c_str(),MAXBUF);
+00886         strlcpy(n,name.c_str(),MAXBUF);
+00887         int res = ReadConf(cache,t,n,index,val);
+00888         if (!res)
+00889         {
+00890                 this->error = CONF_VALUE_NOT_FOUND;
+00891                 return 0;
+00892         }
+00893         for (int i = 0; i < strlen(val); i++)
+00894         {
+00895                 if (!isdigit(val[i]))
+00896                 {
+00897                         this->error = CONF_NOT_A_NUMBER;
+00898                         return 0;
+00899                 }
+00900         }
+00901         if ((needs_unsigned) && (atoi(val)<0))
+00902         {
+00903                 this->error = CONF_NOT_UNSIGNED;
+00904                 return 0;
+00905         }
+00906         return atoi(val);
+00907 }
 
@@ -607,24 +607,24 @@ Retrieves a value from the config file.

This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.

-Definition at line 827 of file modules.cpp. +Definition at line 847 of file modules.cpp.

References cache, CONF_VALUE_NOT_FOUND, and error.

-

00828 {
-00829         char val[MAXBUF];
-00830         char t[MAXBUF];
-00831         char n[MAXBUF];
-00832         strlcpy(t,tag.c_str(),MAXBUF);
-00833         strlcpy(n,name.c_str(),MAXBUF);
-00834         int res = ReadConf(cache,t,n,index,val);
-00835         if (!res)
-00836         {
-00837                 this->error = CONF_VALUE_NOT_FOUND;
-00838                 return "";
-00839         }
-00840         return val;
-00841 }
+
00848 {
+00849         char val[MAXBUF];
+00850         char t[MAXBUF];
+00851         char n[MAXBUF];
+00852         strlcpy(t,tag.c_str(),MAXBUF);
+00853         strlcpy(n,name.c_str(),MAXBUF);
+00854         int res = ReadConf(cache,t,n,index,val);
+00855         if (!res)
+00856         {
+00857                 this->error = CONF_VALUE_NOT_FOUND;
+00858                 return "";
+00859         }
+00860         return val;
+00861 }
 
@@ -657,13 +657,13 @@ Returns true if a config file is valid.

This method is partially implemented and will only return false if the config file does not exist or could not be opened.

-Definition at line 939 of file modules.cpp. +Definition at line 959 of file modules.cpp.

References readerror.

-

00940 {
-00941         return this->readerror;
-00942 }
+
00960 {
+00961         return this->readerror;
+00962 }
 
@@ -693,7 +693,7 @@ It will contain a pointer to the configuration file data with unneeded data (suc

Definition at line 1158 of file modules.h.

-Referenced by ConfigReader(), Enumerate(), EnumerateValues(), ReadFlag(), ReadInteger(), ReadValue(), and ~ConfigReader(). +Referenced by ConfigReader(), Enumerate(), EnumerateValues(), ReadFlag(), ReadInteger(), ReadValue(), and ~ConfigReader().

@@ -719,7 +719,7 @@ Referenced by ConfigReader(

Definition at line 1163 of file modules.h.

-Referenced by ConfigReader(), GetError(), ReadFlag(), ReadInteger(), and ReadValue(). +Referenced by ConfigReader(), GetError(), ReadFlag(), ReadInteger(), and ReadValue().

@@ -745,7 +745,7 @@ Referenced by ConfigReader(

Definition at line 1159 of file modules.h.

-Referenced by ConfigReader(), DumpErrors(), and ~ConfigReader(). +Referenced by ConfigReader(), DumpErrors(), and ~ConfigReader().

@@ -773,12 +773,12 @@ Used to store errors.

Definition at line 1162 of file modules.h.

-Referenced by ConfigReader(), and Verify(). +Referenced by ConfigReader(), and Verify().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:37:55 2005 for InspIRCd by +
Generated on Tue May 24 02:31:43 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConnectClass-members.html b/docs/module-doc/classConnectClass-members.html index de0dd1c1a..bda02a7cf 100644 --- a/docs/module-doc/classConnectClass-members.html +++ b/docs/module-doc/classConnectClass-members.html @@ -19,7 +19,7 @@ thresholdConnectClass typeConnectClass ~classbase()classbase [inline] -
Generated on Sun May 15 18:37:57 2005 for InspIRCd by +
Generated on Tue May 24 02:31:45 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConnectClass.html b/docs/module-doc/classConnectClass.html index 26ea088c9..0257db570 100644 --- a/docs/module-doc/classConnectClass.html +++ b/docs/module-doc/classConnectClass.html @@ -355,7 +355,7 @@ Definition at line 50 of fi
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:37:57 2005 for InspIRCd by +
Generated on Tue May 24 02:31:45 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classDNS-members.html b/docs/module-doc/classDNS-members.html index 4239cc7c2..866b52f0c 100644 --- a/docs/module-doc/classDNS-members.html +++ b/docs/module-doc/classDNS-members.html @@ -33,7 +33,7 @@ SetNS(std::string dnsserver)DNS tDNS [private] ~DNS()DNS -
Generated on Sun May 15 18:38:02 2005 for InspIRCd by +
Generated on Tue May 24 02:31:50 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classDNS.html b/docs/module-doc/classDNS.html index 61a38b3ee..d5f448884 100644 --- a/docs/module-doc/classDNS.html +++ b/docs/module-doc/classDNS.html @@ -891,7 +891,7 @@ Definition at line 40 of file
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:02 2005 for InspIRCd by +
Generated on Tue May 24 02:31:50 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classELine-members.html b/docs/module-doc/classELine-members.html index 5ba4b6572..b160a75b9 100644 --- a/docs/module-doc/classELine-members.html +++ b/docs/module-doc/classELine-members.html @@ -15,7 +15,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:06 2005 for InspIRCd by +
Generated on Tue May 24 02:31:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classELine.html b/docs/module-doc/classELine.html index 01baa4788..379a397c3 100644 --- a/docs/module-doc/classELine.html +++ b/docs/module-doc/classELine.html @@ -53,7 +53,7 @@ Definition at line 88 of fi
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:06 2005 for InspIRCd by +
Generated on Tue May 24 02:31:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classEvent-members.html b/docs/module-doc/classEvent-members.html index dfef00b0e..9db6b9ec7 100644 --- a/docs/module-doc/classEvent-members.html +++ b/docs/module-doc/classEvent-members.html @@ -17,7 +17,7 @@ Send()Event [virtual] sourceEvent [protected] ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:08 2005 for InspIRCd by +
Generated on Tue May 24 02:31:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classEvent.html b/docs/module-doc/classEvent.html index a5aae85a0..00ca01ea3 100644 --- a/docs/module-doc/classEvent.html +++ b/docs/module-doc/classEvent.html @@ -103,9 +103,9 @@ Create a new Event.

-Definition at line 269 of file modules.cpp. +Definition at line 278 of file modules.cpp.

-

00269 : data(anydata), source(src), id(eventid) { };
+
00278 : data(anydata), source(src), id(eventid) { };
 
@@ -139,13 +139,13 @@ Get the Event data.

-Definition at line 271 of file modules.cpp. +Definition at line 280 of file modules.cpp.

References data.

-

00272 {
-00273         return this->data;
-00274 }
+
00281 {
+00282         return this->data;
+00283 }
 
@@ -178,13 +178,13 @@ Get the event ID.

Use this to determine the event type for safe casting of the data

-Definition at line 287 of file modules.cpp. +Definition at line 296 of file modules.cpp.

References id.

-

00288 {
-00289         return this->id;
-00290 }
+
00297 {
+00298         return this->id;
+00299 }
 
@@ -217,13 +217,13 @@ Get the event Source.

-Definition at line 276 of file modules.cpp. +Definition at line 285 of file modules.cpp.

References source.

-

00277 {
-00278         return this->source;
-00279 }
+
00286 {
+00287         return this->source;
+00288 }
 
@@ -258,14 +258,14 @@ The return result of an Event::Send() Implements ModuleMessage.

-Definition at line 281 of file modules.cpp. +Definition at line 290 of file modules.cpp.

References FOREACH_MOD.

-

00282 {
-00283         FOREACH_MOD OnEvent(this);
-00284         return NULL;
-00285 }
+
00291 {
+00292         FOREACH_MOD OnEvent(this);
+00293         return NULL;
+00294 }
 
@@ -295,7 +295,7 @@ This member holds a pointer to arbitary data set by the emitter of the message.

Definition at line 199 of file modules.h.

-Referenced by GetData(). +Referenced by GetData().

@@ -323,7 +323,7 @@ This is arbitary text which should be used to distinguish one type of event from

Definition at line 208 of file modules.h.

-Referenced by GetEventID(). +Referenced by GetEventID().

@@ -351,12 +351,12 @@ This is a pointer to the sender of the message, which can be used to directly tr

Definition at line 203 of file modules.h.

-Referenced by GetSource(). +Referenced by GetSource().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:38:08 2005 for InspIRCd by +
Generated on Tue May 24 02:31:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExemptItem-members.html b/docs/module-doc/classExemptItem-members.html index 6290f2147..fcb3b5941 100644 --- a/docs/module-doc/classExemptItem-members.html +++ b/docs/module-doc/classExemptItem-members.html @@ -14,7 +14,7 @@ set_timeHostItem ~classbase()classbase [inline] ~HostItem()HostItem [inline, virtual] -
Generated on Sun May 15 18:38:10 2005 for InspIRCd by +
Generated on Tue May 24 02:31:57 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExemptItem.html b/docs/module-doc/classExemptItem.html index 9e6368413..c8f2a76b9 100644 --- a/docs/module-doc/classExemptItem.html +++ b/docs/module-doc/classExemptItem.html @@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 60 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:10 2005 for InspIRCd by +
Generated on Tue May 24 02:31:57 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtMode-members.html b/docs/module-doc/classExtMode-members.html index cb5e1c85f..7a77906be 100644 --- a/docs/module-doc/classExtMode-members.html +++ b/docs/module-doc/classExtMode-members.html @@ -16,7 +16,7 @@ params_when_onExtMode typeExtMode ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:16 2005 for InspIRCd by +
Generated on Tue May 24 02:32:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtMode.html b/docs/module-doc/classExtMode.html index e372aa19a..14e8177ac 100644 --- a/docs/module-doc/classExtMode.html +++ b/docs/module-doc/classExtMode.html @@ -88,11 +88,11 @@

-Definition at line 136 of file modules.cpp. +Definition at line 145 of file modules.cpp.

-References modechar, needsoper, params_when_off, params_when_on, and type. +References modechar, needsoper, params_when_off, params_when_on, and type.

-

00136 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
+
00145 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
 
@@ -118,7 +118,7 @@ References modechar,

-Definition at line 135 of file modules.cpp. +Definition at line 144 of file modules.cpp.

@@ -142,9 +142,9 @@ Definition at line 135

-Definition at line 130 of file modules.cpp. +Definition at line 139 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -168,9 +168,9 @@ Referenced by ExtMode()

-Definition at line 134 of file modules.cpp. +Definition at line 143 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -194,9 +194,9 @@ Referenced by ExtMode()

-Definition at line 133 of file modules.cpp. +Definition at line 142 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -220,9 +220,9 @@ Referenced by ExtMode()

-Definition at line 132 of file modules.cpp. +Definition at line 141 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -246,14 +246,14 @@ Referenced by ExtMode()

-Definition at line 131 of file modules.cpp. +Definition at line 140 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:16 2005 for InspIRCd by +
Generated on Tue May 24 02:32:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtensible-members.html b/docs/module-doc/classExtensible-members.html index 1e894ad20..b1b4d8bd6 100644 --- a/docs/module-doc/classExtensible-members.html +++ b/docs/module-doc/classExtensible-members.html @@ -13,7 +13,7 @@ GetExt(std::string key)Extensible Shrink(std::string key)Extensible ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:13 2005 for InspIRCd by +
Generated on Tue May 24 02:31:59 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtensible.html b/docs/module-doc/classExtensible.html index 9ca7326ce..8e3371ba5 100644 --- a/docs/module-doc/classExtensible.html +++ b/docs/module-doc/classExtensible.html @@ -180,7 +180,7 @@ Definition at line 54 of fil
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:13 2005 for InspIRCd by +
Generated on Tue May 24 02:31:59 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classFileReader-members.html b/docs/module-doc/classFileReader-members.html index 8add7fb35..9cc785b5b 100644 --- a/docs/module-doc/classFileReader-members.html +++ b/docs/module-doc/classFileReader-members.html @@ -17,7 +17,7 @@ LoadFile(std::string filename)FileReader ~classbase()classbase [inline] ~FileReader()FileReader -
Generated on Sun May 15 18:38:18 2005 for InspIRCd by +
Generated on Tue May 24 02:32:03 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classFileReader.html b/docs/module-doc/classFileReader.html index 7b5ff42e5..c8688bd2f 100644 --- a/docs/module-doc/classFileReader.html +++ b/docs/module-doc/classFileReader.html @@ -83,10 +83,10 @@ Default constructor.

This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.

-Definition at line 952 of file modules.cpp. +Definition at line 972 of file modules.cpp.

-

00953 {
-00954 }
+
00973 {
+00974 }
 
@@ -120,15 +120,15 @@ Secondary constructor.

This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, FileReader::FileSize returns 0.

-Definition at line 945 of file modules.cpp. +Definition at line 965 of file modules.cpp.

References fc, and file_cache.

-

00946 {
-00947         file_cache c;
-00948         readfile(c,filename.c_str());
-00949         this->fc = c;
-00950 }
+
00966 {
+00967         file_cache c;
+00968         readfile(c,filename.c_str());
+00969         this->fc = c;
+00970 }
 
@@ -161,10 +161,10 @@ Default destructor.

This deletes the memory allocated to the file.

-Definition at line 964 of file modules.cpp. +Definition at line 984 of file modules.cpp.

-

00965 {
-00966 }
+
00985 {
+00986 }
 
@@ -198,20 +198,20 @@ Returns true if the file exists This function will return false if the file coul

-Definition at line 968 of file modules.cpp. +Definition at line 988 of file modules.cpp.

References fc.

-

00969 {
-00970         if (fc.size() == 0)
-00971         {
-00972                 return(false);
-00973         }
-00974         else
-00975         {
-00976                 return(true);
-00977         }
-00978 }
+
00989 {
+00990         if (fc.size() == 0)
+00991         {
+00992                 return(false);
+00993         }
+00994         else
+00995         {
+00996                 return(true);
+00997         }
+00998 }
 
@@ -244,13 +244,13 @@ Returns the size of the file in lines.

This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.

-Definition at line 987 of file modules.cpp. +Definition at line 1007 of file modules.cpp.

References fc.

-

00988 {
-00989         return fc.size();
-00990 }
+
01008 {
+01009         return fc.size();
+01010 }
 
@@ -284,15 +284,15 @@ Retrieve one line from the file.

This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.

-Definition at line 980 of file modules.cpp. +Definition at line 1000 of file modules.cpp.

References fc.

-

00981 {
-00982         if ((x<0) || (x>fc.size()))
-00983                 return "";
-00984         return fc[x];
-00985 }
+
01001 {
+01002         if ((x<0) || (x>fc.size()))
+01003                 return "";
+01004         return fc[x];
+01005 }
 
@@ -326,15 +326,15 @@ Used to load a file.

This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, FileReader::FileSize returns 0.

-Definition at line 956 of file modules.cpp. +Definition at line 976 of file modules.cpp.

References fc, and file_cache.

-

00957 {
-00958         file_cache c;
-00959         readfile(c,filename.c_str());
-00960         this->fc = c;
-00961 }
+
00977 {
+00978         file_cache c;
+00979         readfile(c,filename.c_str());
+00980         this->fc = c;
+00981 }
 
@@ -362,12 +362,12 @@ References fc, and Definition at line 1241 of file modules.h.

-Referenced by Exists(), FileReader(), FileSize(), GetLine(), and LoadFile(). +Referenced by Exists(), FileReader(), FileSize(), GetLine(), and LoadFile().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:38:18 2005 for InspIRCd by +
Generated on Tue May 24 02:32:03 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classGLine-members.html b/docs/module-doc/classGLine-members.html index 326931709..8d1913346 100644 --- a/docs/module-doc/classGLine-members.html +++ b/docs/module-doc/classGLine-members.html @@ -15,7 +15,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:20 2005 for InspIRCd by +
Generated on Tue May 24 02:32:06 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classGLine.html b/docs/module-doc/classGLine.html index a61960caa..1d017d2e4 100644 --- a/docs/module-doc/classGLine.html +++ b/docs/module-doc/classGLine.html @@ -61,7 +61,7 @@ Definition at line 79 of fi
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:20 2005 for InspIRCd by +
Generated on Tue May 24 02:32:06 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classHostItem-members.html b/docs/module-doc/classHostItem-members.html index f62bcd81f..6edb9175b 100644 --- a/docs/module-doc/classHostItem-members.html +++ b/docs/module-doc/classHostItem-members.html @@ -14,7 +14,7 @@ set_timeHostItem ~classbase()classbase [inline] ~HostItem()HostItem [inline, virtual] -
Generated on Sun May 15 18:38:23 2005 for InspIRCd by +
Generated on Tue May 24 02:32:08 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classHostItem.html b/docs/module-doc/classHostItem.html index d5e73b411..77389e5d9 100644 --- a/docs/module-doc/classHostItem.html +++ b/docs/module-doc/classHostItem.html @@ -185,7 +185,7 @@ Definition at line 39 of
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:23 2005 for InspIRCd by +
Generated on Tue May 24 02:32:07 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInviteItem-members.html b/docs/module-doc/classInviteItem-members.html index f8ad2fa92..d9845965c 100644 --- a/docs/module-doc/classInviteItem-members.html +++ b/docs/module-doc/classInviteItem-members.html @@ -14,7 +14,7 @@ set_timeHostItem ~classbase()classbase [inline] ~HostItem()HostItem [inline, virtual] -
Generated on Sun May 15 18:38:27 2005 for InspIRCd by +
Generated on Tue May 24 02:32:11 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInviteItem.html b/docs/module-doc/classInviteItem.html index 5c187c1a1..f4b445ab3 100644 --- a/docs/module-doc/classInviteItem.html +++ b/docs/module-doc/classInviteItem.html @@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 68 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:27 2005 for InspIRCd by +
Generated on Tue May 24 02:32:11 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInvited-members.html b/docs/module-doc/classInvited-members.html index 22c46b7bf..5c24252c7 100644 --- a/docs/module-doc/classInvited-members.html +++ b/docs/module-doc/classInvited-members.html @@ -10,7 +10,7 @@ channelInvited classbase()classbase [inline] ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:25 2005 for InspIRCd by +
Generated on Tue May 24 02:32:09 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInvited.html b/docs/module-doc/classInvited.html index f9418fa19..86dd2a2de 100644 --- a/docs/module-doc/classInvited.html +++ b/docs/module-doc/classInvited.html @@ -53,12 +53,12 @@ Definition at line 36 of fi

Definition at line 39 of file users.h.

-Referenced by userrec::InviteTo(). +Referenced by userrec::InviteTo().


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:25 2005 for InspIRCd by +
Generated on Tue May 24 02:32:09 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classKLine-members.html b/docs/module-doc/classKLine-members.html index cd1832c6a..18020f5b5 100644 --- a/docs/module-doc/classKLine-members.html +++ b/docs/module-doc/classKLine-members.html @@ -15,7 +15,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:36 2005 for InspIRCd by +
Generated on Tue May 24 02:32:17 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classKLine.html b/docs/module-doc/classKLine.html index fb2c061be..96bca5fc8 100644 --- a/docs/module-doc/classKLine.html +++ b/docs/module-doc/classKLine.html @@ -61,7 +61,7 @@ Definition at line 68 of fi
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:36 2005 for InspIRCd by +
Generated on Tue May 24 02:32:17 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModeParameter-members.html b/docs/module-doc/classModeParameter-members.html index d52455ad8..b2bc706b6 100644 --- a/docs/module-doc/classModeParameter-members.html +++ b/docs/module-doc/classModeParameter-members.html @@ -12,7 +12,7 @@ modeModeParameter parameterModeParameter ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:38 2005 for InspIRCd by +
Generated on Tue May 24 02:32:19 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModeParameter.html b/docs/module-doc/classModeParameter.html index 80dc5f044..fa1b317cd 100644 --- a/docs/module-doc/classModeParameter.html +++ b/docs/module-doc/classModeParameter.html @@ -59,7 +59,7 @@ Definition at line 77 of

Definition at line 82 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().

@@ -85,7 +85,7 @@ Referenced by chanrec::Set

Definition at line 80 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().

@@ -111,12 +111,12 @@ Referenced by chanrec::Set

Definition at line 81 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:38 2005 for InspIRCd by +
Generated on Tue May 24 02:32:19 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModule-members.html b/docs/module-doc/classModule-members.html index 2e5a6372c..644a0423d 100644 --- a/docs/module-doc/classModule-members.html +++ b/docs/module-doc/classModule-members.html @@ -65,7 +65,7 @@ OnWhois(userrec *source, userrec *dest)Module [virtual] ~classbase()classbase [inline] ~Module()Module [virtual] -
Generated on Sun May 15 18:38:42 2005 for InspIRCd by +
Generated on Tue May 24 02:32:22 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModule.html b/docs/module-doc/classModule.html index 321974529..0403b27ad 100644 --- a/docs/module-doc/classModule.html +++ b/docs/module-doc/classModule.html @@ -227,9 +227,9 @@ Default constructor creates a module class.

-Definition at line 294 of file modules.cpp. +Definition at line 303 of file modules.cpp.

-

00294 { }
+
00303 { }
 
@@ -262,9 +262,9 @@ Default destructor destroys a module class.

-Definition at line 295 of file modules.cpp. +Definition at line 304 of file modules.cpp.

-

00295 { }
+
00304 { }
 
@@ -298,11 +298,11 @@ Returns the version number of a Module.

The method should return a Version object with its version information assigned via Version::Version

-Definition at line 307 of file modules.cpp. +Definition at line 316 of file modules.cpp.

References VF_VENDOR.

-

00307 { return Version(1,0,0,0,VF_VENDOR); }
+
00316 { return Version(1,0,0,0,VF_VENDOR); }
 
@@ -336,9 +336,9 @@ Called when a 005 numeric is about to be output.

The module should modify the 005 numeric if needed to indicate its features.

-Definition at line 319 of file modules.cpp. +Definition at line 328 of file modules.cpp.

-

00319 { };
+
00328 { };
 
@@ -405,11 +405,11 @@ This function is called before many functions which check a users status on a ch
Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).

-Definition at line 316 of file modules.cpp. +Definition at line 325 of file modules.cpp.

References ACR_DEFAULT.

-

00316 { return ACR_DEFAULT; };
+
00325 { return ACR_DEFAULT; };
 
@@ -458,9 +458,9 @@ Called whenever a ban is added to a channel's list.

Return a non-zero value to 'eat' the mode change and prevent the ban from being added.

-Definition at line 344 of file modules.cpp. +Definition at line 353 of file modules.cpp.

-

00344 { return 0; };
+
00353 { return 0; };
 
@@ -494,9 +494,9 @@ Called once every five seconds for background processing.

This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.

-Definition at line 322 of file modules.cpp. +Definition at line 331 of file modules.cpp.

-

00322 { };
+
00331 { };
 
@@ -539,9 +539,9 @@ Called whenever a change of a local users GECOS (fullname field) is attempted.

return 1 to deny the name change, or 0 to allow it.

-Definition at line 336 of file modules.cpp. +Definition at line 345 of file modules.cpp.

-

00336 { return 0; };
+
00345 { return 0; };
 
@@ -584,9 +584,9 @@ Called whenever a change of a local users displayed host is attempted.

Return 1 to deny the host change, or 0 to allow it.

-Definition at line 335 of file modules.cpp. +Definition at line 344 of file modules.cpp.

-

00335 { return 0; };
+
00344 { return 0; };
 
@@ -620,11 +620,11 @@ Called during a netburst to sync channel data.

This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.

-Definition at line 318 of file modules.cpp. +Definition at line 327 of file modules.cpp.

References string_list.

-

00318 { string_list empty; return empty; }
+
00327 { string_list empty; return empty; }
 
@@ -667,9 +667,9 @@ Called whenever a user joins a channel, to determine if banlist checks should go

This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 333 of file modules.cpp. +Definition at line 342 of file modules.cpp.

-

00333 { return 0; };
+
00342 { return 0; };
 
@@ -712,9 +712,9 @@ Called whenever a user joins a channel, to determine if invite checks should go

This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 330 of file modules.cpp. +Definition at line 339 of file modules.cpp.

-

00330 { return 0; };
+
00339 { return 0; };
 
@@ -763,9 +763,9 @@ Called whenever a user joins a channel, to determine if key checks should go ahe

This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 331 of file modules.cpp. +Definition at line 340 of file modules.cpp.

-

00331 { return 0; };
+
00340 { return 0; };
 
@@ -808,9 +808,9 @@ Called whenever a user joins a channel, to determine if channel limit checks sho

This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 332 of file modules.cpp. +Definition at line 341 of file modules.cpp.

-

00332 { return 0; };
+
00341 { return 0; };
 
@@ -844,9 +844,9 @@ Called to check if a user who is connecting can now be allowed to register If an

For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.

-Definition at line 325 of file modules.cpp. +Definition at line 334 of file modules.cpp.

-

00325 { return true; };
+
00334 { return true; };
 
@@ -895,9 +895,9 @@ Called whenever a ban is removed from a channel's list.

Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.

-Definition at line 345 of file modules.cpp. +Definition at line 354 of file modules.cpp.

-

00345 { return 0; };
+
00354 { return 0; };
 
@@ -931,9 +931,9 @@ Called whenever an Event class is sent

Please see the documentation of Event::Send() for further information. The Event sent can always be assumed to be non-NULL, you should *always* check the value of Event::GetEventID() before doing anything to the event data, and you should *not* change the event data in any way!

-Definition at line 339 of file modules.cpp. +Definition at line 348 of file modules.cpp.

-

00339 { return; };
+
00348 { return; };
 
@@ -1000,9 +1000,9 @@ Called whenever an extended mode is to be processed.

The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with Server::AddExtendedMode If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.

-Definition at line 306 of file modules.cpp. +Definition at line 315 of file modules.cpp.

-

00306 { return false; }
+
00315 { return false; }
 
@@ -1036,9 +1036,9 @@ Called whenever a user connects, anywhere on the network.

This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.

-Definition at line 343 of file modules.cpp. +Definition at line 352 of file modules.cpp.

-

00343 { };
+
00352 { };
 
@@ -1072,9 +1072,9 @@ Called whenever a user is given usermode +o, anywhere on the network.

You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.

-Definition at line 342 of file modules.cpp. +Definition at line 351 of file modules.cpp.

-

00342 { };
+
00351 { };
 
@@ -1109,9 +1109,9 @@ Called whenever a user types /INFO. The userrec will contain the information of the user who typed the command. Modules may use this method to output their own credits in /INFO (which is the ircd's version of an about box). It is purposefully not possible to modify any info that has already been output, or halt the list. You must write a 371 numeric to the user, containing your info in the following format:

<nick> :information here

-Definition at line 309 of file modules.cpp. +Definition at line 318 of file modules.cpp.

-

00309 { };
+
00318 { };
 
@@ -1160,9 +1160,9 @@ Called when a client is disconnected by KILL.

If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!

-Definition at line 320 of file modules.cpp. +Definition at line 329 of file modules.cpp.

-

00320 { return 0; };
+
00329 { return 0; };
 
@@ -1205,9 +1205,9 @@ Called whenever a module is loaded.

mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded "m_killwidgets.so" with "m_makewidgets.so". It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).

-Definition at line 321 of file modules.cpp. +Definition at line 330 of file modules.cpp.

-

00321 { };
+
00330 { };
 
@@ -1256,9 +1256,9 @@ Called whenever a topic is changed by a local user.

Return 1 to deny the topic change, or 0 to allow it.

-Definition at line 337 of file modules.cpp. +Definition at line 346 of file modules.cpp.

-

00337 { return 0; };
+
00346 { return 0; };
 
@@ -1331,9 +1331,9 @@ Called whenever an unknown token is received in a server to server link.

The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.

-Definition at line 338 of file modules.cpp. +Definition at line 347 of file modules.cpp.

-

00338 { return 0; };
+
00347 { return 0; };
 
@@ -1367,9 +1367,9 @@ Called whenever a user opers locally.

The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.

-Definition at line 308 of file modules.cpp. +Definition at line 317 of file modules.cpp.

-

00308 { };
+
00317 { };
 
@@ -1412,9 +1412,9 @@ Called whenever an oper password is to be compared to what a user has input.

The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.

-Definition at line 341 of file modules.cpp. +Definition at line 350 of file modules.cpp.

-

00341 { return 0; };
+
00350 { return 0; };
 
@@ -1457,9 +1457,9 @@ Called after a packet is received from another irc server.

This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.

-Definition at line 302 of file modules.cpp. +Definition at line 311 of file modules.cpp.

-

00302 { }
+
00311 { }
 
@@ -1502,9 +1502,9 @@ Called before a packet is transmitted across the irc network between two irc ser

This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.

-Definition at line 301 of file modules.cpp. +Definition at line 310 of file modules.cpp.

-

00301 { }
+
00310 { }
 
@@ -1559,9 +1559,9 @@ Called whenever any command is about to be executed.

This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using Server::QuitUser) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)

-Definition at line 324 of file modules.cpp. +Definition at line 333 of file modules.cpp.

-

00324 { return 0; };
+
00333 { return 0; };
 
@@ -1628,9 +1628,9 @@ Called whenever a mode character is processed.

Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!

-Definition at line 329 of file modules.cpp. +Definition at line 338 of file modules.cpp.

-

00329 { return 0; };
+
00338 { return 0; };
 
@@ -1679,9 +1679,9 @@ Called immediately after any connection is accepted.

This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.

-Definition at line 346 of file modules.cpp. +Definition at line 355 of file modules.cpp.

-

00346 { };
+
00355 { };
 
@@ -1715,9 +1715,9 @@ Called immediately before any socket is closed.

When this event is called, shutdown() has not yet been called on the socket.

-Definition at line 348 of file modules.cpp. +Definition at line 357 of file modules.cpp.

-

00348 { };
+
00357 { };
 
@@ -1772,9 +1772,9 @@ Called immediately before any read() operation on a client socket in the core.

This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.

-Definition at line 349 of file modules.cpp. +Definition at line 358 of file modules.cpp.

-

00349 { return 0; };
+
00358 { return 0; };
 
@@ -1823,9 +1823,9 @@ Called immediately before any write() operation on a user's socket in the core.

Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().

-Definition at line 347 of file modules.cpp. +Definition at line 356 of file modules.cpp.

-

00347 { return 0; };
+
00356 { return 0; };
 
@@ -1858,9 +1858,9 @@ Called on rehash.

This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.

-Definition at line 303 of file modules.cpp. +Definition at line 312 of file modules.cpp.

-

00303 { }
+
00312 { }
 
@@ -1894,11 +1894,11 @@ Called whenever a Request class is se

Please see the documentation of Request::Send() for further information. The Request sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).

-Definition at line 340 of file modules.cpp. +Definition at line 349 of file modules.cpp.

-Referenced by Request::Send(). +Referenced by Request::Send().

-

00340 { return NULL; };
+
00349 { return NULL; };
 
@@ -1947,9 +1947,9 @@ Called whenever a list is needed for a listmode.

For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.

-Definition at line 323 of file modules.cpp. +Definition at line 332 of file modules.cpp.

-

00323 { };
+
00332 { };
 
@@ -1998,9 +1998,9 @@ Called when a raw command is transmitted or received.

This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter "raw". If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.

-Definition at line 304 of file modules.cpp. +Definition at line 313 of file modules.cpp.

-

00304 { }
+
00313 { }
 
@@ -2034,9 +2034,9 @@ Called on all /STATS commands This method is triggered for all /STATS use, inclu

-Definition at line 334 of file modules.cpp. +Definition at line 343 of file modules.cpp.

-

00334 { };
+
00343 { };
 
@@ -2070,9 +2070,9 @@ Called when a user connects.

The details of the connecting user are available to you in the parameter userrec *user

-Definition at line 296 of file modules.cpp. +Definition at line 305 of file modules.cpp.

-

00296 { }
+
00305 { }
 
@@ -2106,9 +2106,9 @@ Called whenever a user's socket is closed.

The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.

-Definition at line 298 of file modules.cpp. +Definition at line 307 of file modules.cpp.

-

00298 { }
+
00307 { }
 
@@ -2151,9 +2151,9 @@ Called when a user joins a channel.

The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channel

-Definition at line 299 of file modules.cpp. +Definition at line 308 of file modules.cpp.

-

00299 { }
+
00308 { }
 
@@ -2208,9 +2208,9 @@ Called whenever a user is kicked.

If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use Module::OnUserPreKick instead of this method.

-Definition at line 328 of file modules.cpp. +Definition at line 337 of file modules.cpp.

-

00328 { };
+
00337 { };
 
@@ -2253,9 +2253,9 @@ Called when a user parts a channel.

The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channel

-Definition at line 300 of file modules.cpp. +Definition at line 309 of file modules.cpp.

-

00300 { }
+
00309 { }
 
@@ -2298,9 +2298,9 @@ Called after any nickchange, local or remote.

This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this.

-Definition at line 315 of file modules.cpp. +Definition at line 324 of file modules.cpp.

-

00315 { };
+
00324 { };
 
@@ -2349,9 +2349,9 @@ Called whenever a user is about to invite another user into a channel, before an

Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.

-Definition at line 311 of file modules.cpp. +Definition at line 320 of file modules.cpp.

-

00311 { return 0; };
+
00320 { return 0; };
 
@@ -2402,9 +2402,9 @@ Returning a value of 1 from this function stops the process immediately, causing IMPORTANT NOTE!

If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.

-Definition at line 305 of file modules.cpp. +Definition at line 314 of file modules.cpp.

-

00305 { return 0; }
+
00314 { return 0; }
 
@@ -2459,9 +2459,9 @@ Called whenever a user is about to be kicked.

Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc.

-Definition at line 327 of file modules.cpp. +Definition at line 336 of file modules.cpp.

-

00327 { return 0; };
+
00336 { return 0; };
 
@@ -2516,9 +2516,9 @@ Called whenever a user is about to PRIVMSG A user or a channel, before any proce

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.

-Definition at line 312 of file modules.cpp. +Definition at line 321 of file modules.cpp.

-

00312 { return 0; };
+
00321 { return 0; };
 
@@ -2561,9 +2561,9 @@ Called before any nickchange, local or remote.

This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.

-Definition at line 314 of file modules.cpp. +Definition at line 323 of file modules.cpp.

-

00314 { return 0; };
+
00323 { return 0; };
 
@@ -2618,9 +2618,9 @@ Called whenever a user is about to NOTICE A user or a channel, before any proces

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.

-Definition at line 313 of file modules.cpp. +Definition at line 322 of file modules.cpp.

-

00313 { return 0; };
+
00322 { return 0; };
 
@@ -2654,9 +2654,9 @@ Called when a user quits.

The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.

-Definition at line 297 of file modules.cpp. +Definition at line 306 of file modules.cpp.

-

00297 { }
+
00306 { }
 
@@ -2690,9 +2690,9 @@ Called whenever a user is about to register their connection (e.g.

before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.

-Definition at line 326 of file modules.cpp. +Definition at line 335 of file modules.cpp.

-

00326 { };
+
00335 { };
 
@@ -2726,11 +2726,11 @@ Called during a netburst to sync user data.

This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.

-Definition at line 317 of file modules.cpp. +Definition at line 326 of file modules.cpp.

References string_list.

-

00317 { string_list empty; return empty; }
+
00326 { string_list empty; return empty; }
 
@@ -2773,15 +2773,15 @@ Called whenever a /WHOIS is performed on a local user.

The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.

-Definition at line 310 of file modules.cpp. +Definition at line 319 of file modules.cpp.

-

00310 { };
+
00319 { };
 

The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:38:41 2005 for InspIRCd by +
Generated on Tue May 24 02:32:22 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleFactory-members.html b/docs/module-doc/classModuleFactory-members.html index 8f176375d..953c59428 100644 --- a/docs/module-doc/classModuleFactory-members.html +++ b/docs/module-doc/classModuleFactory-members.html @@ -12,7 +12,7 @@ ModuleFactory()ModuleFactory [inline] ~classbase()classbase [inline] ~ModuleFactory()ModuleFactory [inline, virtual] -
Generated on Sun May 15 18:38:43 2005 for InspIRCd by +
Generated on Tue May 24 02:32:24 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleFactory.html b/docs/module-doc/classModuleFactory.html index 3ac3cbf45..ea7ba7be9 100644 --- a/docs/module-doc/classModuleFactory.html +++ b/docs/module-doc/classModuleFactory.html @@ -136,7 +136,7 @@ Your inherited class of ModuleFactory must return a pointer to your modules.h -
Generated on Sun May 15 18:38:43 2005 for InspIRCd by +
Generated on Tue May 24 02:32:24 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleMessage-members.html b/docs/module-doc/classModuleMessage-members.html index 875d29dad..6ec1bc00a 100644 --- a/docs/module-doc/classModuleMessage-members.html +++ b/docs/module-doc/classModuleMessage-members.html @@ -10,7 +10,7 @@ classbase()classbase [inline] Send()=0ModuleMessage [pure virtual] ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:45 2005 for InspIRCd by +
Generated on Tue May 24 02:32:25 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleMessage.html b/docs/module-doc/classModuleMessage.html index 8d27ba15e..da075371a 100644 --- a/docs/module-doc/classModuleMessage.html +++ b/docs/module-doc/classModuleMessage.html @@ -67,7 +67,7 @@ Implemented in Request, and
The documentation for this class was generated from the following file:
-
Generated on Sun May 15 18:38:45 2005 for InspIRCd by +
Generated on Tue May 24 02:32:25 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classQLine-members.html b/docs/module-doc/classQLine-members.html index 9f402a179..2a1dd1db2 100644 --- a/docs/module-doc/classQLine-members.html +++ b/docs/module-doc/classQLine-members.html @@ -16,7 +16,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:49 2005 for InspIRCd by +
Generated on Tue May 24 02:32:28 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classQLine.html b/docs/module-doc/classQLine.html index 283bfb278..931722a3f 100644 --- a/docs/module-doc/classQLine.html +++ b/docs/module-doc/classQLine.html @@ -90,7 +90,7 @@ Definition at line 114 of f
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:49 2005 for InspIRCd by +
Generated on Tue May 24 02:32:28 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classRequest-members.html b/docs/module-doc/classRequest-members.html index 9c3046494..db48b74fd 100644 --- a/docs/module-doc/classRequest-members.html +++ b/docs/module-doc/classRequest-members.html @@ -17,7 +17,7 @@ Send()Request [virtual] sourceRequest [protected] ~classbase()classbase [inline] -
Generated on Sun May 15 18:38:52 2005 for InspIRCd by +
Generated on Tue May 24 02:32:30 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classRequest.html b/docs/module-doc/classRequest.html index dde88044d..82da97903 100644 --- a/docs/module-doc/classRequest.html +++ b/docs/module-doc/classRequest.html @@ -103,9 +103,9 @@ Create a new Request.

-Definition at line 240 of file modules.cpp. +Definition at line 249 of file modules.cpp.

-

00240 : data(anydata), source(src), dest(dst) { };
+
00249 : data(anydata), source(src), dest(dst) { };
 
@@ -139,13 +139,13 @@ Fetch the Request data.

-Definition at line 242 of file modules.cpp. +Definition at line 251 of file modules.cpp.

References data.

-

00243 {
-00244         return this->data;
-00245 }
+
00252 {
+00253         return this->data;
+00254 }
 
@@ -178,13 +178,13 @@ Fetch the request destination (should be 'this' in the receiving module).

-Definition at line 252 of file modules.cpp. +Definition at line 261 of file modules.cpp.

References dest.

-

00253 {
-00254         return this->dest;
-00255 }
+
00262 {
+00263         return this->dest;
+00264 }
 
@@ -217,13 +217,13 @@ Fetch the request source.

-Definition at line 247 of file modules.cpp. +Definition at line 256 of file modules.cpp.

References source.

-

00248 {
-00249         return this->source;
-00250 }
+
00257 {
+00258         return this->source;
+00259 }
 
@@ -258,20 +258,20 @@ Upon returning the result will be arbitary data returned by the module you sent

Implements ModuleMessage.

-Definition at line 257 of file modules.cpp. +Definition at line 266 of file modules.cpp.

-References dest, and Module::OnRequest(). +References dest, and Module::OnRequest().

-

00258 {
-00259         if (this->dest)
-00260         {
-00261                 return dest->OnRequest(this);
-00262         }
-00263         else
-00264         {
-00265                 return NULL;
-00266         }
-00267 }
+
00267 {
+00268         if (this->dest)
+00269         {
+00270                 return dest->OnRequest(this);
+00271         }
+00272         else
+00273         {
+00274                 return NULL;
+00275         }
+00276 }
 
@@ -301,7 +301,7 @@ This member holds a pointer to arbitary data set by the emitter of the message.

Definition at line 159 of file modules.h.

-Referenced by GetData(). +Referenced by GetData().

@@ -329,7 +329,7 @@ The single destination of the Request.

Definition at line 166 of file modules.h.

-Referenced by GetDest(), and Send(). +Referenced by GetDest(), and Send().

@@ -357,12 +357,12 @@ This is a pointer to the sender of the message, which can be used to directly tr

Definition at line 163 of file modules.h.

-Referenced by GetSource(). +Referenced by GetSource().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:38:52 2005 for InspIRCd by +
Generated on Tue May 24 02:32:30 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classServer-members.html b/docs/module-doc/classServer-members.html index 35d7a26e1..63c37a2bf 100644 --- a/docs/module-doc/classServer-members.html +++ b/docs/module-doc/classServer-members.html @@ -70,7 +70,7 @@ UserToPseudo(userrec *user, std::string message)Server [virtual] ~classbase()classbase [inline] ~Server()Server [virtual] -
Generated on Sun May 15 18:38:58 2005 for InspIRCd by +
Generated on Tue May 24 02:32:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classServer.html b/docs/module-doc/classServer.html index 4a69e0ef4..35044dac0 100644 --- a/docs/module-doc/classServer.html +++ b/docs/module-doc/classServer.html @@ -242,10 +242,10 @@ Default constructor.

Creates a Server object.

-Definition at line 355 of file modules.cpp. +Definition at line 364 of file modules.cpp.

-

00356 {
-00357 }
+
00365 {
+00366 }
 
@@ -278,10 +278,10 @@ Default destructor.

Destroys a Server object.

-Definition at line 359 of file modules.cpp. +Definition at line 368 of file modules.cpp.

-

00360 {
-00361 }
+
00369 {
+00370 }
 
@@ -345,13 +345,13 @@ This allows modules to add extra commands into the command table. You must place typedef void (handlerfunc) (char**, int, userrec*); ... void handle_kill(char **parameters, int pcnt, userrec *user)

When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. "m_blarp.so". If you place the wrong identifier here, you can cause crashes if your module is unloaded.

-Definition at line 428 of file modules.cpp. +Definition at line 437 of file modules.cpp.

References createcommand().

-

00429 {
-00430         createcommand(cmd,f,flags,minparams,source);
-00431 }
+
00438 {
+00439         createcommand(cmd,f,flags,minparams,source);
+00440 }
 
@@ -406,13 +406,13 @@ Adds a E-line The E-line is enforced as soon as it is added.

The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 679 of file modules.cpp. +Definition at line 699 of file modules.cpp.

-References add_eline(), and duration(). +References add_eline(), and duration().

-

00680 {
-00681         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00682 }
+
00700 {
+00701         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00702 }
 
@@ -451,16 +451,16 @@ This call is used to implement modes like +q and +a. The characteristics of thes (4) The mode and its parameter are NOT stored in the channels modes structure

It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.

-Definition at line 596 of file modules.cpp. +Definition at line 605 of file modules.cpp.

-References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL. +References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL.

-

00597 {
-00598         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
-00599         if (res)
-00600                 ModeMakeList(modechar);
-00601         return res;
-00602 }
+
00606 {
+00607         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
+00608         if (res)
+00609                 ModeMakeList(modechar);
+00610         return res;
+00611 }
 
@@ -521,36 +521,36 @@ Adds an extended mode letter which is parsed by a module.

This allows modules to add extra mode letters, e.g. +x for hostcloak. the "type" parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.

-Definition at line 568 of file modules.cpp. -

-References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. -

-

00569 {
-00570         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
-00571         {
-00572                 if (type == MT_SERVER)
-00573                 {
-00574                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
-00575                         return false;
-00576                 }
-00577                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
-00578                 {
-00579                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
-00580                         return false;
-00581                 }
-00582                 if ((params_when_on>1) || (params_when_off>1))
-00583                 {
-00584                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
-00585                         return false;
-00586                 }
-00587                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
-00588         }
-00589         else
-00590         {
-00591                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
-00592         }
-00593         return false;
-00594 }
+Definition at line 577 of file modules.cpp.
+

+References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. +

+

00578 {
+00579         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
+00580         {
+00581                 if (type == MT_SERVER)
+00582                 {
+00583                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
+00584                         return false;
+00585                 }
+00586                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
+00587                 {
+00588                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
+00589                         return false;
+00590                 }
+00591                 if ((params_when_on>1) || (params_when_off>1))
+00592                 {
+00593                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
+00594                         return false;
+00595                 }
+00596                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
+00597         }
+00598         else
+00599         {
+00600                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
+00601         }
+00602         return false;
+00603 }
 
@@ -605,13 +605,13 @@ Adds a G-line The G-line is propogated to all of the servers in the mesh and enf

The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 659 of file modules.cpp. +Definition at line 679 of file modules.cpp.

-References add_gline(), and duration(). +References add_gline(), and duration().

-

00660 {
-00661         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00662 }
+
00680 {
+00681         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00682 }
 
@@ -666,13 +666,13 @@ Adds a K-line The K-line is enforced as soon as it is added.

The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 674 of file modules.cpp. +Definition at line 694 of file modules.cpp.

-References add_kline(), and duration(). +References add_kline(), and duration().

-

00675 {
-00676         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00677 }
+
00695 {
+00696         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00697 }
 
@@ -727,13 +727,13 @@ Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enf

The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 664 of file modules.cpp. +Definition at line 684 of file modules.cpp.

-References add_qline(), and duration(). +References add_qline(), and duration().

-

00665 {
-00666         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
-00667 }
+
00685 {
+00686         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
+00687 }
 
@@ -788,13 +788,13 @@ Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enf

The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 669 of file modules.cpp. +Definition at line 689 of file modules.cpp.

-References add_zline(), and duration(). +References add_zline(), and duration().

-

00670 {
-00671         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
-00672 }
+
00690 {
+00691         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
+00692 }
 
@@ -828,13 +828,13 @@ Calculates a duration This method will take a string containing a formatted dura

"1w2d") and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.

-Definition at line 709 of file modules.cpp. +Definition at line 729 of file modules.cpp.

-References duration(). +References duration().

-

00710 {
-00711         return duration(delta.c_str());
-00712 }
+
00730 {
+00731         return duration(delta.c_str());
+00732 }
 
@@ -890,11 +890,11 @@ Calls the handler for a command, either implemented by the core or by another mo You can use this function to trigger other commands in the ircd, such as PRIVMSG, JOIN, KICK etc, or even as a method of callback. By defining command names that are untypeable for users on irc (e.g. those which contain a or
) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih AddCommand(). The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.

-Definition at line 418 of file modules.cpp. +Definition at line 427 of file modules.cpp.

-

00419 {
-00420         call_handler(commandname.c_str(),parameters,pcnt,user);
-00421 }
+
00428 {
+00429         call_handler(commandname.c_str(),parameters,pcnt,user);
+00430 }
 
@@ -937,13 +937,13 @@ Change GECOS (fullname) of a user.

You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.

-Definition at line 511 of file modules.cpp. +Definition at line 520 of file modules.cpp.

-References ChangeName(). +References ChangeName().

-

00512 {
-00513         ChangeName(user,gecos.c_str());
-00514 }
+
00521 {
+00522         ChangeName(user,gecos.c_str());
+00523 }
 
@@ -986,13 +986,13 @@ Change displayed hostname of a user.

You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.

-Definition at line 506 of file modules.cpp. +Definition at line 515 of file modules.cpp.

-References ChangeDisplayedHost(). +References ChangeDisplayedHost().

-

00507 {
-00508         ChangeDisplayedHost(user,host.c_str());
-00509 }
+
00516 {
+00517         ChangeDisplayedHost(user,host.c_str());
+00518 }
 
@@ -1035,11 +1035,11 @@ Forces a user nickchange.

This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.

-Definition at line 403 of file modules.cpp. +Definition at line 412 of file modules.cpp.

-

00404 {
-00405         force_nickchange(user,nickname.c_str());
-00406 }
+
00413 {
+00414         force_nickchange(user,nickname.c_str());
+00415 }
 
@@ -1082,13 +1082,13 @@ Attempts to look up a user's privilages on a channel.

This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.

-Definition at line 536 of file modules.cpp. +Definition at line 545 of file modules.cpp.

-References cmode(). +References cmode().

-

00537 {
-00538         return cmode(User,Chan);
-00539 }
+
00546 {
+00547         return cmode(User,Chan);
+00548 }
 
@@ -1131,13 +1131,13 @@ Returns true if two users share a common channel.

This method is used internally by the NICK and QUIT commands, and the Server::SendCommon method.

-Definition at line 484 of file modules.cpp. +Definition at line 493 of file modules.cpp.

References common_channels().

-

00485 {
-00486         return (common_channels(u1,u2) != 0);
-00487 }
+
00494 {
+00495         return (common_channels(u1,u2) != 0);
+00496 }
 
@@ -1171,11 +1171,11 @@ Returns a count of the number of users on a channel.

This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.

-Definition at line 604 of file modules.cpp. +Definition at line 613 of file modules.cpp.

-

00605 {
-00606         return usercount(c);
-00607 }
+
00614 {
+00615         return usercount(c);
+00616 }
 
@@ -1209,13 +1209,13 @@ Deletes a local E-Line.

-Definition at line 704 of file modules.cpp. +Definition at line 724 of file modules.cpp.

References del_eline().

-

00705 {
-00706         del_eline(hostmask.c_str());
-00707 }
+
00725 {
+00726         del_eline(hostmask.c_str());
+00727 }
 
@@ -1249,13 +1249,13 @@ Deletes a G-Line from all servers on the mesh.

-Definition at line 684 of file modules.cpp. +Definition at line 704 of file modules.cpp.

References del_gline().

-

00685 {
-00686         del_gline(hostmask.c_str());
-00687 }
+
00705 {
+00706         del_gline(hostmask.c_str());
+00707 }
 
@@ -1289,13 +1289,13 @@ Deletes a local K-Line.

-Definition at line 699 of file modules.cpp. +Definition at line 719 of file modules.cpp.

References del_kline().

-

00700 {
-00701         del_kline(hostmask.c_str());
-00702 }
+
00720 {
+00721         del_kline(hostmask.c_str());
+00722 }
 
@@ -1329,13 +1329,13 @@ Deletes a Q-Line from all servers on the mesh.

-Definition at line 689 of file modules.cpp. +Definition at line 709 of file modules.cpp.

References del_qline().

-

00690 {
-00691         del_qline(nickname.c_str());
-00692 }
+
00710 {
+00711         del_qline(nickname.c_str());
+00712 }
 
@@ -1369,13 +1369,13 @@ Deletes a Z-Line from all servers on the mesh.

-Definition at line 694 of file modules.cpp. +Definition at line 714 of file modules.cpp.

References del_zline().

-

00695 {
-00696         del_zline(ipaddr.c_str());
-00697 }
+
00715 {
+00716         del_zline(ipaddr.c_str());
+00717 }
 
@@ -1409,11 +1409,11 @@ Attempts to look up a channel and return a pointer to it.

This function will return NULL if the channel does not exist.

-Definition at line 531 of file modules.cpp. +Definition at line 540 of file modules.cpp.

-

00532 {
-00533         return FindChan(channel.c_str());
-00534 }
+
00541 {
+00542         return FindChan(channel.c_str());
+00543 }
 
@@ -1447,13 +1447,13 @@ Attempts to look up a nick using the file descriptor associated with that nick.

This function will return NULL if the file descriptor is not associated with a valid user.

-Definition at line 526 of file modules.cpp. +Definition at line 535 of file modules.cpp.

-References fd_ref_table. +References fd_ref_table.

-

00527 {
-00528         return (socket < 65536 ? fd_ref_table[socket] : NULL);
-00529 }
+
00536 {
+00537         return (socket < 65536 ? fd_ref_table[socket] : NULL);
+00538 }
 
@@ -1487,20 +1487,20 @@ This function finds a module by name.

You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.

-Definition at line 787 of file modules.cpp. +Definition at line 807 of file modules.cpp.

-References MODCOUNT, module_names, and modules. +References MODCOUNT, module_names, and modules.

-

00788 {
-00789         for (int i = 0; i <= MODCOUNT; i++)
-00790         {
-00791                 if (module_names[i] == name)
-00792                 {
-00793                         return modules[i];
-00794                 }
-00795         }
-00796         return NULL;
-00797 }
+
00808 {
+00809         for (int i = 0; i <= MODCOUNT; i++)
+00810         {
+00811                 if (module_names[i] == name)
+00812                 {
+00813                         return modules[i];
+00814                 }
+00815         }
+00816         return NULL;
+00817 }
 
@@ -1534,11 +1534,11 @@ Attempts to look up a nick and return a pointer to it.

This function will return NULL if the nick does not exist.

-Definition at line 521 of file modules.cpp. +Definition at line 530 of file modules.cpp.

-

00522 {
-00523         return Find(nick);
-00524 }
+
00531 {
+00532         return Find(nick);
+00533 }
 
@@ -1571,11 +1571,11 @@ Returns the information of the server as returned by the /ADMIN command.

See the Admin class for further information of the return value. The members Admin::Nick, Admin::Email and Admin::Name contain the information for the server where the module is loaded.

-Definition at line 561 of file modules.cpp. +Definition at line 570 of file modules.cpp.

-

00562 {
-00563         return Admin(getadminname(),getadminemail(),getadminnick());
-00564 }
+
00571 {
+00572         return Admin(getadminname(),getadminemail(),getadminnick());
+00573 }
 
@@ -1608,11 +1608,11 @@ Returns the network name, global to all linked servers.

-Definition at line 551 of file modules.cpp. +Definition at line 560 of file modules.cpp.

-

00552 {
-00553         return getnetworkname();
-00554 }
+
00561 {
+00562         return getnetworkname();
+00563 }
 
@@ -1645,11 +1645,11 @@ Returns the server description string of the local server.

-Definition at line 556 of file modules.cpp. +Definition at line 565 of file modules.cpp.

-

00557 {
-00558         return getserverdesc();
-00559 }
+
00566 {
+00567         return getserverdesc();
+00568 }
 
@@ -1682,11 +1682,11 @@ Returns the server name of the server where the module is loaded.

-Definition at line 546 of file modules.cpp. +Definition at line 555 of file modules.cpp.

-

00547 {
-00548         return getservername();
-00549 }
+
00556 {
+00557         return getservername();
+00558 }
 
@@ -1720,21 +1720,21 @@ Fetches the userlist of a channel.

This function must be here and not a member of userrec or chanrec due to include constraints.

-Definition at line 391 of file modules.cpp. -

-References chanuserlist, chanrec::GetUsers(), and list. -

-

00392 {
-00393         chanuserlist userl;
-00394         userl.clear();
-00395         std::vector<char*> *list = chan->GetUsers();
-00396         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
-00397         {
-00398                 char* o = *i;
-00399                 userl.push_back((userrec*)o);
-00400         }
-00401         return userl;
-00402 }
+Definition at line 400 of file modules.cpp.
+

+References chanuserlist, chanrec::GetUsers(), and list. +

+

00401 {
+00402         chanuserlist userl;
+00403         userl.clear();
+00404         std::vector<char*> *list = chan->GetUsers();
+00405         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
+00406         {
+00407                 char* o = *i;
+00408                 userl.push_back((userrec*)o);
+00409         }
+00410         return userl;
+00411 }
 
@@ -1768,13 +1768,13 @@ Returns true if a nick is valid.

Nicks for unregistered connections will return false.

-Definition at line 516 of file modules.cpp. +Definition at line 525 of file modules.cpp.

-References isnick(). +References isnick().

-

00517 {
-00518         return (isnick(nick.c_str()) != 0);
-00519 }
+
00526 {
+00527         return (isnick(nick.c_str()) != 0);
+00528 }
 
@@ -1817,13 +1817,13 @@ Checks if a user is on a channel.

This function will return true or false to indicate if user 'User' is on channel 'Chan'.

-Definition at line 541 of file modules.cpp. +Definition at line 550 of file modules.cpp.

-References has_channel(). +References has_channel().

-

00542 {
-00543         return has_channel(User,Chan);
-00544 }
+
00551 {
+00552         return has_channel(User,Chan);
+00553 }
 
@@ -1857,13 +1857,13 @@ Returns true if the servername you give is ulined.

ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.

-Definition at line 413 of file modules.cpp. +Definition at line 422 of file modules.cpp.

-References is_uline(). +References is_uline().

-

00414 {
-00415         return is_uline(server.c_str());
-00416 }
+
00423 {
+00424         return is_uline(server.c_str());
+00425 }
 
@@ -1897,35 +1897,35 @@ Returns true if a nick!ident string is correctly formatted, false if otherwise.

-Definition at line 714 of file modules.cpp. +Definition at line 734 of file modules.cpp.

-

00715 {
-00716         const char* dest = mask.c_str();
-00717         if (strchr(dest,'!')==0)
-00718                 return false;
-00719         if (strchr(dest,'@')==0)
-00720                 return false;
-00721         for (int i = 0; i < strlen(dest); i++)
-00722                 if (dest[i] < 32)
-00723                         return false;
-00724         for (int i = 0; i < strlen(dest); i++)
-00725                 if (dest[i] > 126)
-00726                         return false;
-00727         int c = 0;
-00728         for (int i = 0; i < strlen(dest); i++)
-00729                 if (dest[i] == '!')
-00730                         c++;
-00731         if (c>1)
-00732                 return false;
-00733         c = 0;
-00734         for (int i = 0; i < strlen(dest); i++)
-00735                 if (dest[i] == '@')
-00736                         c++;
-00737         if (c>1)
+
00735 {
+00736         const char* dest = mask.c_str();
+00737         if (strchr(dest,'!')==0)
 00738                 return false;
-00739 
-00740         return true;
-00741 }
+00739         if (strchr(dest,'@')==0)
+00740                 return false;
+00741         for (int i = 0; i < strlen(dest); i++)
+00742                 if (dest[i] < 32)
+00743                         return false;
+00744         for (int i = 0; i < strlen(dest); i++)
+00745                 if (dest[i] > 126)
+00746                         return false;
+00747         int c = 0;
+00748         for (int i = 0; i < strlen(dest); i++)
+00749                 if (dest[i] == '!')
+00750                         c++;
+00751         if (c>1)
+00752                 return false;
+00753         c = 0;
+00754         for (int i = 0; i < strlen(dest); i++)
+00755                 if (dest[i] == '@')
+00756                         c++;
+00757         if (c>1)
+00758                 return false;
+00759 
+00760         return true;
+00761 }
 
@@ -1974,11 +1974,11 @@ Forces a user to join a channel.

This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.

-Definition at line 381 of file modules.cpp. +Definition at line 390 of file modules.cpp.

-

00382 {
-00383         return add_channel(user,cname.c_str(),key.c_str(),false);
-00384 }
+
00391 {
+00392         return add_channel(user,cname.c_str(),key.c_str(),false);
+00393 }
 
@@ -2021,11 +2021,11 @@ Writes a log string.

This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.

-Definition at line 423 of file modules.cpp. +Definition at line 432 of file modules.cpp.

-

00424 {
-00425         log(level,"%s",s.c_str());
-00426 }
+
00433 {
+00434         log(level,"%s",s.c_str());
+00435 }
 
@@ -2068,14 +2068,14 @@ Matches text against a glob pattern.

Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.

-Definition at line 368 of file modules.cpp. +Definition at line 377 of file modules.cpp.

-

00369 {
-00370         char literal[MAXBUF],pattern[MAXBUF];
-00371         strlcpy(literal,sliteral.c_str(),MAXBUF);
-00372         strlcpy(pattern,spattern.c_str(),MAXBUF);
-00373         return match(literal,pattern);
-00374 }
+
00378 {
+00379         char literal[MAXBUF],pattern[MAXBUF];
+00380         strlcpy(literal,sliteral.c_str(),MAXBUF);
+00381         strlcpy(pattern,spattern.c_str(),MAXBUF);
+00382         return match(literal,pattern);
+00383 }
 
@@ -2118,15 +2118,15 @@ This function is used to check if any users on channel c are on server servernam

This is used internally by PRIVMSG etc. You should not need to use it.

-Definition at line 769 of file modules.cpp. +Definition at line 789 of file modules.cpp.

-

00770 {
-00771         if (c)
-00772         {
-00773                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
-00774         }
-00775         else return false;
-00776 }
+
00790 {
+00791         if (c)
+00792         {
+00793                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
+00794         }
+00795         else return false;
+00796 }
 
@@ -2169,15 +2169,15 @@ This function is used to check if user u has any channels in common with users o

This is used internally by Server::MeshSendCommon. You should very rarely need to use it.

-Definition at line 778 of file modules.cpp. +Definition at line 798 of file modules.cpp.

-

00779 {
-00780         if (u)
-00781         {
-00782                 return CommonOnThisServer(u,(char*)servername.c_str());
-00783         }
-00784         else return false;
-00785 }
+
00799 {
+00800         if (u)
+00801         {
+00802                 return CommonOnThisServer(u,(char*)servername.c_str());
+00803         }
+00804         else return false;
+00805 }
 
@@ -2211,11 +2211,11 @@ Sends a line of text to all connected servers.

If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.

-Definition at line 743 of file modules.cpp. +Definition at line 763 of file modules.cpp.

-

00744 {
-00745         NetSendToAll((char*)text.c_str());
-00746 }
+
00764 {
+00765         NetSendToAll((char*)text.c_str());
+00766 }
 
@@ -2249,11 +2249,11 @@ This function is equivalent to Server::MeshSendToAll except it will only route t

-Definition at line 754 of file modules.cpp. +Definition at line 774 of file modules.cpp.

-

00755 {
-00756         NetSendToAllAlive((char*)text.c_str());
-00757 }
+
00775 {
+00776         NetSendToAllAlive((char*)text.c_str());
+00777 }
 
@@ -2296,11 +2296,11 @@ This function sends to all servers EXCEPT the one you specify.

You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.

-Definition at line 764 of file modules.cpp. +Definition at line 784 of file modules.cpp.

-

00765 {
-00766         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
-00767 }
+
00785 {
+00786         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
+00787 }
 
@@ -2343,12 +2343,12 @@ This method sends a line of text to all servers who have users which share commo

For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)

-Definition at line 748 of file modules.cpp. +Definition at line 768 of file modules.cpp.

-

00749 {
-00750         if (user)
-00751                 NetSendToCommon(user,(char*)text.c_str());
-00752 }
+
00769 {
+00770         if (user)
+00771                 NetSendToCommon(user,(char*)text.c_str());
+00772 }
 
@@ -2391,11 +2391,11 @@ This function sends a line of text directly to a server.

If the server is not directly routable at this time, the server attempts to route text through the mesh.

-Definition at line 759 of file modules.cpp. +Definition at line 779 of file modules.cpp.

-

00760 {
-00761         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
-00762 }
+
00780 {
+00781         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
+00782 }
 
@@ -2444,11 +2444,11 @@ Forces a user to part a channel.

This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.

-Definition at line 386 of file modules.cpp. +Definition at line 395 of file modules.cpp.

-

00387 {
-00388         return del_channel(user,cname.c_str(),reason.c_str(),false);
-00389 }
+
00396 {
+00397         return del_channel(user,cname.c_str(),reason.c_str(),false);
+00398 }
 
@@ -2497,38 +2497,38 @@ This user takes one user, and switches their file descriptor with another user,

The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.

-Definition at line 629 of file modules.cpp. -

-References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. -

-

00630 {
-00631         zombie->fd = alive->fd;
-00632         alive->fd = FD_MAGIC_NUMBER;
-00633         alive->ClearBuffer();
-00634         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
-00635         kill_link(alive,message.c_str());
-00636         fd_ref_table[zombie->fd] = zombie;
-00637         for (int i = 0; i != MAXCHANS; i++)
-00638         {
-00639                 if (zombie->chans[i].channel != NULL)
-00640                 {
-00641                         if (zombie->chans[i].channel->name)
-00642                         {
-00643                                 chanrec* Ptr = zombie->chans[i].channel;
-00644                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
-00645                                 if (Ptr->topicset)
-00646                                 {
-00647                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
-00648                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
-00649                                 }
-00650                                 userlist(zombie,Ptr);
-00651                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
-00652 
-00653                         }
-00654                 }
-00655         }
-00656 
-00657 }
+Definition at line 649 of file modules.cpp.
+

+References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. +

+

00650 {
+00651         zombie->fd = alive->fd;
+00652         alive->fd = FD_MAGIC_NUMBER;
+00653         alive->ClearBuffer();
+00654         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
+00655         kill_link(alive,message.c_str());
+00656         fd_ref_table[zombie->fd] = zombie;
+00657         for (int i = 0; i != MAXCHANS; i++)
+00658         {
+00659                 if (zombie->chans[i].channel != NULL)
+00660                 {
+00661                         if (zombie->chans[i].channel->name)
+00662                         {
+00663                                 chanrec* Ptr = zombie->chans[i].channel;
+00664                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
+00665                                 if (Ptr->topicset)
+00666                                 {
+00667                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
+00668                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
+00669                                 }
+00670                                 userlist(zombie,Ptr);
+00671                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
+00672 
+00673                         }
+00674                 }
+00675         }
+00676 
+00677 }
 
@@ -2573,11 +2573,11 @@ To the user, it will appear as if they typed /QUIT themselves, except for the fa WARNING!

Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.

-Definition at line 408 of file modules.cpp. +Definition at line 417 of file modules.cpp.

-

00409 {
-00410         kill_link(user,reason.c_str());
-00411 }
+
00418 {
+00419         kill_link(user,reason.c_str());
+00420 }
 
@@ -2620,11 +2620,11 @@ Sends a line of text down a TCP/IP socket.

This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.

-Definition at line 438 of file modules.cpp. +Definition at line 447 of file modules.cpp.

-

00439 {
-00440         Write(Socket,"%s",s.c_str());
-00441 }
+
00448 {
+00449         Write(Socket,"%s",s.c_str());
+00450 }
 
@@ -2679,18 +2679,18 @@ Sends text from a user to a channel (mulicast).

This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).

-Definition at line 472 of file modules.cpp. -

-

00473 {
-00474         if (IncludeSender)
-00475         {
-00476                 WriteChannel(Channel,User,"%s",s.c_str());
-00477         }
-00478         else
-00479         {
-00480                 ChanExceptSender(Channel,User,"%s",s.c_str());
-00481         }
-00482 }
+Definition at line 481 of file modules.cpp.
+

+

00482 {
+00483         if (IncludeSender)
+00484         {
+00485                 WriteChannel(Channel,User,"%s",s.c_str());
+00486         }
+00487         else
+00488         {
+00489                 ChanExceptSender(Channel,User,"%s",s.c_str());
+00490         }
+00491 }
 
@@ -2739,11 +2739,11 @@ Writes text to a channel, but from a server, including all.

This can be used to send server notices to a group of users.

-Definition at line 467 of file modules.cpp. +Definition at line 476 of file modules.cpp.

-

00468 {
-00469         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
-00470 }
+
00477 {
+00478         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
+00479 }
 
@@ -2792,18 +2792,18 @@ Sends text from a user to one or more channels (mulicast).

This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.

-Definition at line 489 of file modules.cpp. -

-

00490 {
-00491         if (IncludeSender)
-00492         {
-00493                 WriteCommon(User,"%s",text.c_str());
-00494         }
-00495         else
-00496         {
-00497                 WriteCommonExcept(User,"%s",text.c_str());
-00498         }
-00499 }
+Definition at line 498 of file modules.cpp.
+

+

00499 {
+00500         if (IncludeSender)
+00501         {
+00502                 WriteCommon(User,"%s",text.c_str());
+00503         }
+00504         else
+00505         {
+00506                 WriteCommonExcept(User,"%s",text.c_str());
+00507         }
+00508 }
 
@@ -2852,11 +2852,11 @@ Sends text from a user to a socket.

This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)

-Definition at line 448 of file modules.cpp. +Definition at line 457 of file modules.cpp.

-

00449 {
-00450         WriteFrom(Socket,User,"%s",s.c_str());
-00451 }
+
00458 {
+00459         WriteFrom(Socket,User,"%s",s.c_str());
+00460 }
 
@@ -2912,13 +2912,13 @@ modes[2] = user->nick;

Srv->SendMode(modes,3,user);

The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!

-Definition at line 433 of file modules.cpp. +Definition at line 442 of file modules.cpp.

References server_mode().

-

00434 {
-00435         server_mode(parameters,pcnt,user);
-00436 }
+
00443 {
+00444         server_mode(parameters,pcnt,user);
+00445 }
 
@@ -2952,11 +2952,11 @@ Sends text to all opers.

This method sends a server notice to all opers with the usermode +s.

-Definition at line 363 of file modules.cpp. +Definition at line 372 of file modules.cpp.

-

00364 {
-00365         WriteOpers("%s",s.c_str());
-00366 }
+
00373 {
+00374         WriteOpers("%s",s.c_str());
+00375 }
 
@@ -2999,11 +2999,11 @@ Sends text from the server to a socket.

This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)

-Definition at line 443 of file modules.cpp. +Definition at line 452 of file modules.cpp.

-

00444 {
-00445         WriteServ(Socket,"%s",s.c_str());
-00446 }
+
00453 {
+00454         WriteServ(Socket,"%s",s.c_str());
+00455 }
 
@@ -3056,22 +3056,22 @@ The format will become:

:localserver TEXT

Which is useful for numerics and server notices to single users, etc.

-Definition at line 453 of file modules.cpp. -

-References connection::fd. -

-

00454 {
-00455         if (!Source)
-00456         {
-00457                 // if source is NULL, then the message originates from the local server
-00458                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
-00459         }
-00460         else
-00461         {
-00462                 // otherwise it comes from the user specified
-00463                 WriteTo(Source,Dest,"%s",s.c_str());
-00464         }
-00465 }
+Definition at line 462 of file modules.cpp.
+

+References connection::fd. +

+

00463 {
+00464         if (!Source)
+00465         {
+00466                 // if source is NULL, then the message originates from the local server
+00467                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
+00468         }
+00469         else
+00470         {
+00471                 // otherwise it comes from the user specified
+00472                 WriteTo(Source,Dest,"%s",s.c_str());
+00473         }
+00474 }
 
@@ -3122,11 +3122,11 @@ These can be RFC specified modes such as +i, or module provided modes, including Serv->SendToModeMask("xi", WM_OR, "m00");

Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.

-Definition at line 376 of file modules.cpp. +Definition at line 385 of file modules.cpp.

-

00377 {
-00378         WriteMode(modes.c_str(),flags,"%s",text.c_str());
-00379 }
+
00386 {
+00387         WriteMode(modes.c_str(),flags,"%s",text.c_str());
+00388 }
 
@@ -3169,11 +3169,11 @@ Sends a WALLOPS message.

This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.

-Definition at line 501 of file modules.cpp. +Definition at line 510 of file modules.cpp.

-

00502 {
-00503         WriteWallOps(User,false,"%s",text.c_str());
-00504 }
+
00511 {
+00512         WriteWallOps(User,false,"%s",text.c_str());
+00513 }
 
@@ -3216,33 +3216,44 @@ Remove a user's connection to the irc server, but leave their client in existenc

When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.

-Definition at line 610 of file modules.cpp. -

-References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. -

-

00611 {
-00612         unsigned int old_fd = user->fd;
-00613         user->fd = FD_MAGIC_NUMBER;
-00614         user->ClearBuffer();
-00615         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
-00616 #ifdef USE_KQUEUE
-00617         struct kevent ke;
-00618         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
-00619         int i = kevent(kq, &ke, 1, 0, 0, NULL);
-00620         if (i == -1)
-00621         {
-00622                 log(DEBUG,"kqueue: Failed to remove user from queue!");
-00623         }
-00624 #endif
-00625         shutdown(old_fd,2);
-00626         close(old_fd);
-00627 }
+Definition at line 619 of file modules.cpp.
+

+References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. +

+

00620 {
+00621         unsigned int old_fd = user->fd;
+00622         user->fd = FD_MAGIC_NUMBER;
+00623         user->ClearBuffer();
+00624         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
+00625 #ifdef USE_KQUEUE
+00626         struct kevent ke;
+00627         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
+00628         int i = kevent(kq, &ke, 1, 0, 0, NULL);
+00629         if (i == -1)
+00630         {
+00631                 log(DEBUG,"kqueue: Failed to remove user from queue!");
+00632         }
+00633 #endif
+00634 #ifdef USE_EPOLL
+00635         struct epoll_event ev;
+00636         ev.events = EPOLLIN | EPOLLET;
+00637         ev.data.fd = old_fd;
+00638         int i = epoll_ctl(ep, EPOLL_CTL_DEL, old_fd, &ev);
+00639         if (i < 0)
+00640         {
+00641                 log(DEBUG,"epoll: List deletion failure!");
+00642         }
+00643 #endif
+00644 
+00645         shutdown(old_fd,2);
+00646         close(old_fd);
+00647 }
 

The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:38:58 2005 for InspIRCd by +
Generated on Tue May 24 02:32:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classVersion-members.html b/docs/module-doc/classVersion-members.html index 6ca5da31c..5aa753749 100644 --- a/docs/module-doc/classVersion-members.html +++ b/docs/module-doc/classVersion-members.html @@ -15,7 +15,7 @@ RevisionVersion Version(int major, int minor, int revision, int build, int flags)Version ~classbase()classbase [inline] -
Generated on Sun May 15 18:39:16 2005 for InspIRCd by +
Generated on Tue May 24 02:32:49 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classVersion.html b/docs/module-doc/classVersion.html index b6c2ed2fa..74697af5a 100644 --- a/docs/module-doc/classVersion.html +++ b/docs/module-doc/classVersion.html @@ -98,9 +98,9 @@ Definition at line 111 of

-Definition at line 234 of file modules.cpp. +Definition at line 243 of file modules.cpp.

-

00234 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
+
00243 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
 
@@ -227,7 +227,7 @@ Definition at line 114 of
The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:39:16 2005 for InspIRCd by +
Generated on Tue May 24 02:32:49 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classWhoWasUser-members.html b/docs/module-doc/classWhoWasUser-members.html index 68847814a..448545914 100644 --- a/docs/module-doc/classWhoWasUser-members.html +++ b/docs/module-doc/classWhoWasUser-members.html @@ -13,7 +13,7 @@ nickWhoWasUser serverWhoWasUser signonWhoWasUser -
Generated on Sun May 15 18:39:18 2005 for InspIRCd by +
Generated on Tue May 24 02:32:50 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classWhoWasUser.html b/docs/module-doc/classWhoWasUser.html index b066f53f6..c36b0662c 100644 --- a/docs/module-doc/classWhoWasUser.html +++ b/docs/module-doc/classWhoWasUser.html @@ -34,7 +34,7 @@ A lightweight userrec used by WHOWAS.

-Definition at line 318 of file users.h.


Member Data Documentation

+Definition at line 326 of file users.h.

Member Data Documentation

@@ -56,7 +56,7 @@ Definition at line 318 of f

-Definition at line 323 of file users.h. +Definition at line 331 of file users.h.

@@ -80,7 +80,7 @@ Definition at line 323 of f

-Definition at line 325 of file users.h. +Definition at line 333 of file users.h.

@@ -104,7 +104,7 @@ Definition at line 325 of f

-Definition at line 324 of file users.h. +Definition at line 332 of file users.h.

@@ -128,7 +128,7 @@ Definition at line 324 of f

-Definition at line 322 of file users.h. +Definition at line 330 of file users.h.

@@ -152,7 +152,7 @@ Definition at line 322 of f

-Definition at line 321 of file users.h. +Definition at line 329 of file users.h.

@@ -176,7 +176,7 @@ Definition at line 321 of f

-Definition at line 326 of file users.h. +Definition at line 334 of file users.h.

@@ -200,12 +200,12 @@ Definition at line 326 of f

-Definition at line 327 of file users.h. +Definition at line 335 of file users.h.


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:39:18 2005 for InspIRCd by +
Generated on Tue May 24 02:32:50 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classXLine-members.html b/docs/module-doc/classXLine-members.html index d3f34edf4..ef40a92bc 100644 --- a/docs/module-doc/classXLine-members.html +++ b/docs/module-doc/classXLine-members.html @@ -14,7 +14,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:39:22 2005 for InspIRCd by +
Generated on Tue May 24 02:32:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classXLine.html b/docs/module-doc/classXLine.html index 785ab3e8a..164493759 100644 --- a/docs/module-doc/classXLine.html +++ b/docs/module-doc/classXLine.html @@ -180,7 +180,7 @@ Definition at line 48 of fi
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:39:22 2005 for InspIRCd by +
Generated on Tue May 24 02:32:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classZLine-members.html b/docs/module-doc/classZLine-members.html index 3ed821cb8..383065ee5 100644 --- a/docs/module-doc/classZLine-members.html +++ b/docs/module-doc/classZLine-members.html @@ -16,7 +16,7 @@ set_timeXLine sourceXLine ~classbase()classbase [inline] -
Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classZLine.html b/docs/module-doc/classZLine.html index 800235db2..b407cf4c6 100644 --- a/docs/module-doc/classZLine.html +++ b/docs/module-doc/classZLine.html @@ -90,7 +90,7 @@ Definition at line 103 of f
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classchanrec-members.html b/docs/module-doc/classchanrec-members.html index 1a5291bdc..35411d7df 100644 --- a/docs/module-doc/classchanrec-members.html +++ b/docs/module-doc/classchanrec-members.html @@ -33,7 +33,7 @@ topicsetchanrec ~chanrec()chanrec [inline, virtual] ~classbase()classbase [inline] -
Generated on Sun May 15 18:37:45 2005 for InspIRCd by +
Generated on Tue May 24 02:31:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classchanrec.html b/docs/module-doc/classchanrec.html index d40fedbde..e44480b41 100644 --- a/docs/module-doc/classchanrec.html +++ b/docs/module-doc/classchanrec.html @@ -124,20 +124,20 @@ Creates a channel record and initialises it with default values.

-Definition at line 108 of file channels.cpp. +Definition at line 107 of file channels.cpp.

References binarymodes, created, custom_modes, internal_userlist, key, limit, name, setby, topic, and topicset.

-

00109 {
-00110         strcpy(name,"");
-00111         strcpy(custom_modes,"");
-00112         strcpy(topic,"");
-00113         strcpy(setby,"");
-00114         strcpy(key,"");
-00115         created = topicset = limit = 0;
-00116         binarymodes = 0;
-00117         internal_userlist.clear();
-00118 }
+
00108 {
+00109         strcpy(name,"");
+00110         strcpy(custom_modes,"");
+00111         strcpy(topic,"");
+00112         strcpy(setby,"");
+00113         strcpy(key,"");
+00114         created = topicset = limit = 0;
+00115         binarymodes = 0;
+00116         internal_userlist.clear();
+00117 }
 
@@ -205,14 +205,14 @@ Add a user pointer to the internal reference list The data inserted into the ref

-Definition at line 202 of file channels.cpp. +Definition at line 201 of file channels.cpp.

References DEBUG, and internal_userlist.

-

00203 {
-00204         internal_userlist.push_back(castuser);
-00205         log(DEBUG,"Added casted user to channel's internal list");
-00206 }
+
00202 {
+00203         internal_userlist.push_back(castuser);
+00204         log(DEBUG,"Added casted user to channel's internal list");
+00205 }
 
@@ -246,22 +246,22 @@ Delete a user pointer to the internal reference list The data removed from the r

-Definition at line 208 of file channels.cpp. +Definition at line 207 of file channels.cpp.

References DEBUG, internal_userlist, and name.

-

00209 {
-00210         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
-00211         {
-00212                 if (*a == castuser)
-00213                 {
-00214                         log(DEBUG,"Removed casted user from channel's internal list");
-00215                         internal_userlist.erase(a);
-00216                         return;
-00217                 }
-00218         }
-00219         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
-00220 }
+
00208 {
+00209         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
+00210         {
+00211                 if (*a == castuser)
+00212                 {
+00213                         log(DEBUG,"Removed casted user from channel's internal list");
+00214                         internal_userlist.erase(a);
+00215                         return;
+00216                 }
+00217         }
+00218         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
+00219 }
 
@@ -295,23 +295,23 @@ Returns the parameter for a custom mode on a channel.

For example if "+L #foo" is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.

-Definition at line 182 of file channels.cpp. -

-References custom_mode_params. -

-

00183 {
-00184         if (custom_mode_params.size())
-00185         {
-00186                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00187                 {
-00188                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00189                         {
-00190                                 return i->parameter;
-00191                         }
-00192                 }
-00193         }
-00194         return "";
-00195 }
+Definition at line 181 of file channels.cpp.
+

+References custom_mode_params. +

+

00182 {
+00183         if (custom_mode_params.size())
+00184         {
+00185                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00186                 {
+00187                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00188                         {
+00189                                 return i->parameter;
+00190                         }
+00191                 }
+00192         }
+00193         return "";
+00194 }
 
@@ -344,13 +344,13 @@ Obtain the channel "user counter" This returns the channel reference counter, wh

-Definition at line 197 of file channels.cpp. +Definition at line 196 of file channels.cpp.

References internal_userlist.

-

00198 {
-00199         return (this->internal_userlist.size());
-00200 }
+
00197 {
+00198         return (this->internal_userlist.size());
+00199 }
 
@@ -383,15 +383,15 @@ Obrain the internal reference list The internal reference list contains a list o

These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.

-Definition at line 222 of file channels.cpp. +Definition at line 221 of file channels.cpp.

References internal_userlist.

-Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

-

00223 {
-00224         return &internal_userlist;
-00225 }
+
00222 {
+00223         return &internal_userlist;
+00224 }
 
@@ -425,14 +425,14 @@ Returns true if a custom mode is set on a channel.

-Definition at line 176 of file channels.cpp. +Definition at line 175 of file channels.cpp.

References DEBUG.

-

00177 {
-00178         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
-00179         return (strchr(this->custom_modes,mode) != 0);
-00180 }
+
00176 {
+00177         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
+00178         return (strchr(this->custom_modes,mode) != 0);
+00179 }
 
@@ -475,32 +475,32 @@ Sets or unsets a custom mode in the channels info.

-Definition at line 120 of file channels.cpp. -

-References custom_modes, DEBUG, and SetCustomModeParam(). -

-

00121 {
-00122         if (mode_on) {
-00123                 static char m[3];
-00124                 m[0] = mode;
-00125                 m[1] = '\0';
-00126                 if (!strchr(this->custom_modes,mode))
-00127                 {
-00128                         strlcat(custom_modes,m,MAXMODES);
-00129                 }
-00130                 log(DEBUG,"Custom mode %c set",mode);
-00131         }
-00132         else {
-00133 
-00134                 std::string a = this->custom_modes;
-00135                 int pos = a.find(mode);
-00136                 a.erase(pos,1);
-00137                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
-00138 
-00139                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
-00140                 this->SetCustomModeParam(mode,"",false);
-00141         }
-00142 }
+Definition at line 119 of file channels.cpp.
+

+References custom_modes, DEBUG, and SetCustomModeParam(). +

+

00120 {
+00121         if (mode_on) {
+00122                 static char m[3];
+00123                 m[0] = mode;
+00124                 m[1] = '\0';
+00125                 if (!strchr(this->custom_modes,mode))
+00126                 {
+00127                         strlcat(custom_modes,m,MAXMODES);
+00128                 }
+00129                 log(DEBUG,"Custom mode %c set",mode);
+00130         }
+00131         else {
+00132 
+00133                 std::string a = this->custom_modes;
+00134                 int pos = a.find(mode);
+00135                 a.erase(pos,1);
+00136                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
+00137 
+00138                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
+00139                 this->SetCustomModeParam(mode,"",false);
+00140         }
+00141 }
 
@@ -549,41 +549,41 @@ Sets or unsets the parameters for a custom mode in a channels info.

-Definition at line 145 of file channels.cpp. -

-References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter. -

-Referenced by SetCustomMode(). -

-

00146 {
-00147 
-00148         log(DEBUG,"SetCustomModeParam called");
-00149         ModeParameter M;
-00150         M.mode = mode;
-00151         strlcpy(M.channel,this->name,CHANMAX);
-00152         strlcpy(M.parameter,parameter,MAXBUF);
-00153         if (mode_on)
-00154         {
-00155                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
-00156                 custom_mode_params.push_back(M);
-00157         }
-00158         else
-00159         {
-00160                 if (custom_mode_params.size())
-00161                 {
-00162                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00163                         {
-00164                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00165                                 {
-00166                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
-00167                                         custom_mode_params.erase(i);
-00168                                         return;
-00169                                 }
-00170                         }
-00171                 }
-00172                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
-00173         }
-00174 }
+Definition at line 144 of file channels.cpp.
+

+References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter. +

+Referenced by SetCustomMode(). +

+

00145 {
+00146 
+00147         log(DEBUG,"SetCustomModeParam called");
+00148         ModeParameter M;
+00149         M.mode = mode;
+00150         strlcpy(M.channel,this->name,CHANMAX);
+00151         strlcpy(M.parameter,parameter,MAXBUF);
+00152         if (mode_on)
+00153         {
+00154                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
+00155                 custom_mode_params.push_back(M);
+00156         }
+00157         else
+00158         {
+00159                 if (custom_mode_params.size())
+00160                 {
+00161                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00162                         {
+00163                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00164                                 {
+00165                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
+00166                                         custom_mode_params.erase(i);
+00167                                         return;
+00168                                 }
+00169                         }
+00170                 }
+00171                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
+00172         }
+00173 }
 
@@ -639,7 +639,7 @@ Contains a bitmask of the CM_* builtin (RFC) binary mode symbols.

Definition at line 145 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -667,7 +667,7 @@ Creation time.

Definition at line 123 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -695,7 +695,7 @@ Plugins may use this field in any way they see fit.

Definition at line 110 of file channels.h.

-Referenced by chanrec(), and SetCustomMode(). +Referenced by chanrec(), and SetCustomMode().

@@ -723,7 +723,7 @@ User list (casted to char*'s to stop forward declaration stuff) (chicken and egg

Definition at line 115 of file channels.h.

-Referenced by AddUser(), chanrec(), DelUser(), GetUserCounter(), and GetUsers(). +Referenced by AddUser(), chanrec(), DelUser(), GetUserCounter(), and GetUsers().

@@ -751,7 +751,7 @@ If this value is an empty string, there is no channel key in place.

Definition at line 141 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -779,7 +779,7 @@ If this value is zero, there is no limit in place.

Definition at line 136 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -807,7 +807,7 @@ The channels name.

Definition at line 106 of file channels.h.

-Referenced by chanrec(), DelUser(), and Server::PseudoToUser(). +Referenced by chanrec(), DelUser(), and Server::PseudoToUser().

@@ -835,7 +835,7 @@ If this member is an empty string, no topic was ever set.

Definition at line 131 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().

@@ -863,7 +863,7 @@ If this is an empty string, no channel topic is set.

Definition at line 120 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().

@@ -891,12 +891,12 @@ If no topic was ever set, this will be equal to 127 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:37:45 2005 for InspIRCd by +
Generated on Tue May 24 02:31:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classclassbase-members.html b/docs/module-doc/classclassbase-members.html index fe23c4ec7..526b1989c 100644 --- a/docs/module-doc/classclassbase-members.html +++ b/docs/module-doc/classclassbase-members.html @@ -9,7 +9,7 @@ ageclassbase classbase()classbase [inline] ~classbase()classbase [inline] -
Generated on Sun May 15 18:37:49 2005 for InspIRCd by +
Generated on Tue May 24 02:31:38 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classclassbase.html b/docs/module-doc/classclassbase.html index 53f725456..c4a92ad4e 100644 --- a/docs/module-doc/classclassbase.html +++ b/docs/module-doc/classclassbase.html @@ -150,7 +150,7 @@ Referenced by classbase().
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:37:49 2005 for InspIRCd by +
Generated on Tue May 24 02:31:38 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classcommand__t-members.html b/docs/module-doc/classcommand__t-members.html index ccf7d2322..a17af276c 100644 --- a/docs/module-doc/classcommand__t-members.html +++ b/docs/module-doc/classcommand__t-members.html @@ -19,7 +19,7 @@ total_bytescommand_t use_countcommand_t ~classbase()classbase [inline] -
Generated on Sun May 15 18:37:52 2005 for InspIRCd by +
Generated on Tue May 24 02:31:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classcommand__t.html b/docs/module-doc/classcommand__t.html index a6bf42dae..31be9ae77 100644 --- a/docs/module-doc/classcommand__t.html +++ b/docs/module-doc/classcommand__t.html @@ -235,7 +235,7 @@ Definition at line 43 of
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:37:52 2005 for InspIRCd by +
Generated on Tue May 24 02:31:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classconnection-members.html b/docs/module-doc/classconnection-members.html index c798fcedf..da1039151 100644 --- a/docs/module-doc/classconnection-members.html +++ b/docs/module-doc/classconnection-members.html @@ -6,37 +6,28 @@

connection Member List

This is the complete list of members for connection, including all inherited members. - - - - - - - - - -
AddIncoming(int fd, char *targethost, int sourceport)connection
ageclassbase
BeginLink(char *targethost, int port, char *password, char *servername, int myport)connection
bytes_inconnection
bytes_outconnection
classbase()classbase [inline]
cmds_inconnection
cmds_outconnection
connection()connection
connectorsconnection
CreateListener(char *host, int p)connection
Extend(std::string key, char *p)Extensible
fdconnection
FindHost(std::string host)connection
GetExt(std::string key)Extensible
haspassedconnection
hostconnection
idle_lastmsgconnection
ipconnection
lastpingconnection
MeshCookie(char *targethost, int port, unsigned long cookie, char *servername)connection
npingconnection
portconnection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
registeredconnection
SendPacket(char *message, const char *host)connection
Shrink(std::string key)Extensible
signonconnection
TerminateLink(char *targethost)connection
~classbase()classbase [inline]

Generated on Sun May 15 18:38:01 2005 for InspIRCd by +
Generated on Tue May 24 02:31:49 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classconnection.html b/docs/module-doc/classconnection.html index b1e868b27..59d9ff2dd 100644 --- a/docs/module-doc/classconnection.html +++ b/docs/module-doc/classconnection.html @@ -19,7 +19,8 @@ Inheritance diagram for connection:

[legend]
Collaboration diagram for connection:

Collaboration graph
- + +
[legend]
List of all members. @@ -27,30 +28,6 @@ Inheritance diagram for connection:

 
- - - - - - - - - - - - - - - - - - - - - - - - @@ -61,16 +38,16 @@ Inheritance diagram for connection:

char 
- + - + - + - + @@ -94,16 +71,13 @@ Inheritance diagram for connection:

time_t 
- - -
connection ()
 Default constructor.

bool CreateListener (char *host, int p)
 Create a listening socket on 'host' using port number 'p'.

bool BeginLink (char *targethost, int port, char *password, char *servername, int myport)
 Begin an outbound link to another ircd at targethost.

bool MeshCookie (char *targethost, int port, unsigned long cookie, char *servername)
 Begin an outbound mesh link to another ircd on a network you are already an authenticated member of.

void TerminateLink (char *targethost)
 Terminate a link to 'targethost' by calling the ircd_connector::CloseConnection method.

bool SendPacket (char *message, const char *host)
 Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false.

bool RecvPacket (std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)
 Returns the next available packet and returns true if data is available.

ircd_connectorFindHost (std::string host)
 Find the ircd_connector oject related to a certain servername given in 'host'.

bool AddIncoming (int fd, char *targethost, int sourceport)
 Add an incoming connection to the connection pool.


Public Attributes

int fd
ip [16]
 IP of connection.

long bytes_in
int bytes_in
 Stats counter for bytes inbound.

long bytes_out
int bytes_out
 Stats counter for bytes outbound.

long cmds_in
int cmds_in
 Stats counter for commands inbound.

long cmds_out
int cmds_out
 Stats counter for commands outbound.

bool haspassed
nping
 Used by PING checks with clients.

std::vector< ircd_connectorconnectors
 With a serverrec, this is a list of all established server connections.


Detailed Description

Please note: classes serverrec and userrec both inherit from class connection.

-Definition at line 212 of file connection.h.


Constructor & Destructor Documentation

+Definition at line 261 of file connection.h.

Constructor & Destructor Documentation

@@ -134,351 +108,6 @@ Default constructor.
-


Member Function Documentation

-

- - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - -
bool connection::AddIncoming int  fd,
char *  targethost,
int  sourceport
-
- - - - - -
-   - - -

-Add an incoming connection to the connection pool. -

-(reserved for core use)

-

- - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool connection::BeginLink char *  targethost,
int  port,
char *  password,
char *  servername,
int  myport
-
- - - - - -
-   - - -

-Begin an outbound link to another ircd at targethost. -

-

-

- - - - -
- - - - - - - - - - - - - - - - - - - -
bool connection::CreateListener char *  host,
int  p
-
- - - - - -
-   - - -

-Create a listening socket on 'host' using port number 'p'. -

-

-

- - - - -
- - - - - - - - - - -
ircd_connector* connection::FindHost std::string  host  ) 
-
- - - - - -
-   - - -

-Find the ircd_connector oject related to a certain servername given in 'host'. -

-

-

- - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool connection::MeshCookie char *  targethost,
int  port,
unsigned long  cookie,
char *  servername
-
- - - - - -
-   - - -

-Begin an outbound mesh link to another ircd on a network you are already an authenticated member of. -

-

-

- - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - -
bool connection::RecvPacket std::deque< std::string > &  messages,
char *  host,
std::deque< std::string > &  sums
-
- - - - - -
-   - - -

-Returns the next available packet and returns true if data is available. -

-Writes the servername the data came from to 'host'. If no data is available this function returns false. This function will automatically close broken links and reroute pathways, generating split messages on the network.

-

- - - - -
- - - - - - - - - - - - - - - - - - - -
bool connection::SendPacket char *  message,
const char *  host
-
- - - - - -
-   - - -

-Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. -

-

-

- - - - -
- - - - - - - - - - -
void connection::TerminateLink char *  targethost  ) 
-
- - - - - -
-   - - -

-Terminate a link to 'targethost' by calling the ircd_connector::CloseConnection method. -

-


Member Data Documentation

@@ -486,7 +115,7 @@ Terminate a link to 'targethost' by calling the
-
long connection::bytes_in + int connection::bytes_in
@@ -503,9 +132,9 @@ Stats counter for bytes inbound.

-Definition at line 229 of file connection.h. +Definition at line 278 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -514,7 +143,7 @@ Referenced by userrec::userre -
long connection::bytes_out + int connection::bytes_out
@@ -531,9 +160,9 @@ Stats counter for bytes outbound.

-Definition at line 233 of file connection.h. +Definition at line 282 of file connection.h.

-Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). +Referenced by userrec::FlushWriteBuf(), and userrec::userrec().

@@ -542,7 +171,7 @@ Referenced by userrec::FlushW -
long connection::cmds_in + int connection::cmds_in
@@ -559,9 +188,9 @@ Stats counter for commands inbound.

-Definition at line 237 of file connection.h. +Definition at line 286 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -570,7 +199,7 @@ Referenced by userrec::userre -
long connection::cmds_out + int connection::cmds_out
@@ -587,35 +216,9 @@ Stats counter for commands outbound.

-Definition at line 241 of file connection.h. -

-Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). - - -

- - - - -
- - -
std::vector<ircd_connector> connection::connectors -
-
- - - - +Referenced by userrec::FlushWriteBuf(), and userrec::userrec().
-   - - -

-With a serverrec, this is a list of all established server connections. -

-With a userrec this is unused. +Definition at line 290 of file connection.h.

-Definition at line 276 of file connection.h.

@@ -641,9 +244,9 @@ File descriptor of the connection.

-Definition at line 217 of file connection.h. +Definition at line 266 of file connection.h.

-Referenced by ConfigReader::DumpErrors(), Server::PseudoToUser(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo(). +Referenced by serverrec::BeginLink(), serverrec::CreateListener(), ConfigReader::DumpErrors(), serverrec::MeshCookie(), Server::PseudoToUser(), userrec::ReadData(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo().

@@ -669,9 +272,9 @@ True if server/user has authenticated, false if otherwise.

-Definition at line 245 of file connection.h. +Definition at line 294 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -697,9 +300,9 @@ Hostname of connection.

Not used if this is a serverrec

-Definition at line 221 of file connection.h. +Definition at line 270 of file connection.h.

-Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo(). +Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo().

@@ -725,9 +328,9 @@ Time that the connection last sent data, used to calculate idle time.

-Definition at line 267 of file connection.h. +Definition at line 316 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -753,9 +356,9 @@ IP of connection.

-Definition at line 225 of file connection.h. +Definition at line 274 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -781,9 +384,9 @@ Time the connection was last pinged.

-Definition at line 259 of file connection.h. +Definition at line 308 of file connection.h.

-Referenced by serverrec::serverrec(), and userrec::userrec(). +Referenced by serverrec::serverrec(), and userrec::userrec().

@@ -809,9 +412,9 @@ Used by PING checks with clients.

-Definition at line 271 of file connection.h. +Definition at line 320 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -837,9 +440,9 @@ Port number For a userrec, this is the port they connected to the network on.

For a serverrec this is the current listening port of the serverrec object.

-Definition at line 251 of file connection.h. +Definition at line 300 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by serverrec::CreateListener(), and userrec::userrec().

@@ -865,9 +468,9 @@ Used by userrec to indicate the registration status of the connection.

-Definition at line 255 of file connection.h. +Definition at line 304 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -893,14 +496,14 @@ Time the connection was created, set in the constructor.

-Definition at line 263 of file connection.h. +Definition at line 312 of file connection.h.

-Referenced by serverrec::serverrec(), and userrec::userrec(). +Referenced by serverrec::serverrec(), and userrec::userrec().


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:01 2005 for InspIRCd by +
Generated on Tue May 24 02:31:49 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classconnection__coll__graph.gif b/docs/module-doc/classconnection__coll__graph.gif index 796ec9c6d..12d07f356 100644 Binary files a/docs/module-doc/classconnection__coll__graph.gif and b/docs/module-doc/classconnection__coll__graph.gif differ diff --git a/docs/module-doc/classes.html b/docs/module-doc/classes.html index e9f3df77d..4660246ac 100644 --- a/docs/module-doc/classes.html +++ b/docs/module-doc/classes.html @@ -26,7 +26,7 @@ ModeParameter   Server   
  Z  
connection   GLine   Module   serverrec   ZLine   
  D  
  H  
-
Generated on Sun May 15 18:37:36 2005 for InspIRCd by +
Generated on Tue May 24 02:31:27 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classircd__connector-members.html b/docs/module-doc/classircd__connector-members.html index 90c099212..f11fa4e85 100644 --- a/docs/module-doc/classircd__connector-members.html +++ b/docs/module-doc/classircd__connector-members.html @@ -6,44 +6,56 @@

ircd_connector Member List

This is the complete list of members for ircd_connector, including all inherited members. - + + - + + - - + + - - - + + + + - - - - - + + + + + + + + - + + + + + - - + + - - - - - + + + + + + + -
AddBuffer(std::string a)ircd_connector
AddBuffer(std::string a)ircd_connector
addrircd_connector [private]
AddWriteBuf(std::string data)ircd_connector
ageclassbase
BufferIsComplete()ircd_connector
BufferIsComplete()ircd_connector
CheckPing()ircd_connector
classbase()classbase [inline]
ClearBuffer()ircd_connector
CloseConnection()ircd_connector
ClearBuffer()ircd_connector
CloseConnection()ircd_connector
descriptionircd_connector [private]
Extend(std::string key, char *p)Extensible
fdircd_connector [private]
GetBuffer()ircd_connector
GetDescription()ircd_connector
GetDescriptor()ircd_connector
FlushWriteBuf()ircd_connector
GetBuffer()ircd_connector
GetDescription()ircd_connector
GetDescriptor()ircd_connector
GetExt(std::string key)Extensible
GetServerIP()ircd_connector
GetServerName()ircd_connector
GetServerPort()ircd_connector
GetState()ircd_connector
GetVersionString()ircd_connector
GetServerIP()ircd_connector
GetServerName()ircd_connector
GetServerPort()ircd_connector
GetState()ircd_connector
GetVersionString()ircd_connector
GetWriteError()ircd_connector
HasBufferedOutput()ircd_connector
hostircd_connector
ircd_connector()ircd_connector
ircdbufferircd_connector
MakeOutboundConnection(char *newhost, int newport)ircd_connector
MakeOutboundConnection(char *newhost, int newport)ircd_connector
nextpingircd_connector [private]
portircd_connector
repliedircd_connector [private]
ResetPing()ircd_connector
routesircd_connector
sendqircd_connector [private]
servernameircd_connector [private]
SetDescription(std::string desc)ircd_connector
SetDescriptor(int fd)ircd_connector
SetDescription(std::string desc)ircd_connector
SetDescriptor(int fd)ircd_connector
SetHostAddress(char *host, int port)ircd_connector [private]
SetHostAndPort(char *newhost, int newport)ircd_connector
SetServerName(std::string serv)ircd_connector
SetServerPort(int p)ircd_connector
SetState(int state)ircd_connector
SetVersionString(std::string newversion)ircd_connector
SetHostAndPort(char *newhost, int newport)ircd_connector
SetServerName(std::string serv)ircd_connector
SetServerPort(int p)ircd_connector
SetState(int state)ircd_connector
SetVersionString(std::string newversion)ircd_connector
SetWriteError(std::string error)ircd_connector
Shrink(std::string key)Extensible
stateircd_connector [private]
versionircd_connector [private]
WriteErrorircd_connector [private]
~classbase()classbase [inline]

Generated on Sun May 15 18:38:31 2005 for InspIRCd by +
Generated on Tue May 24 02:32:15 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classircd__connector.html b/docs/module-doc/classircd__connector.html index 95a1f09bc..052631803 100644 --- a/docs/module-doc/classircd__connector.html +++ b/docs/module-doc/classircd__connector.html @@ -17,71 +17,95 @@ Inheritance diagram for ircd_connector:

[legend]
Collaboration diagram for ircd_connector:

Collaboration graph
- +
[legend]
List of all members. - + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - + + + + + + + + + + + + + + + + + + + + + + + + + @@ -119,6 +143,18 @@ Inheritance diagram for ircd_connector:

std::string 
+ + + + + + + + + + + +

Public Member Functions

bool MakeOutboundConnection (char *newhost, int newport)
 ircd_connector ()
 Create an outbound connection to a listening socket.

std::string GetServerName ()
 Constructor clears the sendq and initialises the fd to -1.

bool MakeOutboundConnection (char *newhost, int newport)
 Return the servername on this established connection.

void SetServerName (std::string serv)
 Create an outbound connection to a listening socket.

std::string GetServerName ()
 Set the server name of this connection.

int GetDescriptor ()
 Return the servername on this established connection.

void SetServerName (std::string serv)
 Get the file descriptor associated with this connection.

void SetDescriptor (int fd)
 Set the server name of this connection.

int GetDescriptor ()
 Set the file descriptor for this connection.

int GetState ()
 Get the file descriptor associated with this connection.

void SetDescriptor (int fd)
 Get the state flags for this connection.

void SetState (int state)
 Set the file descriptor for this connection.

int GetState ()
 Set the state flags for this connection.

char * GetServerIP ()
 Get the state flags for this connection.

void SetState (int state)
 Get the ip address (not servername) associated with this connection.

std::string GetDescription ()
 Set the state flags for this connection.

char * GetServerIP ()
 Get the server description of this connection.

void SetDescription (std::string desc)
 Get the ip address (not servername) associated with this connection.

std::string GetDescription ()
 Set the server description of this connection.

int GetServerPort ()
 Get the server description of this connection.

void SetDescription (std::string desc)
 Get the port number being used for this connection If the connection is outbound this will be the remote port otherwise it will be the local port, so it can always be gautanteed as open at the address given in GetServerIP().

void SetServerPort (int p)
 Set the server description of this connection.

int GetServerPort ()
 Set the port used by this connection.

bool SetHostAndPort (char *newhost, int newport)
 Get the port number being used for this connection If the connection is outbound this will be the remote port otherwise it will be the local port, so it can always be gautanteed as open at the address given in GetServerIP().

void SetServerPort (int p)
 Set both the host and the port in one operation for this connection.

void CloseConnection ()
 Set the port used by this connection.

bool SetHostAndPort (char *newhost, int newport)
 Close the connection by calling close() on its file descriptor This function call updates no other data.

void AddBuffer (std::string a)
 Set both the host and the port in one operation for this connection.

void CloseConnection ()
 This method adds text to the ircd connection's buffer There is no limitation on how much text of what line width may be added to this buffer.

bool BufferIsComplete ()
 Close the connection by calling close() on its file descriptor This function call updates no other data.

bool AddBuffer (std::string a)
 This method returns true if the buffer contains at least one carriage return character, e.g.

void ClearBuffer ()
 This method adds text to the ircd connection's buffer This buffer's maximum size is one megabyte, the method returning false if the buffer is full.

bool BufferIsComplete ()
 This method clears the server's buffer by setting it to an empty string.

std::string GetBuffer ()
 This method returns true if the buffer contains at least one carriage return character, e.g.

void ClearBuffer ()
 This method retrieves the first string from the tail end of the buffer and advances the tail end of the buffer past the returned string, in a similar manner to strtok().

void SetVersionString (std::string newversion)
 This method clears the server's buffer by setting it to an empty string.

std::string GetBuffer ()
 This method sets the version string of the remote server.

std::string GetVersionString ()
 This method retrieves the first string from the tail end of the buffer and advances the tail end of the buffer past the returned string, in a similar manner to strtok().

void SetVersionString (std::string newversion)
 This method returns the version string of the remote server.

 This method sets the version string of the remote server.

std::string GetVersionString ()
 This method returns the version string of the remote server.

bool AddWriteBuf (std::string data)
 Adds data to the connection's sendQ to be flushed later Fails if there is an error pending on the connection.

bool FlushWriteBuf ()
 Flushes as much of the data from the buffer as possible, and advances the queue pointer to what is left.

void SetWriteError (std::string error)
 Sets the error string for this connection.

std::string GetWriteError ()
 Gets the error string for this connection.

bool HasBufferedOutput ()
 Returns true if there is data to be written that hasn't been sent yet.

bool CheckPing ()
 Checks if the connection replied to its last ping, and if it did sends another and returns true, if not, returns false.

void ResetPing ()
 Resets the ping counter.


Public Attributes

std::string ircdbuffer
version
 This string holds the ircd's version response.

std::string sendq
 SendQ of the outbound connector, does not have a limit.

std::string WriteError
 Write error of connection.

time_t nextping
 Time this connection was last pinged.

bool replied
 Did this connection reply to its last ping?


Detailed Description

Each connection has one or more of these each represents ONE outbound connection to another ircd so each inbound has multiple outbounds. @@ -127,14 +163,45 @@ A listening socket that accepts server type connections is represented by one cl

-Definition at line 56 of file connection.h.


Member Function Documentation

-

+Definition at line 56 of file connection.h.


Constructor & Destructor Documentation

+

+ +
- + + + + + + + +
void ircd_connector::AddBuffer ircd_connector::ircd_connector  ) 
+
+ + + + + +
+   + + +

+Constructor clears the sendq and initialises the fd to -1. +

+

+


Member Function Documentation

+

+ + +
+ + + @@ -154,12 +221,45 @@ Definition at line 56 + +
bool ircd_connector::AddBuffer std::string  a

-This method adds text to the ircd connection's buffer There is no limitation on how much text of what line width may be added to this buffer. +This method adds text to the ircd connection's buffer This buffer's maximum size is one megabyte, the method returning false if the buffer is full. +

+

+

+ + + + +
+ + + + + + + + + + +
bool ircd_connector::AddWriteBuf std::string  data  ) 
+
+ + + + +Referenced by serverrec::SendPacket().
+   + + +

+Adds data to the connection's sendQ to be flushed later Fails if there is an error pending on the connection. +

+

-It is the sending server's responsibility to ensure sent data is kept within reasonable quanities.

-

+

@@ -189,7 +289,37 @@ This method returns true if the buffer contains at least one carriage return cha one line can be read from the buffer successfully.
-

+

+ + + + +
+ + + + + + + + + +
bool ircd_connector::CheckPing  ) 
+
+ + + + + +
+   + + +

+Checks if the connection replied to its last ping, and if it did sends another and returns true, if not, returns false. +

+

+

@@ -219,7 +349,7 @@ This method clears the server's buffer by setting it to an empty string.
-

+

+ +
@@ -246,10 +376,44 @@ This method clears the server's buffer by setting it to an empty string.

Close the connection by calling close() on its file descriptor This function call updates no other data.

+ +

+Referenced by serverrec::SendPacket().

+

+ + +
+ + + + + + + + + +
bool ircd_connector::FlushWriteBuf  ) 
-

+ + + + + +
+   + + +

+Flushes as much of the data from the buffer as possible, and advances the queue pointer to what is left. +

+ +

+Referenced by serverrec::SendPacket().

+

@@ -279,7 +443,7 @@ This method retrieves the first string from the tail end of the buffer and advan
-

+

@@ -309,7 +473,7 @@ Get the server description of this connection.
-

+

@@ -339,7 +503,7 @@ Get the file descriptor associated with this connection.
-

+

@@ -369,7 +533,7 @@ Get the ip address (not servername) associated with this connection.
-

+

+ +

+Referenced by serverrec::SendPacket().

@@ -396,10 +560,12 @@ Get the ip address (not servername) associated with this connection.

Return the servername on this established connection.

-

-

+

@@ -424,12 +590,12 @@ Return the servername on this established connection.

-Get the port number being used for this connection If the connection is outbound this will be the remote port otherwise it will be the local port, so it can always be gautanteed as open at the address given in GetServerIP(). +Get the port number being used for this connection If the connection is outbound this will be the remote port otherwise it will be the local port, so it can always be gautanteed as open at the address given in GetServerIP().

-

+

+ +

+Referenced by serverrec::SendPacket().

@@ -456,10 +622,12 @@ Get the port number being used for this connection If the connection is outbound

Get the state flags for this connection.

-

-

+

@@ -489,7 +657,69 @@ This method returns the version string of the remote server. If the server has no version string an empty string is returned.
-

+

+ + + + +
+ + + + + + + + + +
std::string ircd_connector::GetWriteError  ) 
+
+ + + + + +
+   + + +

+Gets the error string for this connection. +

+ +

+Referenced by serverrec::SendPacket().

+

+ + + + +
+ + + + + + + + + +
bool ircd_connector::HasBufferedOutput  ) 
+
+ + + + + +
+   + + +

+Returns true if there is data to be written that hasn't been sent yet. +

+

+

Create an outbound connection to a listening socket.

+ +

+Referenced by serverrec::BeginLink(), and serverrec::MeshCookie(). +

+
@@ -526,10 +756,42 @@ If the server has no version string an empty string is returned.
+

+ + +
+ + + + + + + + + +
void ircd_connector::ResetPing  ) 
-

+ + + + + +
+   + + +

+Resets the ping counter. +

+

+

@@ -560,7 +822,7 @@ Set the server description of this connection.
-

+

+ +

+Referenced by serverrec::AddIncoming().

@@ -588,7 +850,9 @@ Set the server description of this connection.

Set the file descriptor for this connection.

-

@@ -631,7 +895,7 @@ PRIVATE function to set the host address and port to connect to.

-

+

+ +

+Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), and serverrec::MeshCookie().

@@ -668,10 +932,12 @@ PRIVATE function to set the host address and port to connect to.

Set both the host and the port in one operation for this connection.

-

-

+

+ +

+Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), and serverrec::MeshCookie().

@@ -699,10 +965,12 @@ Set both the host and the port in one operation for this connection.

Set the server name of this connection.

-

-

+

@@ -733,7 +1001,7 @@ Set the port used by this connection.
-

+

+ +

+Referenced by serverrec::AddIncoming(), serverrec::BeginLink(), serverrec::MeshCookie(), and serverrec::SendPacket().

@@ -761,10 +1029,12 @@ Set the port used by this connection.

Set the state flags for this connection.

-

-

+

@@ -795,6 +1065,37 @@ This method sets the version string of the remote server.
+

+ + + + +
+ + + + + + + + + + +
void ircd_connector::SetWriteError std::string  error  ) 
+
+ + + + + +
+   + + +

+Sets the error string for this connection. +

+


Member Data Documentation

@@ -897,7 +1198,7 @@ When MakeOutboundConnection is called, these public members are filled with the

-Definition at line 101 of file connection.h. +Definition at line 117 of file connection.h.

@@ -924,7 +1225,33 @@ IRCD Buffer for input characters, holds as many lines as are pending - Note that

-Definition at line 94 of file connection.h. +Definition at line 110 of file connection.h. + + +

+ + + + +
+ + +
time_t ircd_connector::nextping [private] +
+
+ + + +
+   + + +

+Time this connection was last pinged. +

+ +

+Definition at line 98 of file connection.h.

@@ -950,7 +1277,33 @@ When MakeOutboundConnection is called, these public members are filled with the

-Definition at line 107 of file connection.h. +Definition at line 123 of file connection.h. + + +

+ + + + +
+ + +
bool ircd_connector::replied [private] +
+
+ + + +
+   + + +

+Did this connection reply to its last ping? +

+ +

+Definition at line 102 of file connection.h.

@@ -976,7 +1329,33 @@ Definition at line 107

-Definition at line 113 of file connection.h. +Definition at line 129 of file connection.h. + + +

+ + + + +
+ + +
std::string ircd_connector::sendq [private] +
+
+ + + +
+   + + +

+SendQ of the outbound connector, does not have a limit. +

+ +

+Definition at line 90 of file connection.h.

@@ -1057,9 +1436,35 @@ This string holds the ircd's version response. Definition at line 86 of file connection.h. +

+ + + + +
+ + +
std::string ircd_connector::WriteError [private] +
+
+ + + + + +
+   + + +

+Write error of connection. +

+ +

+Definition at line 94 of file connection.h.


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:38:31 2005 for InspIRCd by +
Generated on Tue May 24 02:32:15 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classircd__connector__coll__graph.gif b/docs/module-doc/classircd__connector__coll__graph.gif index 141a60856..28d7dd681 100644 Binary files a/docs/module-doc/classircd__connector__coll__graph.gif and b/docs/module-doc/classircd__connector__coll__graph.gif differ diff --git a/docs/module-doc/classserverrec-members.html b/docs/module-doc/classserverrec-members.html index 7cb071cd7..b11b9cdf4 100644 --- a/docs/module-doc/classserverrec-members.html +++ b/docs/module-doc/classserverrec-members.html @@ -6,21 +6,22 @@

serverrec Member List

This is the complete list of members for serverrec, including all inherited members. - + - + - - + + - + + @@ -29,28 +30,28 @@ - + - + - + - + -
AddIncoming(int fd, char *targethost, int sourceport)connection
AddIncoming(int fd, char *targethost, int sourceport)serverrec
ageclassbase
BeginLink(char *targethost, int port, char *password, char *servername, int myport)connection
BeginLink(char *targethost, int port, char *password, char *servername, int myport)serverrec
bytes_inconnection
bytes_outconnection
classbase()classbase [inline]
cmds_inconnection
cmds_outconnection
connection()connection
connectorsconnection
CreateListener(char *host, int p)connection
connectorsserverrec
CreateListener(char *host, int p)serverrec
descriptionserverrec
Extend(std::string key, char *p)Extensible
fdconnection
FindHost(std::string host)connection
FindHost(std::string host)serverrec
FlushWriteBuffers()serverrec
GetExt(std::string key)Extensible
haspassedconnection
hops_awayserverrec
ipconnection
jupiterserverrec
lastpingconnection
MeshCookie(char *targethost, int port, unsigned long cookie, char *servername)connection
MeshCookie(char *targethost, int port, unsigned long cookie, char *servername)serverrec
nameserverrec
nickservserverrec
npingconnection
opercountserverrec
pingtimeserverrec
portconnection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)serverrec
registeredconnection
SendPacket(char *message, const char *host)connection
SendPacket(char *message, const char *host)serverrec
serverrec()serverrec
serverrec(char *n, long ver, bool jupe)serverrec
Shrink(std::string key)Extensible
signonconnection
sync_soonserverrec
TerminateLink(char *targethost)connection
TerminateLink(char *targethost)serverrec
usercountserverrec
usercount_iserverrec
versionserverrec
~classbase()classbase [inline]
~serverrec()serverrec

Generated on Sun May 15 18:39:02 2005 for InspIRCd by +
Generated on Tue May 24 02:32:39 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classserverrec.html b/docs/module-doc/classserverrec.html index e470bf9c1..3d7dc51ec 100644 --- a/docs/module-doc/classserverrec.html +++ b/docs/module-doc/classserverrec.html @@ -18,7 +18,7 @@ Inheritance diagram for serverrec:

[legend]
Collaboration diagram for serverrec:

Collaboration graph
- +
[legend]
List of all members. @@ -32,6 +32,33 @@ Inheritance diagram for serverrec:

 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -65,6 +92,9 @@ Inheritance diagram for serverrec:

 
+ + +
~serverrec ()
 Destructor.

bool CreateListener (char *host, int p)
 Create a listening socket on 'host' using port number 'p'.

bool BeginLink (char *targethost, int port, char *password, char *servername, int myport)
 Begin an outbound link to another ircd at targethost.

bool MeshCookie (char *targethost, int port, unsigned long cookie, char *servername)
 Begin an outbound mesh link to another ircd on a network you are already an authenticated member of.

void TerminateLink (char *targethost)
 Terminate a link to 'targethost' by calling the ircd_connector::CloseConnection method.

bool SendPacket (char *message, const char *host)
 Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false.

bool RecvPacket (std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)
 Returns the next available packet and returns true if data is available.

ircd_connectorFindHost (std::string host)
 Find the ircd_connector oject related to a certain servername given in 'host'.

bool AddIncoming (int fd, char *targethost, int sourceport)
 Add an incoming connection to the connection pool.

void FlushWriteBuffers ()
 Flushes all data waiting to be written for all of this server's connections.


Public Attributes

char name [MAXBUF]
Holds nickserv's name on U:lined (services) servers (this is a kludge for ircservices which ASSUMES things :/).

bool sync_soon
std::vector< ircd_connectorconnectors
 With a serverrec, this is a list of all established server connections.


Detailed Description

A class that defines the local server or a remote server. @@ -101,22 +131,23 @@ Constructor.

-Definition at line 27 of file servers.cpp. +Definition at line 42 of file servers.cpp.

-References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connectors, connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version.

-

00028 {
-00029         strlcpy(name,"",256);
-00030         pingtime = 0;
-00031         lastping = TIME;
-00032         usercount_i = usercount = opercount = version = 0;
-00033         hops_away = 1;
-00034         signon = TIME;
-00035         jupiter = false;
-00036         fd = 0;
-00037         sync_soon = false;
-00038         strlcpy(nickserv,"",NICKMAX);
-00039 }
+
00043 {
+00044         strlcpy(name,"",256);
+00045         pingtime = 0;
+00046         lastping = TIME;
+00047         usercount_i = usercount = opercount = version = 0;
+00048         hops_away = 1;
+00049         signon = TIME;
+00050         jupiter = false;
+00051         fd = 0;
+00052         sync_soon = false;
+00053         strlcpy(nickserv,"",NICKMAX);
+00054         connectors.clear();
+00055 }
 
@@ -165,22 +196,23 @@ Constructor which initialises some of the main variables.

-Definition at line 46 of file servers.cpp. +Definition at line 62 of file servers.cpp.

-References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connectors, connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version.

-

00047 {
-00048         strlcpy(name,n,256);
-00049         lastping = TIME;
-00050         usercount_i = usercount = opercount = 0;
-00051         version = ver;
-00052         hops_away = 1;
-00053         signon = TIME;
-00054         jupiter = jupe;
-00055         fd = 0;
-00056         sync_soon = false;
-00057         strlcpy(nickserv,"",NICKMAX);
-00058 }
+
00063 {
+00064         strlcpy(name,n,256);
+00065         lastping = TIME;
+00066         usercount_i = usercount = opercount = 0;
+00067         version = ver;
+00068         hops_away = 1;
+00069         signon = TIME;
+00070         jupiter = jupe;
+00071         fd = 0;
+00072         sync_soon = false;
+00073         strlcpy(nickserv,"",NICKMAX);
+00074         connectors.clear();
+00075 }
 
@@ -213,14 +245,812 @@ Destructor.

-Definition at line 42 of file servers.cpp. +Definition at line 58 of file servers.cpp.

-

00043 {
-00044 }
+
00059 {
+00060 }
+
+ + +

Member Function Documentation

+

+ + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + +
bool serverrec::AddIncoming int  fd,
char *  targethost,
int  sourceport
+
+ + + + + +
+   + + +

+Add an incoming connection to the connection pool. +

+(reserved for core use) +

+Definition at line 207 of file servers.cpp. +

+References connectors, DEBUG, ircd_connector::SetDescriptor(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), and STATE_NOAUTH_INBOUND. +

+

00208 {
+00209         ircd_connector connector;
+00210 
+00211         // targethost has been turned into an ip...
+00212         // we dont want this as the server name.
+00213         connector.SetServerName(targethost);
+00214         connector.SetDescriptor(newfd);
+00215         connector.SetState(STATE_NOAUTH_INBOUND);
+00216         int flags = fcntl(newfd, F_GETFL, 0);
+00217         fcntl(newfd, F_SETFL, flags | O_NONBLOCK);
+00218         int sendbuf = 32768;
+00219         int recvbuf = 32768;
+00220         setsockopt(newfd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf));
+00221         setsockopt(newfd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf));
+00222         connector.SetHostAndPort(targethost, sourceport);
+00223         connector.SetState(STATE_NOAUTH_INBOUND);
+00224         log(DEBUG,"serverrec::AddIncoming() Added connection: %s:%d",targethost,sourceport);
+00225         this->connectors.push_back(connector);
+00226         return true;
+00227 }
+
+

+ + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
bool serverrec::BeginLink char *  targethost,
int  port,
char *  password,
char *  servername,
int  myport
+
+ + + + + +
+   + + +

+Begin an outbound link to another ircd at targethost. +

+ +

+Definition at line 138 of file servers.cpp. +

+References connectors, connection::fd, FindHost(), ircd_connector::MakeOutboundConnection(), SendPacket(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), STATE_DISCONNECTED, and STATE_NOAUTH_OUTBOUND. +

+

00139 {
+00140         char connect[MAXBUF];
+00141 
+00142         ircd_connector connector;
+00143         ircd_connector *cn = this->FindHost(servername);
+00144 
+00145 
+00146         if (cn)
+00147         {
+00148                 WriteOpers("CONNECT aborted: Server %s already exists",servername);
+00149                 return false;
+00150         }
+00151 
+00152 
+00153         if (this->fd)
+00154         {
+00155                 if (connector.MakeOutboundConnection(targethost,newport))
+00156                 {
+00157                         // targethost has been turned into an ip...
+00158                         // we dont want this as the server name.
+00159                         connector.SetServerName(servername);
+00160                         snprintf(connect,MAXBUF,"S %s %s %lu %s :%s",getservername().c_str(),password,(unsigned long)myport,GetRevision().c_str(),getserverdesc().c_str());
+00161                         connector.SetState(STATE_NOAUTH_OUTBOUND);
+00162                         connector.SetHostAndPort(targethost, newport);
+00163                         this->connectors.push_back(connector);
+00164                         return this->SendPacket(connect, servername);
+00165                 }
+00166                 else
+00167                 {
+00168                         connector.SetState(STATE_DISCONNECTED);
+00169                         WriteOpers("Could not create outbound connection to %s:%d",targethost,newport);
+00170                 }
+00171         }
+00172         return false;
+00173 }
+
+

+ + + + +
+ + + + + + + + + + + + + + + + + + + +
bool serverrec::CreateListener char *  host,
int  p
+
+ + + + + +
+   + + +

+Create a listening socket on 'host' using port number 'p'. +

+ +

+Definition at line 77 of file servers.cpp. +

+References connection::fd, MaxConn, and connection::port. +

+

00078 {
+00079         sockaddr_in host_address;
+00080         int flags;
+00081         in_addr addy;
+00082         int on = 0;
+00083         struct linger linger = { 0 };
+00084 
+00085         this->port = p;
+00086 
+00087         fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
+00088         if (fd <= 0)
+00089         {
+00090                 return false;
+00091         }
+00092 
+00093         setsockopt(fd,SOL_SOCKET,SO_REUSEADDR,(const char*)&on,sizeof(on));
+00094         linger.l_onoff = 1;
+00095         linger.l_linger = 1;
+00096         setsockopt(fd,SOL_SOCKET,SO_LINGER,(const char*)&linger,sizeof(linger));
+00097 
+00098         // attempt to increase socket sendq and recvq as high as its possible
+00099         // to get them on linux.
+00100         int sendbuf = 32768;
+00101         int recvbuf = 32768;
+00102         setsockopt(fd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf));
+00103         setsockopt(fd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf));
+00104 
+00105         memset((void*)&host_address, 0, sizeof(host_address));
+00106 
+00107         host_address.sin_family = AF_INET;
+00108 
+00109         if (!strcmp(newhost,""))
+00110         {
+00111                 host_address.sin_addr.s_addr = htonl(INADDR_ANY);
+00112         }
+00113         else
+00114         {
+00115                 inet_aton(newhost,&addy);
+00116                 host_address.sin_addr = addy;
+00117         }
+00118 
+00119         host_address.sin_port = htons(p);
+00120 
+00121         if (bind(fd,(sockaddr*)&host_address,sizeof(host_address))<0)
+00122         {
+00123                 return false;
+00124         }
+00125 
+00126         // make the socket non-blocking
+00127         flags = fcntl(fd, F_GETFL, 0);
+00128         fcntl(fd, F_SETFL, flags | O_NONBLOCK);
+00129 
+00130         this->port = p;
+00131 
+00132         listen(this->fd, MaxConn);
+00133 
+00134         return true;
+00135 }
+
+

+ + + + +
+ + + + + + + + + + +
ircd_connector * serverrec::FindHost std::string  host  ) 
+
+ + + + + +
+   + + +

+Find the ircd_connector oject related to a certain servername given in 'host'. +

+ +

+Definition at line 237 of file servers.cpp. +

+References connectors. +

+Referenced by BeginLink(), and SendPacket(). +

+

00238 {
+00239         for (int i = 0; i < this->connectors.size(); i++)
+00240         {
+00241                 if (this->connectors[i].GetServerName() == findhost)
+00242                 {
+00243                         return &this->connectors[i];
+00244                 }
+00245         }
+00246         return NULL;
+00247 }
+
+

+ + + + +
+ + + + + + + + + +
void serverrec::FlushWriteBuffers  ) 
+
+ + + + + +
+   + + +

+Flushes all data waiting to be written for all of this server's connections. +

+ +

+Definition at line 249 of file servers.cpp. +

+References connectors, and STATE_DISCONNECTED. +

+

00250 {
+00251         for (int i = 0; i < this->connectors.size(); i++)
+00252         {
+00253                 if (this->connectors[i].GetState() != STATE_DISCONNECTED)
+00254                 {
+00255                         if (!this->connectors[i].CheckPing())
+00256                         {
+00257                                 WriteOpers("*** Lost single connection to %s: Ping timeout",this->connectors[i].GetServerName().c_str());
+00258                                 this->connectors[i].CloseConnection();
+00259                                 this->connectors[i].SetState(STATE_DISCONNECTED);
+00260                         }
+00261                 }
+00262                 if (this->connectors[i].HasBufferedOutput())
+00263                 {
+00264                         if (!this->connectors[i].FlushWriteBuf())
+00265                         {
+00266                                 // if we're here the write() caused an error, we cannot proceed
+00267                                 WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",this->connectors[i].GetServerName().c_str(),this->connectors[i].GetWriteError().c_str());
+00268                                 this->connectors[i].CloseConnection();
+00269                                 this->connectors[i].SetState(STATE_DISCONNECTED);
+00270                         }
+00271                 }
+00272         }
+00273 }
+
+

+ + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
bool serverrec::MeshCookie char *  targethost,
int  port,
unsigned long  cookie,
char *  servername
+
+ + + + + +
+   + + +

+Begin an outbound mesh link to another ircd on a network you are already an authenticated member of. +

+ +

+Definition at line 176 of file servers.cpp. +

+References connectors, connection::fd, ircd_connector::MakeOutboundConnection(), SendPacket(), ircd_connector::SetHostAndPort(), ircd_connector::SetServerName(), ircd_connector::SetState(), STATE_CONNECTED, STATE_DISCONNECTED, and STATE_NOAUTH_OUTBOUND. +

+

00177 {
+00178         char connect[MAXBUF];
+00179 
+00180         ircd_connector connector;
+00181 
+00182         WriteOpers("Establishing meshed link to %s:%d",servername,newport);
+00183 
+00184         if (this->fd)
+00185         {
+00186                 if (connector.MakeOutboundConnection(targethost,newport))
+00187                 {
+00188                         // targethost has been turned into an ip...
+00189                         // we dont want this as the server name.
+00190                         connector.SetServerName(servername);
+00191                         snprintf(connect,MAXBUF,"- %lu %s :%s",cookie,getservername().c_str(),getserverdesc().c_str());
+00192                         connector.SetState(STATE_NOAUTH_OUTBOUND);
+00193                         connector.SetHostAndPort(targethost, newport);
+00194                         connector.SetState(STATE_CONNECTED);
+00195                         this->connectors.push_back(connector);
+00196                         return this->SendPacket(connect, servername);
+00197                 }
+00198                 else
+00199                 {
+00200                         connector.SetState(STATE_DISCONNECTED);
+00201                         WriteOpers("Could not create outbound connection to %s:%d",targethost,newport);
+00202                 }
+00203         }
+00204         return false;
+00205 }
+
+

+ + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + +
bool serverrec::RecvPacket std::deque< std::string > &  messages,
char *  host,
std::deque< std::string > &  sums
+
+ + + + + +
+   + + +

+Returns the next available packet and returns true if data is available. +

+Writes the servername the data came from to 'host'. If no data is available this function returns false. This function will automatically close broken links and reroute pathways, generating split messages on the network. +

+Definition at line 370 of file servers.cpp. +

+References already_have_sum(), connectors, DEBUG, and STATE_DISCONNECTED. +

+

00371 {
+00372         char data[65536];
+00373         memset(data, 0, 65536);
+00374         for (int i = 0; i < this->connectors.size(); i++)
+00375         {
+00376                 if (this->connectors[i].GetState() != STATE_DISCONNECTED)
+00377                 {
+00378                         // returns false if the packet could not be sent (e.g. target host down)
+00379                         int rcvsize = 0;
+00380 
+00381                         // check if theres any data on this socket
+00382                         // if not, continue onwards to the next.
+00383                         pollfd polls;
+00384                         polls.fd = this->connectors[i].GetDescriptor();
+00385                         polls.events = POLLIN;
+00386                         int ret = poll(&polls,1,1);
+00387                         if (ret <= 0) continue;
+00388 
+00389                         rcvsize = recv(this->connectors[i].GetDescriptor(),data,65000,0);
+00390                         data[rcvsize] = '\0';
+00391                         if (rcvsize == -1)
+00392                         {
+00393                                 if (errno != EAGAIN)
+00394                                 {
+00395                                         log(DEBUG,"recv() failed for serverrec::RecvPacket(): %s",strerror(errno));
+00396                                         log(DEBUG,"Disabling connector: %s",this->connectors[i].GetServerName().c_str());
+00397                                         this->connectors[i].CloseConnection();
+00398                                         this->connectors[i].SetState(STATE_DISCONNECTED);
+00399                                 }
+00400                         }
+00401                         int pushed = 0;
+00402                         if (rcvsize > 0)
+00403                         {
+00404                                 if (!this->connectors[i].AddBuffer(data))
+00405                                 {
+00406                                         WriteOpers("*** Read buffer for %s exceeds maximum, closing connection!",this->connectors[i].GetServerName().c_str());
+00407                                         this->connectors[i].CloseConnection();
+00408                                         this->connectors[i].SetState(STATE_DISCONNECTED);
+00409                                 }
+00410                                 if (this->connectors[i].BufferIsComplete())
+00411                                 {
+00412                                         this->connectors[i].ResetPing();
+00413                                         while (this->connectors[i].BufferIsComplete())
+00414                                         {
+00415                                                 std::string text = this->connectors[i].GetBuffer();
+00416                                                 if (text != "")
+00417                                                 {
+00418                                                         if ((text[0] == ':') && (text.find(" ") != std::string::npos))
+00419                                                         {
+00420                                                                 std::string orig = text;
+00421                                                                 log(DEBUG,"Original: %s",text.c_str());
+00422                                                                 std::string sum = text.substr(1,text.find(" ")-1);
+00423                                                                 text = text.substr(text.find(" ")+1,text.length());
+00424                                                                 std::string possible_token = text.substr(1,text.find(" ")-1);
+00425                                                                 if (possible_token.length() > 1)
+00426                                                                 {
+00427                                                                         sums.push_back("*");
+00428                                                                         text = orig;
+00429                                                                         log(DEBUG,"Non-mesh, non-tokenized string passed up the chain");
+00430                                                                 }
+00431                                                                 else
+00432                                                                 {
+00433                                                                         log(DEBUG,"Packet sum: '%s'",sum.c_str());
+00434                                                                         if ((already_have_sum(sum)) && (sum != "*"))
+00435                                                                         {
+00436                                                                                 // we don't accept dupes
+00437                                                                                 continue;
+00438                                                                         }
+00439                                                                         sums.push_back(sum.c_str());
+00440                                                                 }
+00441                                                         }
+00442                                                         else sums.push_back("*");
+00443                                                         messages.push_back(text.c_str());
+00444                                                         strlcpy(recvhost,this->connectors[i].GetServerName().c_str(),160);
+00445                                                         log(DEBUG,"serverrec::RecvPacket() %d:%s->%s",pushed++,recvhost,text.c_str());
+00446                                                 }
+00447                                         }
+00448                                         return true;
+00449                                 }
+00450                         }
+00451                 }
+00452         }
+00453         // nothing new yet -- message and host will be undefined
+00454         return false;
+00455 }
+
+

+ + + + +
+ + + + + + + + + + + + + + + + + + + +
bool serverrec::SendPacket char *  message,
const char *  host
+
+ + + + + +
+   + + +

+Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. +

+ +

+Definition at line 275 of file servers.cpp. +

+References ircd_connector::AddWriteBuf(), ircd_connector::CloseConnection(), connectors, DEBUG, FindHost(), ircd_connector::FlushWriteBuf(), ircd_connector::GetServerName(), ircd_connector::GetState(), ircd_connector::GetWriteError(), ircd_connector::SetState(), and STATE_DISCONNECTED. +

+Referenced by BeginLink(), and MeshCookie(). +

+

00276 {
+00277         if ((!message) || (!sendhost))
+00278                 return true;
+00279 
+00280         ircd_connector* cn = this->FindHost(sendhost);
+00281 
+00282         if (!strchr(message,'\n'))
+00283         {
+00284                 strlcat(message,"\n",MAXBUF);
+00285         }
+00286 
+00287         if (cn)
+00288         {
+00289                 log(DEBUG,"main: serverrec::SendPacket() sent '%s' to %s",message,cn->GetServerName().c_str());
+00290 
+00291                 if (cn->GetState() == STATE_DISCONNECTED)
+00292                 {
+00293                         // fix: can only route one hop to avoid a loop
+00294                         if (strncmp(message,"R ",2))
+00295                         {
+00296                                 log(DEBUG,"Not a double reroute");
+00297                                 // this route is down, we must re-route the packet through an available point in the mesh.
+00298                                 for (int k = 0; k < this->connectors.size(); k++)
+00299                                 {
+00300                                         log(DEBUG,"Check connector %d: %s",k,this->connectors[k].GetServerName().c_str());
+00301                                         // search for another point in the mesh which can 'reach' where we want to go
+00302                                         for (int m = 0; m < this->connectors[k].routes.size(); m++)
+00303                                         {
+00304                                                 if (!strcasecmp(this->connectors[k].routes[m].c_str(),sendhost))
+00305                                                 {
+00306                                                         log(DEBUG,"Found alternative route for packet: %s",this->connectors[k].GetServerName().c_str());
+00307                                                         char buffer[MAXBUF];
+00308                                                         snprintf(buffer,MAXBUF,"R %s %s",sendhost,message);
+00309                                                         this->SendPacket(buffer,this->connectors[k].GetServerName().c_str());
+00310                                                         return true;
+00311                                                 }
+00312                                         }
+00313                                 }
+00314                         }
+00315                         char buffer[MAXBUF];
+00316                         snprintf(buffer,MAXBUF,"& %s",sendhost);
+00317                         WriteOpers("*** All connections to %s lost.",sendhost);
+00318                         NetSendToAllExcept(sendhost,buffer);
+00319                         DoSplit(sendhost);
+00320                         return false;
+00321                 }
+00322 
+00323                 // returns false if the packet could not be sent (e.g. target host down)
+00324                 if (!cn->AddWriteBuf(message))
+00325                 {
+00326                         // if we're here, there was an error pending, and the send cannot proceed
+00327                         log(DEBUG,"cn->AddWriteBuf() failed for serverrec::SendPacket(): %s",cn->GetWriteError().c_str());
+00328                         log(DEBUG,"Disabling connector: %s",cn->GetServerName().c_str());
+00329                         cn->CloseConnection();
+00330                         cn->SetState(STATE_DISCONNECTED);
+00331                         WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",cn->GetServerName().c_str(),cn->GetWriteError().c_str());
+00332                         // retry the packet along a new route so either arrival OR failure are gauranteed (bugfix)
+00333                         return this->SendPacket(message,sendhost);
+00334                 }
+00335                 if (!cn->FlushWriteBuf())
+00336                 {
+00337                         // if we're here the write() caused an error, we cannot proceed
+00338                         log(DEBUG,"cn->FlushWriteBuf() failed for serverrec::SendPacket(): %s",cn->GetWriteError().c_str());
+00339                         log(DEBUG,"Disabling connector: %s",cn->GetServerName().c_str());
+00340                         cn->CloseConnection();
+00341                         cn->SetState(STATE_DISCONNECTED);
+00342                         WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",cn->GetServerName().c_str(),cn->GetWriteError().c_str());
+00343                         // retry the packet along a new route so either arrival OR failure are gauranteed
+00344                         return this->SendPacket(message,sendhost);
+00345                 }
+00346                 return true;
+00347         }
+00348 }
+
+

+ + + + +
+ + + + + + + + + + +
void serverrec::TerminateLink char *  targethost  ) 
+
+ + + +
+   + + +

+Terminate a link to 'targethost' by calling the ircd_connector::CloseConnection method. +

+ +

+Definition at line 229 of file servers.cpp. +

+

00230 {
+00231         // this locates the targethost in the serverrec::connectors vector of the class,
+00232         // and terminates it by sending it an SQUIT token and closing its descriptor.
+00233         // TerminateLink with a null string causes a terminate of ALL links
+00234 }
 


Member Data Documentation

+

+ + + + +
+ + +
std::vector<ircd_connector> serverrec::connectors +
+
+ + + + + +
+   + + +

+With a serverrec, this is a list of all established server connections. +

+ +

+Definition at line 81 of file servers.h. +

+Referenced by AddIncoming(), BeginLink(), FindHost(), FlushWriteBuffers(), MeshCookie(), RecvPacket(), SendPacket(), and serverrec().

@@ -272,7 +1102,7 @@ number of hops away (for quick access)

Definition at line 51 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -300,7 +1130,7 @@ is a JUPE server (faked to enforce a server ban)

Definition at line 57 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -328,7 +1158,7 @@ server name

Definition at line 36 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -356,7 +1186,7 @@ Holds nickserv's name on U:lined (services) servers (this is a kludge for ircser

Definition at line 65 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -384,7 +1214,7 @@ opers on server

Definition at line 48 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -412,7 +1242,7 @@ last ping response (ms)

Definition at line 39 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -438,7 +1268,7 @@ Referenced by serverrec() Definition at line 67 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -466,7 +1296,7 @@ non-invisible users on server

Definition at line 45 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -494,7 +1324,7 @@ invisible users on server

Definition at line 42 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -522,12 +1352,12 @@ ircd version

Definition at line 54 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:39:02 2005 for InspIRCd by +
Generated on Tue May 24 02:32:39 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classserverrec__coll__graph.gif b/docs/module-doc/classserverrec__coll__graph.gif index b3baed69b..05abae634 100644 Binary files a/docs/module-doc/classserverrec__coll__graph.gif and b/docs/module-doc/classserverrec__coll__graph.gif differ diff --git a/docs/module-doc/classstd_1_1char__traits.html b/docs/module-doc/classstd_1_1char__traits.html index 04a13d5a6..279a40c74 100644 --- a/docs/module-doc/classstd_1_1char__traits.html +++ b/docs/module-doc/classstd_1_1char__traits.html @@ -14,7 +14,7 @@
The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:37:46 2005 for InspIRCd by +
Generated on Tue May 24 02:31:35 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classucrec-members.html b/docs/module-doc/classucrec-members.html index c03035468..a83284aac 100644 --- a/docs/module-doc/classucrec-members.html +++ b/docs/module-doc/classucrec-members.html @@ -13,7 +13,7 @@ ucrec()ucrec [inline] ~classbase()classbase [inline] ~ucrec()ucrec [inline, virtual] -
Generated on Sun May 15 18:39:04 2005 for InspIRCd by +
Generated on Tue May 24 02:32:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classucrec.html b/docs/module-doc/classucrec.html index 53aa8405e..fe543e2b9 100644 --- a/docs/module-doc/classucrec.html +++ b/docs/module-doc/classucrec.html @@ -134,7 +134,7 @@ If the record is not in use, this value will be NULL.

Definition at line 233 of file channels.h.

-Referenced by Server::PseudoToUser(), and userrec::userrec(). +Referenced by Server::PseudoToUser(), and userrec::userrec().

@@ -162,12 +162,12 @@ UCMODE_FOUNDER values. If this value is zero, the user has no privilages upon th

Definition at line 228 of file channels.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().


The documentation for this class was generated from the following file: -
Generated on Sun May 15 18:39:04 2005 for InspIRCd by +
Generated on Tue May 24 02:32:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classuserrec-members.html b/docs/module-doc/classuserrec-members.html index bf72fdb78..f4da154bd 100644 --- a/docs/module-doc/classuserrec-members.html +++ b/docs/module-doc/classuserrec-members.html @@ -6,37 +6,33 @@

userrec Member List

This is the complete list of members for userrec, including all inherited members. - - - + + - - + - + + - - - - + - + - - + + @@ -48,7 +44,6 @@ - @@ -56,28 +51,26 @@ - + - - + - -
AddBuffer(std::string a)userrec
AddIncoming(int fd, char *targethost, int sourceport)connection
AddWriteBuf(std::string data)userrec
AddBuffer(std::string a)userrec
AddWriteBuf(std::string data)userrec
ageclassbase
awaymsguserrec
BeginLink(char *targethost, int port, char *password, char *servername, int myport)connection
BufferIsReady()userrec
BufferIsReady()userrec
bytes_inconnection
bytes_outconnection
chansuserrec
classbase()classbase [inline]
ClearBuffer()userrec
ClearBuffer()userrec
CloseSocket()userrec
cmds_inconnection
cmds_outconnection
connection()connection
connectorsconnection
CreateListener(char *host, int p)connection
dhostuserrec
dns_doneuserrec
Extend(std::string key, char *p)Extensible
fdconnection
FindHost(std::string host)connection
flooduserrec
FlushWriteBuf()userrec
FlushWriteBuf()userrec
fullnameuserrec
GetBuffer()userrec
GetBuffer()userrec
GetExt(std::string key)Extensible
GetFullHost()userrec [virtual]
GetFullRealHost()userrec [virtual]
GetInviteList()userrec
GetWriteError()userrec
GetInviteList()userrec
GetWriteError()userrec
haspassedconnection
HasPermission(char *command)userrec
hostconnection
IsInvited(char *channel)userrec [virtual]
lastpingconnection
lines_inuserrec
MeshCookie(char *targethost, int port, unsigned long cookie, char *servername)connection
modesuserrec
nickuserrec
npingconnection
passworduserrec
pingmaxuserrec
portconnection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
ReadData(void *buffer, size_t size)userrec
recvquserrec
recvqmaxuserrec
registeredconnection
RemoveInvite(char *channel)userrec [virtual]
reset_dueuserrec
resultuserrec
SendPacket(char *message, const char *host)connection
sendquserrec
sendqmaxuserrec
serveruserrec
SetWriteError(std::string error)userrec
SetWriteError(std::string error)userrec
Shrink(std::string key)Extensible
signonconnection
TerminateLink(char *targethost)connection
thresholduserrec
timeoutuserrec
userrec()userrec
WriteErroruserrec
~classbase()classbase [inline]
~userrec()userrec [inline, virtual]

Generated on Sun May 15 18:39:14 2005 for InspIRCd by +
Generated on Tue May 24 02:32:48 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classuserrec.html b/docs/module-doc/classuserrec.html index c9aec653f..257dd3b50 100644 --- a/docs/module-doc/classuserrec.html +++ b/docs/module-doc/classuserrec.html @@ -18,8 +18,8 @@ Inheritance diagram for userrec:

[legend]
Collaboration diagram for userrec:

Collaboration graph
- - + +
[legend]
List of all members. @@ -46,33 +46,39 @@ Inheritance diagram for userrec:

bool 
- + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - + + + + + + + @@ -179,39 +185,39 @@ Definition at line 108 of f

-Definition at line 29 of file users.cpp. -

-References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. -

-

00030 {
-00031         // the PROPER way to do it, AVOID bzero at *ALL* costs
-00032         strcpy(nick,"");
-00033         strcpy(ip,"127.0.0.1");
-00034         timeout = 0;
-00035         strcpy(ident,"");
-00036         strcpy(host,"");
-00037         strcpy(dhost,"");
-00038         strcpy(fullname,"");
-00039         strcpy(modes,"");
-00040         strcpy(server,"");
-00041         strcpy(awaymsg,"");
-00042         strcpy(oper,"");
-00043         reset_due = TIME;
-00044         lines_in = 0;
-00045         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
-00046         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
-00047         haspassed = false;
-00048         dns_done = false;
-00049         recvq = "";
-00050         sendq = "";
-00051         strcpy(result,"");
-00052         for (int i = 0; i < MAXCHANS; i++)
-00053         {
-00054                 this->chans[i].channel = NULL;
-00055                 this->chans[i].uc_modes = 0;
-00056         }
-00057         invites.clear();
-00058 }
+Definition at line 31 of file users.cpp.
+

+References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. +

+

00032 {
+00033         // the PROPER way to do it, AVOID bzero at *ALL* costs
+00034         strcpy(nick,"");
+00035         strcpy(ip,"127.0.0.1");
+00036         timeout = 0;
+00037         strcpy(ident,"");
+00038         strcpy(host,"");
+00039         strcpy(dhost,"");
+00040         strcpy(fullname,"");
+00041         strcpy(modes,"");
+00042         strcpy(server,"");
+00043         strcpy(awaymsg,"");
+00044         strcpy(oper,"");
+00045         reset_due = TIME;
+00046         lines_in = 0;
+00047         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
+00048         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
+00049         haspassed = false;
+00050         dns_done = false;
+00051         recvq = "";
+00052         sendq = "";
+00053         strcpy(result,"");
+00054         for (int i = 0; i < MAXCHANS; i++)
+00055         {
+00056                 this->chans[i].channel = NULL;
+00057                 this->chans[i].uc_modes = 0;
+00058         }
+00059         invites.clear();
+00060 }
 
HasPermission (char *command)
 Returns true or false for if a user can execute a privilaged oper command.

bool AddBuffer (std::string a)
int ReadData (void *buffer, size_t size)
 This method adds data to the buffer of the user.

bool BufferIsReady ()
 Calls read() to read some data for this user using their fd.

bool AddBuffer (std::string a)
 This method returns true if the buffer contains at least one carriage return character (e.g.

void ClearBuffer ()
 This method adds data to the buffer of the user.

bool BufferIsReady ()
 This function clears the entire buffer by setting it to an empty string.

std::string GetBuffer ()
 This method returns true if the buffer contains at least one carriage return character (e.g.

void ClearBuffer ()
 This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string.

void SetWriteError (std::string error)
 This function clears the entire buffer by setting it to an empty string.

std::string GetBuffer ()
 Sets the write error for a connection.

std::string GetWriteError ()
 This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string.

void SetWriteError (std::string error)
 Returns the write error which last occured on this connection or an empty string if none occured.

void AddWriteBuf (std::string data)
 Sets the write error for a connection.

std::string GetWriteError ()
 Adds to the user's write buffer.

void FlushWriteBuf ()
 Returns the write error which last occured on this connection or an empty string if none occured.

void AddWriteBuf (std::string data)
 Flushes as much of the user's buffer to the file descriptor as possible.

InvitedListGetInviteList ()
 Adds to the user's write buffer.

void FlushWriteBuf ()
 Returns the list of channels this user has been invited to but has not yet joined.

 Flushes as much of the user's buffer to the file descriptor as possible.

InvitedListGetInviteList ()
 Returns the list of channels this user has been invited to but has not yet joined.

void CloseSocket ()
 Shuts down and closes the user's socket.


Public Attributes

char nick [NICKMAX]
@@ -249,7 +255,7 @@ Definition at line 222 of f

Member Function Documentation

-

+

@@ -279,38 +285,38 @@ This method adds data to the buffer of the user.

The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.

-Definition at line 175 of file users.cpp. -

-References recvq, recvqmax, and SetWriteError(). -

-

00176 {
-00177         std::string b = "";
-00178         for (int i = 0; i < a.length(); i++)
-00179                 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7))
-00180                         b = b + a[i];
-00181         std::stringstream stream(recvq);
-00182         stream << b;
-00183         recvq = stream.str();
-00184         int i = 0;
-00185         // count the size of the first line in the buffer.
-00186         while (i < recvq.length())
-00187         {
-00188                 if (recvq[i++] == '\n')
-00189                         break;
-00190         }
-00191         if (recvq.length() > this->recvqmax)
-00192         {
-00193                 this->SetWriteError("RecvQ exceeded");
-00194                 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax);
-00195         }
-00196         // return false if we've had more than 600 characters WITHOUT
-00197         // a carriage return (this is BAD, drop the socket)
-00198         return (i < 600);
-00199 }
+Definition at line 190 of file users.cpp.
+

+References recvq, recvqmax, and SetWriteError(). +

+

00191 {
+00192         std::string b = "";
+00193         for (int i = 0; i < a.length(); i++)
+00194                 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7))
+00195                         b = b + a[i];
+00196         std::stringstream stream(recvq);
+00197         stream << b;
+00198         recvq = stream.str();
+00199         int i = 0;
+00200         // count the size of the first line in the buffer.
+00201         while (i < recvq.length())
+00202         {
+00203                 if (recvq[i++] == '\n')
+00204                         break;
+00205         }
+00206         if (recvq.length() > this->recvqmax)
+00207         {
+00208                 this->SetWriteError("RecvQ exceeded");
+00209                 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax);
+00210         }
+00211         // return false if we've had more than 600 characters WITHOUT
+00212         // a carriage return (this is BAD, drop the socket)
+00213         return (i < 600);
+00214 }
 
-

+

@@ -338,29 +344,29 @@ References recvq, Adds to the user's write buffer.

-You may add any amount of text up to this users sendq value, if you exceed the sendq value, SetWriteError() will be called to set the users error string to "SendQ exceeded", and further buffer adds will be dropped. -

-Definition at line 231 of file users.cpp. -

-References GetWriteError(), sendq, sendqmax, and SetWriteError(). -

-

00232 {
-00233         if (this->GetWriteError() != "")
-00234                 return;
-00235         if (sendq.length() + data.length() > this->sendqmax)
-00236         {
-00237                 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax);
-00238                 this->SetWriteError("SendQ exceeded");
-00239                 return;
-00240         }
-00241         std::stringstream stream;
-00242         stream << sendq << data;
-00243         sendq = stream.str();
-00244 }
+You may add any amount of text up to this users sendq value, if you exceed the sendq value, SetWriteError() will be called to set the users error string to "SendQ exceeded", and further buffer adds will be dropped.
+

+Definition at line 246 of file users.cpp. +

+References GetWriteError(), sendq, sendqmax, and SetWriteError(). +

+

00247 {
+00248         if (this->GetWriteError() != "")
+00249                 return;
+00250         if (sendq.length() + data.length() > this->sendqmax)
+00251         {
+00252                 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax);
+00253                 this->SetWriteError("SendQ exceeded");
+00254                 return;
+00255         }
+00256         std::stringstream stream;
+00257         stream << sendq << data;
+00258         sendq = stream.str();
+00259 }
 
-

+

@@ -389,20 +395,20 @@ This method returns true if the buffer contains at least one carriage return cha

one complete line may be read)

-Definition at line 201 of file users.cpp. +Definition at line 216 of file users.cpp.

References recvq.

-

00202 {
-00203         for (int i = 0; i < recvq.length(); i++)
-00204                 if (recvq[i] == '\n')
-00205                         return true;
-00206         return false;
-00207 }
+
00217 {
+00218         for (int i = 0; i < recvq.length(); i++)
+00219                 if (recvq[i] == '\n')
+00220                         return true;
+00221         return false;
+00222 }
 
-

+

@@ -431,19 +437,57 @@ This function clears the entire buffer by setting it to an empty string.

-Definition at line 209 of file users.cpp. +Definition at line 224 of file users.cpp.

References recvq.

-Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). +Referenced by Server::PseudoToUser(), and Server::UserToPseudo().

-

00210 {
-00211         recvq = "";
-00212 }
+
00225 {
+00226         recvq = "";
+00227 }
 
-

+

+ + + + +
+ + + + + + + + + +
void userrec::CloseSocket  ) 
+
+ + + + + +
+   + + +

+Shuts down and closes the user's socket. +

+ +

+Definition at line 62 of file users.cpp. +

+

00063 {
+00064         shutdown(this->fd,2);
+00065         close(this->fd);
+00066 }
+
+

@@ -472,34 +516,34 @@ Flushes as much of the user's buffer to the file descriptor as possible.

This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.

-Definition at line 247 of file users.cpp. -

-References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). -

-

00248 {
-00249         if (sendq.length())
-00250         {
-00251                 char* tb = (char*)this->sendq.c_str();
-00252                 int n_sent = write(this->fd,tb,this->sendq.length());
-00253                 if (n_sent == -1)
-00254                 {
-00255                         this->SetWriteError(strerror(errno));
-00256                 }
-00257                 else
-00258                 {
-00259                         // advance the queue
-00260                         tb += n_sent;
-00261                         this->sendq = tb;
-00262                         // update the user's stats counters
-00263                         this->bytes_out += n_sent;
-00264                         this->cmds_out++;
-00265                 }
-00266         }
-00267 }
+Definition at line 262 of file users.cpp.
+

+References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). +

+

00263 {
+00264         if (sendq.length())
+00265         {
+00266                 char* tb = (char*)this->sendq.c_str();
+00267                 int n_sent = write(this->fd,tb,this->sendq.length());
+00268                 if (n_sent == -1)
+00269                 {
+00270                         this->SetWriteError(strerror(errno));
+00271                 }
+00272                 else
+00273                 {
+00274                         // advance the queue
+00275                         tb += n_sent;
+00276                         this->sendq = tb;
+00277                         // update the user's stats counters
+00278                         this->bytes_out += n_sent;
+00279                         this->cmds_out++;
+00280                 }
+00281         }
+00282 }
 
-

+

@@ -526,27 +570,27 @@ References connection::byt

This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string.

-This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use BufferIsReady() to check if it is ok to read the buffer before calling GetBuffer(). +This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use BufferIsReady() to check if it is ok to read the buffer before calling GetBuffer().

-Definition at line 214 of file users.cpp. +Definition at line 229 of file users.cpp.

References recvq.

-

00215 {
-00216         if (recvq == "")
-00217                 return "";
-00218         char* line = (char*)recvq.c_str();
-00219         std::string ret = "";
-00220         while ((*line != '\n') && (strlen(line)))
-00221         {
-00222                 ret = ret + *line;
-00223                 line++;
-00224         }
-00225         if ((*line == '\n') || (*line == '\r'))
-00226                 line++;
-00227         recvq = line;
-00228         return ret;
-00229 }
+
00230 {
+00231         if (recvq == "")
+00232                 return "";
+00233         char* line = (char*)recvq.c_str();
+00234         std::string ret = "";
+00235         while ((*line != '\n') && (strlen(line)))
+00236         {
+00237                 ret = ret + *line;
+00238                 line++;
+00239         }
+00240         if ((*line == '\n') || (*line == '\r'))
+00241                 line++;
+00242         recvq = line;
+00243         return ret;
+00244 }
 
@@ -579,14 +623,14 @@ Returns the full displayed host of the user This member function returns the hos

-Definition at line 62 of file users.cpp. +Definition at line 68 of file users.cpp.

References dhost, ident, nick, and result.

-

00063 {
-00064         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
-00065         return result;
-00066 }
+
00069 {
+00070         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
+00071         return result;
+00072 }
 
@@ -619,18 +663,18 @@ Returns the full real host of the user This member function returns the hostname

If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.

-Definition at line 69 of file users.cpp. +Definition at line 84 of file users.cpp.

-References connection::host, ident, nick, and result. +References connection::host, ident, nick, and result.

-

00070 {
-00071         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host);
-00072         return result;
-00073 }
+
00085 {
+00086         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host);
+00087         return result;
+00088 }
 
-

+

@@ -659,17 +703,17 @@ Returns the list of channels this user has been invited to but has not yet joine

-Definition at line 89 of file users.cpp. +Definition at line 104 of file users.cpp.

References InvitedList, and invites.

-

00090 {
-00091         return &invites;
-00092 }
+
00105 {
+00106         return &invites;
+00107 }
 
-

+

@@ -698,15 +742,15 @@ Returns the write error which last occured on this connection or an empty string

-Definition at line 277 of file users.cpp. +Definition at line 292 of file users.cpp.

References WriteError.

-Referenced by AddWriteBuf(). +Referenced by AddWriteBuf().

-

00278 {
-00279         return this->WriteError;
-00280 }
+
00293 {
+00294         return this->WriteError;
+00295 }
 
@@ -740,59 +784,59 @@ Returns true or false for if a user can execute a privilaged oper command.

This is done by looking up their oper type from userrec::oper, then referencing this to their oper classes and checking the commands they can execute.

-Definition at line 123 of file users.cpp. -

-References config_f, and DEBUG. -

-

00124 {
-00125         char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
-00126         char* mycmd;
-00127         char* savept;
-00128         char* savept2;
-00129         
-00130         // are they even an oper at all?
-00131         if (strchr(this->modes,'o'))
-00132         {
-00133                 log(DEBUG,"*** HasPermission: %s is an oper",this->nick);
-00134                 for (int j =0; j < ConfValueEnum("type",&config_f); j++)
-00135                 {
-00136                         ConfValue("type","name",j,TypeName,&config_f);
-00137                         if (!strcmp(TypeName,this->oper))
-00138                         {
-00139                                 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper);
-00140                                 ConfValue("type","classes",j,Classes,&config_f);
-00141                                 char* myclass = strtok_r(Classes," ",&savept);
-00142                                 while (myclass)
-00143                                 {
-00144                                         log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass);
-00145                                         for (int k =0; k < ConfValueEnum("class",&config_f); k++)
-00146                                         {
-00147                                                 ConfValue("class","name",k,ClassName,&config_f);
-00148                                                 if (!strcmp(ClassName,myclass))
-00149                                                 {
-00150                                                         ConfValue("class","commands",k,CommandList,&config_f);
-00151                                                         log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList);
-00152                                                         
-00153                                                         
-00154                                                         mycmd = strtok_r(CommandList," ",&savept2);
-00155                                                         while (mycmd)
-00156                                                         {
-00157                                                                 if (!strcasecmp(mycmd,command))
-00158                                                                 {
-00159                                                                         log(DEBUG,"*** Command %s found, returning true",command);
-00160                                                                         return true;
-00161                                                                 }
-00162                                                                 mycmd = strtok_r(NULL," ",&savept2);
-00163                                                         }
-00164                                                 }
-00165                                         }
-00166                                         myclass = strtok_r(NULL," ",&savept);
-00167                                 }
-00168                         }
-00169                 }
-00170         }
-00171         return false;
-00172 }
+Definition at line 138 of file users.cpp.
+

+References config_f, and DEBUG. +

+

00139 {
+00140         char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
+00141         char* mycmd;
+00142         char* savept;
+00143         char* savept2;
+00144         
+00145         // are they even an oper at all?
+00146         if (strchr(this->modes,'o'))
+00147         {
+00148                 log(DEBUG,"*** HasPermission: %s is an oper",this->nick);
+00149                 for (int j =0; j < ConfValueEnum("type",&config_f); j++)
+00150                 {
+00151                         ConfValue("type","name",j,TypeName,&config_f);
+00152                         if (!strcmp(TypeName,this->oper))
+00153                         {
+00154                                 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper);
+00155                                 ConfValue("type","classes",j,Classes,&config_f);
+00156                                 char* myclass = strtok_r(Classes," ",&savept);
+00157                                 while (myclass)
+00158                                 {
+00159                                         log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass);
+00160                                         for (int k =0; k < ConfValueEnum("class",&config_f); k++)
+00161                                         {
+00162                                                 ConfValue("class","name",k,ClassName,&config_f);
+00163                                                 if (!strcmp(ClassName,myclass))
+00164                                                 {
+00165                                                         ConfValue("class","commands",k,CommandList,&config_f);
+00166                                                         log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList);
+00167                                                         
+00168                                                         
+00169                                                         mycmd = strtok_r(CommandList," ",&savept2);
+00170                                                         while (mycmd)
+00171                                                         {
+00172                                                                 if (!strcasecmp(mycmd,command))
+00173                                                                 {
+00174                                                                         log(DEBUG,"*** Command %s found, returning true",command);
+00175                                                                         return true;
+00176                                                                 }
+00177                                                                 mycmd = strtok_r(NULL," ",&savept2);
+00178                                                         }
+00179                                                 }
+00180                                         }
+00181                                         myclass = strtok_r(NULL," ",&savept);
+00182                                 }
+00183                         }
+00184                 }
+00185         }
+00186         return false;
+00187 }
 
@@ -826,15 +870,15 @@ Adds a channel to a users invite list (invites them to a channel).

-Definition at line 94 of file users.cpp. +Definition at line 109 of file users.cpp.

References Invited::channel, and invites.

-

00095 {
-00096         Invited i;
-00097         strlcpy(i.channel,channel,CHANMAX);
-00098         invites.push_back(i);
-00099 }
+
00110 {
+00111         Invited i;
+00112         strlcpy(i.channel,channel,CHANMAX);
+00113         invites.push_back(i);
+00114 }
 
@@ -868,22 +912,75 @@ Returns true if a user is invited to a channel.

-Definition at line 75 of file users.cpp. +Definition at line 90 of file users.cpp.

References invites.

-

00076 {
-00077         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
-00078         {
-00079                 if (i->channel) {
-00080                         if (!strcasecmp(i->channel,channel))
-00081                         {
-00082                                 return true;
-00083                         }
-00084                 }
-00085         }
-00086         return false;
-00087 }
+
00091 {
+00092         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
+00093         {
+00094                 if (i->channel) {
+00095                         if (!strcasecmp(i->channel,channel))
+00096                         {
+00097                                 return true;
+00098                         }
+00099                 }
+00100         }
+00101         return false;
+00102 }
+
+ + +

+ + + + +
+ + + + + + + + + + + + + + + + + + + +
int userrec::ReadData void *  buffer,
size_t  size
+
+ + + +
+   + + +

+Calls read() to read some data for this user using their fd. +

+ +

+Definition at line 74 of file users.cpp. +

+References connection::fd. +

+

00075 {
+00076         if (this->fd > -1)
+00077         {
+00078                 return read(this->fd, buffer, size);
+00079         }
+00080         else return 0;
+00081 }
 
@@ -917,34 +1014,34 @@ Removes a channel from a users invite list.

This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.

-Definition at line 101 of file users.cpp. +Definition at line 116 of file users.cpp.

References DEBUG, and invites.

-

00102 {
-00103         log(DEBUG,"Removing invites");
-00104         if (channel)
-00105         {
-00106                 if (invites.size())
-00107                 {
-00108                         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
-00109                         {
-00110                                 if (i->channel)
-00111                                 {
-00112                                         if (!strcasecmp(i->channel,channel))
-00113                                         {
-00114                                                 invites.erase(i);
-00115                                                 return;
-00116                                         }
-00117                                 }
-00118                         }
-00119                 }
-00120         }
-00121 }
+
00117 {
+00118         log(DEBUG,"Removing invites");
+00119         if (channel)
+00120         {
+00121                 if (invites.size())
+00122                 {
+00123                         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
+00124                         {
+00125                                 if (i->channel)
+00126                                 {
+00127                                         if (!strcasecmp(i->channel,channel))
+00128                                         {
+00129                                                 invites.erase(i);
+00130                                                 return;
+00131                                         }
+00132                                 }
+00133                         }
+00134                 }
+00135         }
+00136 }
 
-

+

@@ -974,18 +1071,18 @@ Sets the write error for a connection.

This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.

-Definition at line 269 of file users.cpp. +Definition at line 284 of file users.cpp.

References DEBUG, and WriteError.

-Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf(). +Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf().

-

00270 {
-00271         log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str());
-00272         // don't try to set the error twice, its already set take the first string.
-00273         if (this->WriteError == "")
-00274                 this->WriteError = error;
-00275 }
+
00285 {
+00286         log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str());
+00287         // don't try to set the error twice, its already set take the first string.
+00288         if (this->WriteError == "")
+00289                 this->WriteError = error;
+00290 }
 
@@ -1015,7 +1112,7 @@ If this string is empty, the user is not marked as away.

Definition at line 151 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1041,7 +1138,7 @@ Referenced by userrec().

Definition at line 142 of file users.h.

-Referenced by Server::PseudoToUser(), and userrec(). +Referenced by Server::PseudoToUser(), and userrec().

@@ -1069,7 +1166,7 @@ This usually matches the value of u

Definition at line 130 of file users.h.

-Referenced by GetFullHost(), and userrec(). +Referenced by GetFullHost(), and userrec().

@@ -1097,7 +1194,7 @@ True when DNS lookups are completed.

Definition at line 179 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1125,7 +1222,7 @@ Number of lines the user can place into the buffer (up to the global NetBufferSi

Definition at line 162 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1153,7 +1250,7 @@ The users full name.

Definition at line 134 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1181,7 +1278,7 @@ The users ident reply.

Definition at line 125 of file users.h.

-Referenced by GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), userrec(), and Server::UserToPseudo(). +Referenced by GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), userrec(), and Server::UserToPseudo().

@@ -1209,7 +1306,7 @@ A list of channels the user has a pending invite to.

Definition at line 114 of file users.h.

-Referenced by GetInviteList(), InviteTo(), IsInvited(), RemoveInvite(), and userrec(). +Referenced by GetInviteList(), InviteTo(), IsInvited(), RemoveInvite(), and userrec().

@@ -1237,7 +1334,7 @@ Flood counters.

Definition at line 204 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1265,7 +1362,7 @@ This may contain any of the following RFC characters: o, w, s, i Your module may

Definition at line 140 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1293,7 +1390,7 @@ An invalid nickname indicates an unregistered connection prior to the NICK comma

Definition at line 121 of file users.h.

-Referenced by ConfigReader::DumpErrors(), GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), and userrec(). +Referenced by ConfigReader::DumpErrors(), GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), and userrec().

@@ -1321,7 +1418,7 @@ This is used to check permissions in operclasses, so that we can say 'yay' or 'n

Definition at line 175 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1401,7 +1498,7 @@ Lines from the IRCd awaiting processing are stored here. Upgraded april 2005, ol

Definition at line 195 of file users.h.

-Referenced by AddBuffer(), BufferIsReady(), ClearBuffer(), GetBuffer(), and userrec(). +Referenced by AddBuffer(), BufferIsReady(), ClearBuffer(), GetBuffer(), and userrec().

@@ -1429,7 +1526,7 @@ Maximum size this user's recvq can become.

Definition at line 218 of file users.h.

-Referenced by AddBuffer(). +Referenced by AddBuffer().

@@ -1455,7 +1552,7 @@ Referenced by AddBuffer()

Definition at line 205 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1483,7 +1580,7 @@ You may use this to increase the speed of use of this class.

Definition at line 156 of file users.h.

-Referenced by GetFullHost(), GetFullRealHost(), and userrec(). +Referenced by GetFullHost(), GetFullRealHost(), and userrec().

@@ -1511,7 +1608,7 @@ Lines waiting to be sent are stored here until their buffer is flushed.

Definition at line 200 of file users.h.

-Referenced by AddWriteBuf(), FlushWriteBuf(), and userrec(). +Referenced by AddWriteBuf(), FlushWriteBuf(), and userrec().

@@ -1539,7 +1636,7 @@ Maximum size this user's sendq can become.

Definition at line 214 of file users.h.

-Referenced by AddWriteBuf(). +Referenced by AddWriteBuf().

@@ -1567,7 +1664,7 @@ The server the user is connected to.

Definition at line 146 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1619,7 +1716,7 @@ Number of seconds this user is given to send USER/NICK If they do not send their

Definition at line 168 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1645,12 +1742,12 @@ Referenced by userrec().

Definition at line 210 of file users.h.

-Referenced by GetWriteError(), and SetWriteError(). +Referenced by GetWriteError(), and SetWriteError().


The documentation for this class was generated from the following files: -
Generated on Sun May 15 18:39:14 2005 for InspIRCd by +
Generated on Tue May 24 02:32:48 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classuserrec__coll__graph.gif b/docs/module-doc/classuserrec__coll__graph.gif index d3f4813c3..60ce17f24 100644 Binary files a/docs/module-doc/classuserrec__coll__graph.gif and b/docs/module-doc/classuserrec__coll__graph.gif differ diff --git a/docs/module-doc/commands_8h-source.html b/docs/module-doc/commands_8h-source.html index 77ed0214e..827dbc081 100644 --- a/docs/module-doc/commands_8h-source.html +++ b/docs/module-doc/commands_8h-source.html @@ -86,39 +86,40 @@ 00081 void handle_server(char **parameters, int pcnt, userrec *user); 00082 void handle_loadmodule(char **parameters, int pcnt, userrec *user); 00083 void handle_unloadmodule(char **parameters, int pcnt, userrec *user); -00084 -00087 void handle_link_packet(char* tcp_msg, char* tcp_host, serverrec *serv, char* tcp_sum); -00088 void process_restricted_commands(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host,char* ipaddr,int port, char* tcp_sum); -00089 -00092 void handle_amp(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00093 void handle_dollar(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00094 void handle_J(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00095 void handle_R(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00096 void handle_plus(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00097 void handle_b(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00098 void handle_a(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00099 void handle_F(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00100 void handle_N(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00101 void handle_AT(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00102 void handle_k(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00103 void handle_n(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00104 void handle_Q(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00105 void handle_K(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00106 void handle_L(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00107 void handle_m(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00108 void handle_M(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00109 void handle_T(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00110 void handle_t(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00111 void handle_i(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00112 void handle_P(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00113 void handle_V(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); -00114 -00117 bool is_uline(const char* server); -00118 -00121 long duration(const char* str); -00122 -00123 #endif -

Generated on Sun May 15 18:36:01 2005 for InspIRCd by +00084 void handle_commands(char **parameters, int pcnt, userrec *user); +00085 +00088 void handle_link_packet(char* tcp_msg, char* tcp_host, serverrec *serv, char* tcp_sum); +00089 void process_restricted_commands(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host,char* ipaddr,int port, char* tcp_sum); +00090 +00093 void handle_amp(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00094 void handle_dollar(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00095 void handle_J(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00096 void handle_R(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00097 void handle_plus(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00098 void handle_b(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00099 void handle_a(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00100 void handle_F(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00101 void handle_N(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00102 void handle_AT(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00103 void handle_k(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00104 void handle_n(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00105 void handle_Q(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00106 void handle_K(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00107 void handle_L(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00108 void handle_m(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00109 void handle_M(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00110 void handle_T(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00111 void handle_t(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00112 void handle_i(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00113 void handle_P(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00114 void handle_V(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum); +00115 +00118 bool is_uline(const char* server); +00119 +00122 long duration(const char* str); +00123 +00124 #endif +

Generated on Tue May 24 02:30:02 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/commands_8h.html b/docs/module-doc/commands_8h.html index af4d8d8c9..d2475883b 100644 --- a/docs/module-doc/commands_8h.html +++ b/docs/module-doc/commands_8h.html @@ -132,65 +132,67 @@ This graph shows which files directly or indirectly include this file:

void handle_unloadmodule (char **parameters, int pcnt, userrec *user) -void handle_link_packet (char *tcp_msg, char *tcp_host, serverrec *serv, char *tcp_sum) +void handle_commands (char **parameters, int pcnt, userrec *user) - Special functions for processing server to server traffic.

-void process_restricted_commands (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *ipaddr, int port, char *tcp_sum) +void handle_link_packet (char *tcp_msg, char *tcp_host, serverrec *serv, char *tcp_sum) -void handle_amp (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) + Special functions for processing server to server traffic.


+void process_restricted_commands (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *ipaddr, int port, char *tcp_sum) - These are the handlers for server commands (tokens).


-void handle_dollar (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_amp (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_J (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) + These are the handlers for server commands (tokens).


+void handle_dollar (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_R (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_J (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_plus (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_R (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_b (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_plus (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_a (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_b (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_F (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_a (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_N (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_F (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_AT (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_N (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_k (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_AT (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_n (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_k (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_Q (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_n (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_K (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_Q (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_L (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_K (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_m (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_L (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_M (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_m (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_T (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_M (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_t (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_T (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_i (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_t (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_P (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_i (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_V (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) +void handle_P (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -bool is_uline (const char *server) +void handle_V (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) - Functions for u:lined servers.


-long duration (const char *str) +bool is_uline (const char *server) - Other useful functions.


+ Functions for u:lined servers.


+long duration (const char *str) + + Other useful functions.



Function Documentation

-

+

+Referenced by Server::AddELine(), Server::AddGLine(), Server::AddKLine(), Server::AddQLine(), Server::AddZLine(), and Server::CalcDuration().
@@ -220,10 +222,10 @@ Other useful functions.

-Referenced by Server::AddELine(), Server::AddGLine(), Server::AddKLine(), Server::AddQLine(), Server::AddZLine(), and Server::CalcDuration().

-

+

@@ -329,7 +331,7 @@ Referenced by Server::AddEL
-

+

@@ -393,7 +395,7 @@ These are the handlers for server commands (tokens).
-

+

@@ -499,7 +501,7 @@ These are the handlers for server commands (tokens).
-

+

+ +
@@ -557,6 +559,50 @@ These are the handlers for server commands (tokens). +

+

+

+ + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + +
void handle_commands char **  parameters,
int  pcnt,
userrec user
+
+ + + + @@ -649,7 +695,7 @@ These are the handlers for server commands (tokens).
+   + +

-

+

@@ -755,7 +801,7 @@ These are the handlers for server commands (tokens).
-

+

@@ -861,7 +907,7 @@ These are the handlers for server commands (tokens).
-

+

@@ -1055,7 +1101,7 @@ These are the handlers for server commands (tokens).
-

+

@@ -1163,7 +1209,7 @@ These are the handlers for user commands.
-

+

@@ -1225,7 +1271,7 @@ These are the handlers for user commands.
-

+

@@ -1419,7 +1465,7 @@ These are the handlers for user commands.
-

+

@@ -1481,7 +1527,7 @@ These are the handlers for user commands.
-

+

@@ -1709,7 +1755,7 @@ Special functions for processing server to server traffic.
-

+

@@ -1771,7 +1817,7 @@ Special functions for processing server to server traffic.
-

+

@@ -1965,7 +2011,7 @@ Special functions for processing server to server traffic.
-

+

@@ -2027,7 +2073,7 @@ Special functions for processing server to server traffic.
-

+

@@ -2265,7 +2311,7 @@ Special functions for processing server to server traffic.
-

+

@@ -2459,7 +2505,7 @@ Special functions for processing server to server traffic.
-

+

@@ -2609,7 +2655,7 @@ Special functions for processing server to server traffic.
-

+

@@ -2759,7 +2805,7 @@ Special functions for processing server to server traffic.
-

+

@@ -3129,7 +3175,7 @@ Special functions for processing server to server traffic.
-

+

@@ -3191,7 +3237,7 @@ Special functions for processing server to server traffic.
-

+

@@ -3561,7 +3607,7 @@ Special functions for processing server to server traffic.
-

+

@@ -3843,7 +3889,7 @@ Special functions for processing server to server traffic.
-

+

+Referenced by Server::IsUlined().
@@ -3873,10 +3919,10 @@ Functions for u:lined servers.

-Referenced by Server::IsUlined().

-

+

@@ -3950,7 +3996,7 @@ Referenced by Server::IsUli
-


Generated on Sun May 15 18:36:40 2005 for InspIRCd by +
Generated on Tue May 24 02:30:38 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/connection_8h-source.html b/docs/module-doc/connection_8h-source.html index 243488ec6..1767f150f 100644 --- a/docs/module-doc/connection_8h-source.html +++ b/docs/module-doc/connection_8h-source.html @@ -65,116 +65,120 @@ 00083 00086 std::string version; 00087 -00088 public: -00089 -00094 std::string ircdbuffer; +00090 std::string sendq; +00091 +00094 std::string WriteError; 00095 -00096 -00101 char host[MAXBUF]; -00102 -00107 int port; -00108 -00113 std::vector<std::string> routes; -00114 -00115 -00118 bool MakeOutboundConnection(char* newhost, int newport); -00119 -00122 std::string GetServerName(); -00123 -00126 void SetServerName(std::string serv); -00127 -00130 int GetDescriptor(); -00131 -00134 void SetDescriptor(int fd); -00135 -00138 int GetState(); -00139 -00142 void SetState(int state); -00143 -00146 char* GetServerIP(); -00147 -00150 std::string GetDescription(); -00151 -00154 void SetDescription(std::string desc); -00155 -00161 int GetServerPort(); +00098 time_t nextping; +00099 +00102 bool replied; +00103 +00104 public: +00105 +00110 std::string ircdbuffer; +00111 +00112 +00117 char host[MAXBUF]; +00118 +00123 int port; +00124 +00129 std::vector<std::string> routes; +00130 +00133 ircd_connector(); +00134 +00137 bool MakeOutboundConnection(char* newhost, int newport); +00138 +00141 std::string GetServerName(); +00142 +00145 void SetServerName(std::string serv); +00146 +00149 int GetDescriptor(); +00150 +00153 void SetDescriptor(int fd); +00154 +00157 int GetState(); +00158 +00161 void SetState(int state); 00162 -00165 void SetServerPort(int p); +00165 char* GetServerIP(); 00166 -00169 bool SetHostAndPort(char* newhost, int newport); +00169 std::string GetDescription(); 00170 -00174 void CloseConnection(); -00175 -00181 void AddBuffer(std::string a); -00182 -00187 bool BufferIsComplete(); -00188 -00191 void ClearBuffer(); -00192 -00197 std::string GetBuffer(); -00198 -00201 void SetVersionString(std::string newversion); -00202 -00206 std::string GetVersionString(); -00207 }; -00208 -00209 -00212 class connection : public Extensible -00213 { -00214 public: -00217 int fd; -00218 -00221 char host[160]; -00222 -00225 char ip[16]; -00226 -00229 long bytes_in; +00173 void SetDescription(std::string desc); +00174 +00180 int GetServerPort(); +00181 +00184 void SetServerPort(int p); +00185 +00188 bool SetHostAndPort(char* newhost, int newport); +00189 +00193 void CloseConnection(); +00194 +00199 bool AddBuffer(std::string a); +00200 +00205 bool BufferIsComplete(); +00206 +00209 void ClearBuffer(); +00210 +00215 std::string GetBuffer(); +00216 +00219 void SetVersionString(std::string newversion); +00220 +00224 std::string GetVersionString(); +00225 +00229 bool AddWriteBuf(std::string data); 00230 -00233 long bytes_out; -00234 -00237 long cmds_in; -00238 -00241 long cmds_out; -00242 -00245 bool haspassed; -00246 -00251 int port; -00252 -00255 char registered; -00256 -00259 time_t lastping; -00260 -00263 time_t signon; -00264 -00267 time_t idle_lastmsg; -00268 -00271 time_t nping; -00272 -00276 std::vector<ircd_connector> connectors; -00277 -00280 connection(); -00281 -00284 bool CreateListener(char* host, int p); -00285 -00288 bool BeginLink(char* targethost, int port, char* password, char* servername, int myport); -00289 -00292 bool MeshCookie(char* targethost, int port, unsigned long cookie, char* servername); -00293 -00296 void TerminateLink(char* targethost); -00297 -00301 bool SendPacket(char *message, const char* host); -00302 -00307 bool RecvPacket(std::deque<std::string> &messages, char* host, std::deque<std::string> &sums); -00308 -00311 ircd_connector* FindHost(std::string host); -00312 -00316 bool AddIncoming(int fd,char* targethost, int sourceport); +00234 bool FlushWriteBuf(); +00235 +00238 void SetWriteError(std::string error); +00239 +00242 std::string GetWriteError(); +00243 +00246 bool HasBufferedOutput(); +00247 +00251 bool CheckPing(); +00252 +00255 void ResetPing(); +00256 }; +00257 +00258 +00261 class connection : public Extensible +00262 { +00263 public: +00266 int fd; +00267 +00270 char host[160]; +00271 +00274 char ip[16]; +00275 +00278 int bytes_in; +00279 +00282 int bytes_out; +00283 +00286 int cmds_in; +00287 +00290 int cmds_out; +00291 +00294 bool haspassed; +00295 +00300 int port; +00301 +00304 char registered; +00305 +00308 time_t lastping; +00309 +00312 time_t signon; +00313 +00316 time_t idle_lastmsg; 00317 -00318 }; -00319 -00320 -00321 #endif -

Generated on Sun May 15 18:36:01 2005 for InspIRCd by +00320 time_t nping; +00321 +00324 connection(); +00325 }; +00326 +00327 +00328 #endif +

Generated on Tue May 24 02:30:02 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/connection_8h.html b/docs/module-doc/connection_8h.html index af85ae99d..2d718b681 100644 --- a/docs/module-doc/connection_8h.html +++ b/docs/module-doc/connection_8h.html @@ -29,10 +29,11 @@ Include dependency graph for connection.h:

Included by dependency graph
- + - + +

@@ -84,7 +85,9 @@ This graph shows which files directly or indirectly include this file:

-Definition at line 36 of file connection.h. +Definition at line 36 of file connection.h. +

+Referenced by serverrec::MeshCookie().

@@ -108,7 +111,9 @@ Definition at line 36

-Definition at line 35 of file connection.h. +Definition at line 35 of file connection.h. +

+Referenced by serverrec::BeginLink(), serverrec::FlushWriteBuffers(), serverrec::MeshCookie(), serverrec::RecvPacket(), and serverrec::SendPacket().

@@ -132,7 +137,9 @@ Definition at line 35

-Definition at line 38 of file connection.h. +Definition at line 38 of file connection.h. +

+Referenced by serverrec::AddIncoming().

@@ -156,7 +163,9 @@ Definition at line 38

-Definition at line 39 of file connection.h. +Definition at line 39 of file connection.h. +

+Referenced by serverrec::BeginLink(), and serverrec::MeshCookie().

@@ -236,7 +245,7 @@ Definition at line 37 -


Generated on Sun May 15 18:36:47 2005 for InspIRCd by +
Generated on Tue May 24 02:30:42 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/connection_8h__dep__incl.gif b/docs/module-doc/connection_8h__dep__incl.gif index e848401f9..2df9e0a05 100644 Binary files a/docs/module-doc/connection_8h__dep__incl.gif and b/docs/module-doc/connection_8h__dep__incl.gif differ diff --git a/docs/module-doc/ctables_8h-source.html b/docs/module-doc/ctables_8h-source.html index 87143b063..c4687a31a 100644 --- a/docs/module-doc/ctables_8h-source.html +++ b/docs/module-doc/ctables_8h-source.html @@ -42,7 +42,7 @@ 00051 00052 #endif 00053 -

Generated on Sun May 15 18:36:01 2005 for InspIRCd by +

Generated on Tue May 24 02:30:02 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/ctables_8h.html b/docs/module-doc/ctables_8h.html index a236f69ec..d0145641c 100644 --- a/docs/module-doc/ctables_8h.html +++ b/docs/module-doc/ctables_8h.html @@ -31,7 +31,7 @@ This graph shows which files directly or indirectly include this file:

 A structure that defines a command. More...

-
Generated on Sun May 15 18:36:49 2005 for InspIRCd by +
Generated on Tue May 24 02:30:44 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/dns_8h-source.html b/docs/module-doc/dns_8h-source.html index 135072684..4fd4dd82c 100644 --- a/docs/module-doc/dns_8h-source.html +++ b/docs/module-doc/dns_8h-source.html @@ -70,7 +70,7 @@ 00093 }; 00094 00095 #endif -

Generated on Sun May 15 18:36:01 2005 for InspIRCd by +

Generated on Tue May 24 02:30:02 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/dns_8h.html b/docs/module-doc/dns_8h.html index 4b381cca6..50e0dd7e1 100644 --- a/docs/module-doc/dns_8h.html +++ b/docs/module-doc/dns_8h.html @@ -23,7 +23,7 @@ Include dependency graph for dns.h:

struct  dns_ip4list -
Generated on Sun May 15 18:36:50 2005 for InspIRCd by +
Generated on Tue May 24 02:30:45 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/files.html b/docs/module-doc/files.html index a0bb4c52e..a80461590 100644 --- a/docs/module-doc/files.html +++ b/docs/module-doc/files.html @@ -24,7 +24,7 @@ users.h [code] xline.h [code] -
Generated on Sun May 15 18:36:01 2005 for InspIRCd by +
Generated on Tue May 24 02:30:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/functions.html b/docs/module-doc/functions.html index ef133b2bf..050119272 100644 --- a/docs/module-doc/functions.html +++ b/docs/module-doc/functions.html @@ -14,18 +14,18 @@ Here is a list of all class members with links to the classes they belong to:

- a -

- d - @@ -127,23 +129,24 @@ Here is a list of all class members with links to the classes they belong to:

irc::irc_char_traits
  • FindChannel() : Server
  • FindDescriptor() : Server
  • FindHost() -: connection
  • FindModule() +: serverrec
  • FindModule() : Server
  • FindNick() : Server
  • Flags : Version
  • flags_needed : command_t
  • flood : userrec, ConnectClass
  • FlushWriteBuf() -: userrec
  • ForwardLookup() +: userrec, ircd_connector
  • FlushWriteBuffers() +: serverrec
  • ForwardLookup() : DNS
  • fullname : WhoWasUser, userrec

    - g -

    +: ircd_connector
  • GetWriteError() +: userrec, ircd_connector

    - h -

    - c -

    - d -

    - g -

    +: ircd_connector
  • GetWriteError() +: userrec, ircd_connector

    - h -

    - i -

    - u -

    -
    Generated on Sun May 15 18:37:37 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:27 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/functions_vars.html b/docs/module-doc/functions_vars.html index ebcfedc66..984002521 100644 --- a/docs/module-doc/functions_vars.html +++ b/docs/module-doc/functions_vars.html @@ -35,7 +35,7 @@ : connection
  • cmds_out : connection
  • command : command_t
  • connectors -: connection
  • created +: serverrec
  • created : chanrec
  • custom_modes : chanrec

    - d - @@ -114,7 +114,8 @@ : Admin
  • name : serverrec, chanrec
  • needsoper : ExtMode
  • next -: dns_ip4list
  • Nick +: dns_ip4list
  • nextping +: ircd_connector
  • Nick : Admin
  • nick : QLine, WhoWasUser, userrec
  • nickserv : serverrec
  • nping @@ -143,7 +144,8 @@ : userrec
  • recvqmax : userrec, ConnectClass
  • registered : connection
  • registration_timeout -: ConnectClass
  • reset_due +: ConnectClass
  • replied +: ircd_connector
  • reset_due : userrec
  • result : userrec, DNS
  • Revision : Version
  • routes @@ -151,7 +153,7 @@

    - s -

    +
    Generated on Tue May 24 02:31:27 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals.html b/docs/module-doc/globals.html index 909e26c1e..3284639d7 100644 --- a/docs/module-doc/globals.html +++ b/docs/module-doc/globals.html @@ -6,7 +6,7 @@ -
    a | b | c | d | e | f | g | h | i | l | m | n | p | q | r | s | t | u | v | w | z
    +
    a | b | c | d | e | f | g | h | i | l | m | n | p | q | r | s | t | u | v | w | x | z

    @@ -32,61 +32,62 @@ Here is a list of all file members with links to the files they belong to:

    xline.h
  • add_qline() : xline.h
  • add_zline() : xline.h
  • address_cache -: modules.cpp
  • AdminEmail +: modules.cpp
  • AdminEmail : modules.cpp, channels.cpp
  • AdminName : modules.cpp, channels.cpp
  • AdminNick : modules.cpp, channels.cpp
  • allowed_umode() -: mode.h
  • apply_lines() +: mode.h
  • already_have_sum() +: servers.cpp
  • apply_lines() : xline.h
  • auth_cookies -: modules.cpp, channels.cpp +: modules.cpp, channels.cpp

    - b -

    +: message.h
  • boundPortCount +: modules.cpp, channels.cpp

    - c -

    +: message.h
  • custom_mode_params +: channels.cpp

    - d -

    +: modules.cpp
  • duration() +: commands.h

    - e -

    +: modules.cpp
  • ExtModeListIter +: modules.cpp

    - f -

    @@ -125,66 +125,67 @@ Here is a list of all file members with links to the files they belong to:

    - h -

    +: message.h
  • hasumode() +: message.h

    - i -

    +: commands.h
  • isident() +: message.h
  • isnick() +: message.h

    - l -

    - m -

    @@ -251,18 +253,18 @@ Here is a list of all file members with links to the files they belong to:

    modules.cpp, channels.cpp
  • NetBufferSize : modules.cpp, channels.cpp
  • Network : modules.cpp, channels.cpp
  • NonBlocking() -: message.h
  • NONE +: message.h
  • NONE : modules.h
  • nspace : hashcomp.h, channels.cpp

    - p -

    +: commands.h

    - q -

    +: modules.cpp

    - s -

    +: users.cpp, servers.cpp, modules.cpp, channels.cpp

    - u -

    +: modules.cpp

    - v -

    -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_func.html b/docs/module-doc/globals_func.html index cc96c816f..cf17c00b5 100644 --- a/docs/module-doc/globals_func.html +++ b/docs/module-doc/globals_func.html @@ -20,26 +20,27 @@ : xline.h
  • add_qline() : xline.h
  • add_zline() : xline.h
  • allowed_umode() -: mode.h
  • apply_lines() +: mode.h
  • already_have_sum() +: servers.cpp
  • apply_lines() : xline.h

    - b -

    +: message.h

    - c -

    +: message.h

    - d -

    +: modules.cpp
  • duration() +: commands.h

    - e -

    - g -

    - i -

    +: commands.h
  • isident() +: message.h
  • isnick() +: message.h

    - m -

    +: modules.cpp
  • ModeDefinedOff() +: modules.cpp
  • ModeDefinedOn() +: modules.cpp
  • ModeDefinedOper() +: modules.cpp
  • ModeIsListMode() +: modules.cpp
  • ModeMakeList() +: modules.cpp
  • modules() +: modules.cpp, channels.cpp

    - n -

    +: message.h

    - p -

    +: commands.h

    - q -

    • qline_make_global() @@ -188,9 +190,8 @@ : xline.h

    - s -

    - z -

    -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_type.html b/docs/module-doc/globals_type.html index 2f045235c..d3bf5b35b 100644 --- a/docs/module-doc/globals_type.html +++ b/docs/module-doc/globals_type.html @@ -10,24 +10,24 @@

    -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +: modules.cpp +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_vars.html b/docs/module-doc/globals_vars.html index 71a8c6db3..e3b1e0065 100644 --- a/docs/module-doc/globals_vars.html +++ b/docs/module-doc/globals_vars.html @@ -6,7 +6,7 @@ -
    a | b | c | d | e | f | i | l | m | n | p | r | s | t | w
    +
    a | b | c | d | e | f | i | l | m | n | p | r | s | t | w | x

    @@ -17,57 +17,57 @@ : modules.cpp, channels.cpp

  • AdminName : modules.cpp, channels.cpp
  • AdminNick : modules.cpp, channels.cpp
  • auth_cookies -: modules.cpp, channels.cpp +: modules.cpp, channels.cpp

    - b -

    +: modules.cpp, channels.cpp

    - c -

    +: modules.cpp
  • clientlist +: modules.cpp
  • cmdlist +: modules.cpp
  • config_f +: users.cpp, modules.cpp, channels.cpp
  • custom_mode_params +: channels.cpp

    - d -

    - e -

    +: modules.cpp

    - f -

    +: modules.cpp, channels.cpp
  • fd_ref_table +: modules.cpp

    - i -

    +: modules.cpp

    - l -

    - m -

    +: modules.cpp

    - n -

    - s -

    - t -

    +: users.cpp, servers.cpp, modules.cpp, channels.cpp

    - w -

    -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +

    - x - +

    +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/graph_legend.html b/docs/module-doc/graph_legend.html index c7458dd2c..a97d98270 100644 --- a/docs/module-doc/graph_legend.html +++ b/docs/module-doc/graph_legend.html @@ -67,7 +67,7 @@ A purple dashed arrow is used if a class is contained or used by another class.
  • A yellow dashed arrow denotes a relation between a template instance and the template class it was instantiated from. The arrow is labeled with the template parameters of the instance.
  • -
    Generated on Sun May 15 18:39:29 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/hashcomp_8h-source.html b/docs/module-doc/hashcomp_8h-source.html index 0872e69c6..12ddc30d8 100644 --- a/docs/module-doc/hashcomp_8h-source.html +++ b/docs/module-doc/hashcomp_8h-source.html @@ -26,73 +26,88 @@ 00019 00020 #include "inspircd_config.h" 00021 -00022 #ifdef GCC3 -00023 #include <ext/hash_map> -00024 #else -00025 #include <hash_map> -00026 #endif -00027 -00028 #ifdef GCC3 -00029 #define nspace __gnu_cxx -00030 #else -00031 #define nspace std -00032 #endif -00033 -00034 using namespace std; -00035 -00036 namespace nspace -00037 { -00038 #ifdef GCC34 -00039 template<> struct hash<in_addr> -00040 #else -00041 template<> struct nspace::hash<in_addr> -00042 #endif -00043 { -00044 size_t operator()(const struct in_addr &a) const; -00045 }; -00046 #ifdef GCC34 -00047 template<> struct hash<string> -00048 #else -00049 template<> struct nspace::hash<string> -00050 #endif -00051 { -00052 size_t operator()(const string &s) const; -00053 }; -00054 } -00055 -00058 namespace irc -00059 { -00060 -00065 struct StrHashComp +00022 /******************************************************* +00023 * This file contains classes and templates that deal +00024 * with the comparison and hashing of 'irc strings'. +00025 * An 'irc string' is a string which compares in a +00026 * case insensitive manner, and as per RFC 1459 will +00027 * treat [ identical to {, ] identical to }, and \ +00028 * as identical to |. +00029 * +00030 * Our hashing functions are designed to accept +00031 * std::string and compare/hash them as type irc::string +00032 * by converting them internally. This makes them +00033 * backwards compatible with other code which is not +00034 * aware of irc::string. +00035 *******************************************************/ +00036 +00037 #ifdef GCC3 +00038 #include <ext/hash_map> +00039 #else +00040 #include <hash_map> +00041 #endif +00042 +00043 #ifdef GCC3 +00044 #define nspace __gnu_cxx +00045 #else +00046 #define nspace std +00047 #endif +00048 +00049 using namespace std; +00050 +00051 namespace nspace +00052 { +00053 #ifdef GCC34 +00054 template<> struct hash<in_addr> +00055 #else +00056 template<> struct nspace::hash<in_addr> +00057 #endif +00058 { +00059 size_t operator()(const struct in_addr &a) const; +00060 }; +00061 #ifdef GCC34 +00062 template<> struct hash<string> +00063 #else +00064 template<> struct nspace::hash<string> +00065 #endif 00066 { -00069 bool operator()(const std::string& s1, const std::string& s2) const; -00070 }; -00071 -00072 -00077 struct InAddr_HashComp -00078 { -00081 bool operator()(const in_addr &s1, const in_addr &s2) const; -00082 }; -00083 -00084 -00089 struct irc_char_traits : std::char_traits<char> { -00090 -00093 static bool eq(char c1st, char c2nd); -00094 -00097 static bool ne(char c1st, char c2nd); +00067 size_t operator()(const string &s) const; +00068 }; +00069 } +00070 +00073 namespace irc +00074 { +00075 +00080 struct StrHashComp +00081 { +00084 bool operator()(const std::string& s1, const std::string& s2) const; +00085 }; +00086 +00087 +00092 struct InAddr_HashComp +00093 { +00096 bool operator()(const in_addr &s1, const in_addr &s2) const; +00097 }; 00098 -00101 static bool lt(char c1st, char c2nd); -00102 -00105 static int compare(const char* str1, const char* str2, size_t n); -00106 -00109 static const char* find(const char* s1, int n, char c); -00110 }; -00111 -00114 typedef basic_string<char, irc_char_traits, allocator<char> > string; -00115 } -00116 -00117 #endif -


  • Generated on Sun May 15 18:36:01 2005 for InspIRCd by +00099 +00104 struct irc_char_traits : std::char_traits<char> { +00105 +00108 static bool eq(char c1st, char c2nd); +00109 +00112 static bool ne(char c1st, char c2nd); +00113 +00116 static bool lt(char c1st, char c2nd); +00117 +00120 static int compare(const char* str1, const char* str2, size_t n); +00121 +00124 static const char* find(const char* s1, int n, char c); +00125 }; +00126 +00129 typedef basic_string<char, irc_char_traits, allocator<char> > string; +00130 } +00131 +00132 #endif +

    Generated on Tue May 24 02:30:02 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/hashcomp_8h.html b/docs/module-doc/hashcomp_8h.html index 56c3f5107..8d7cfa156 100644 --- a/docs/module-doc/hashcomp_8h.html +++ b/docs/module-doc/hashcomp_8h.html @@ -51,10 +51,10 @@ This graph shows which files directly or indirectly include this file:

    -Definition at line 29 of file hashcomp.h. +Definition at line 44 of file hashcomp.h. -


    Generated on Sun May 15 18:36:51 2005 for InspIRCd by +
    Generated on Tue May 24 02:30:47 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/hierarchy.html b/docs/module-doc/hierarchy.html index 24f05e557..7ca7a6ee1 100644 --- a/docs/module-doc/hierarchy.html +++ b/docs/module-doc/hierarchy.html @@ -65,7 +65,7 @@ This inheritance list is sorted roughly, but not completely, alphabetically: -
    Generated on Sun May 15 18:37:36 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:27 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/inherits.html b/docs/module-doc/inherits.html index a29b1d570..9079b86bb 100644 --- a/docs/module-doc/inherits.html +++ b/docs/module-doc/inherits.html @@ -78,7 +78,7 @@ -
    Generated on Sun May 15 18:39:35 2005 for InspIRCd by +
    Generated on Tue May 24 02:33:02 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/main.html b/docs/module-doc/main.html index 8269e4135..f62060115 100644 --- a/docs/module-doc/main.html +++ b/docs/module-doc/main.html @@ -7,7 +7,7 @@

    InspIRCd Documentation

    -

    1.0Betareleases


    Generated on Sun May 15 18:36:01 2005 for InspIRCd by +

    1.0Betareleases


    Generated on Tue May 24 02:30:01 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/message_8h-source.html b/docs/module-doc/message_8h-source.html index 54b6b118b..74bbb3cfa 100644 --- a/docs/module-doc/message_8h-source.html +++ b/docs/module-doc/message_8h-source.html @@ -38,26 +38,24 @@ 00031 int common_channels(userrec *u, userrec *u2); 00032 void chop(char* str); 00033 void tidystring(char* str); -00034 void safedelete(chanrec *p); -00035 void safedelete(userrec *p); -00036 void Blocking(int s); -00037 void NonBlocking(int s); -00038 int CleanAndResolve (char *resolvedHost, const char *unresolvedHost); -00039 int c_count(userrec* u); -00040 bool hasumode(userrec* user, char mode); -00041 void ChangeName(userrec* user, const char* gecos); -00042 void ChangeDisplayedHost(userrec* user, const char* host); -00043 int isident(const char* n); -00044 int isnick(const char* n); -00045 char* cmode(userrec *user, chanrec *chan); -00046 int cstatus(userrec *user, chanrec *chan); -00047 int has_channel(userrec *u, chanrec *c); -00048 void TidyBan(char *ban); -00049 char* chlist(userrec *user, userrec* source); -00050 void send_network_quit(const char* nick, const char* reason); -00051 -00052 #endif -

    Generated on Sun May 15 18:36:01 2005 for InspIRCd by +00034 void Blocking(int s); +00035 void NonBlocking(int s); +00036 int CleanAndResolve (char *resolvedHost, const char *unresolvedHost); +00037 int c_count(userrec* u); +00038 bool hasumode(userrec* user, char mode); +00039 void ChangeName(userrec* user, const char* gecos); +00040 void ChangeDisplayedHost(userrec* user, const char* host); +00041 int isident(const char* n); +00042 int isnick(const char* n); +00043 char* cmode(userrec *user, chanrec *chan); +00044 int cstatus(userrec *user, chanrec *chan); +00045 int has_channel(userrec *u, chanrec *c); +00046 void TidyBan(char *ban); +00047 char* chlist(userrec *user, userrec* source); +00048 void send_network_quit(const char* nick, const char* reason); +00049 +00050 #endif +

    Generated on Tue May 24 02:30:03 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/message_8h.html b/docs/module-doc/message_8h.html index d1aeaeb2a..667050117 100644 --- a/docs/module-doc/message_8h.html +++ b/docs/module-doc/message_8h.html @@ -38,43 +38,39 @@ This graph shows which files directly or indirectly include this file:

    void tidystring (char *str) -void safedelete (chanrec *p) +void Blocking (int s) -void safedelete (userrec *p) +void NonBlocking (int s) -void Blocking (int s) +int CleanAndResolve (char *resolvedHost, const char *unresolvedHost) -void NonBlocking (int s) +int c_count (userrec *u) -int CleanAndResolve (char *resolvedHost, const char *unresolvedHost) +bool hasumode (userrec *user, char mode) -int c_count (userrec *u) +void ChangeName (userrec *user, const char *gecos) -bool hasumode (userrec *user, char mode) +void ChangeDisplayedHost (userrec *user, const char *host) -void ChangeName (userrec *user, const char *gecos) +int isident (const char *n) -void ChangeDisplayedHost (userrec *user, const char *host) +int isnick (const char *n) -int isident (const char *n) +char * cmode (userrec *user, chanrec *chan) -int isnick (const char *n) +int cstatus (userrec *user, chanrec *chan) -char * cmode (userrec *user, chanrec *chan) +int has_channel (userrec *u, chanrec *c) -int cstatus (userrec *user, chanrec *chan) +void TidyBan (char *ban) -int has_channel (userrec *u, chanrec *c) +char * chlist (userrec *user, userrec *source) -void TidyBan (char *ban) - -char * chlist (userrec *user, userrec *source) - -void send_network_quit (const char *nick, const char *reason) +void send_network_quit (const char *nick, const char *reason)

    Function Documentation

    -

    +

    @@ -103,7 +99,7 @@ This graph shows which files directly or indirectly include this file:

    -

    +

    @@ -132,7 +128,7 @@ This graph shows which files directly or indirectly include this file:

    -

    +

    +Referenced by Server::ChangeHost().
    @@ -169,10 +165,10 @@ This graph shows which files directly or indirectly include this file:

    -Referenced by Server::ChangeHost().

    -

    +

    +Referenced by Server::ChangeGECOS().
    @@ -209,10 +205,10 @@ Referenced by Server::Chang

    -Referenced by Server::ChangeGECOS().

    -

    +

    @@ -279,7 +275,7 @@ Referenced by Server::Chang
    -

    +

    @@ -317,7 +313,7 @@ Referenced by Server::Chang
    -

    +

    +Referenced by Server::ChanMode().
    @@ -354,7 +350,7 @@ Referenced by Server::Chang

    -Referenced by Server::ChanMode().

    @@ -394,10 +390,10 @@ Referenced by Server::ChanM

    -Referenced by Server::CommonChannels(). +Referenced by Server::CommonChannels(). -

    +

    @@ -435,7 +431,7 @@ Referenced by Server::Commo
    -

    +

    +Referenced by Server::IsOnChannel().
    @@ -472,10 +468,10 @@ Referenced by Server::Commo

    -Referenced by Server::IsOnChannel().

    -

    +

    @@ -513,7 +509,7 @@ Referenced by Server::IsOnC
    -

    +

    @@ -542,7 +538,7 @@ Referenced by Server::IsOnC
    -

    +

    +Referenced by Server::IsNick().
    @@ -570,10 +566,10 @@ Referenced by Server::IsOnC

    -Referenced by Server::IsNick().

    -

    +

    @@ -602,65 +598,7 @@ Referenced by Server::IsNic
    -

    - - - - -
    - - - - - - - - - - -
    void safedelete userrec p  ) 
    -
    - - - - - -
    -   - - -

    -

    -

    - - - - -
    - - - - - - - - - - -
    void safedelete chanrec p  ) 
    -
    - - - - - -
    -   - - -

    -

    -

    +

    @@ -698,7 +636,7 @@ Referenced by Server::IsNic
    -

    +

    @@ -756,7 +694,7 @@ Referenced by Server::IsNic
    -


    Generated on Sun May 15 18:36:55 2005 for InspIRCd by +
    Generated on Tue May 24 02:30:50 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/mode_8h-source.html b/docs/module-doc/mode_8h-source.html index efa798faf..8ad0eae9b 100644 --- a/docs/module-doc/mode_8h-source.html +++ b/docs/module-doc/mode_8h-source.html @@ -53,7 +53,7 @@ 00046 00047 00048 #endif -

    Generated on Sun May 15 18:36:01 2005 for InspIRCd by +

    Generated on Tue May 24 02:30:03 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/mode_8h.html b/docs/module-doc/mode_8h.html index fb949957d..3cb474367 100644 --- a/docs/module-doc/mode_8h.html +++ b/docs/module-doc/mode_8h.html @@ -802,7 +802,7 @@ This graph shows which files directly or indirectly include this file:

    -
    Generated on Sun May 15 18:36:59 2005 for InspIRCd by +
    Generated on Tue May 24 02:30:53 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8cpp-source.html b/docs/module-doc/modules_8cpp-source.html index 10b371c07..8492f387e 100644 --- a/docs/module-doc/modules_8cpp-source.html +++ b/docs/module-doc/modules_8cpp-source.html @@ -21,989 +21,1009 @@ 00014 * --------------------------------------------------- 00015 */ 00016 -00017 #include "inspircd.h" -00018 #include "inspircd_io.h" -00019 #include "inspircd_util.h" -00020 #include "inspircd_config.h" -00021 #include <unistd.h> -00022 #include <sys/errno.h> -00023 #ifdef USE_KQUEUE -00024 #include <sys/types.h> -00025 #include <sys/event.h> -00026 #include <sys/time.h> -00027 #endif -00028 #include <time.h> -00029 #include <string> -00030 #ifdef GCC3 -00031 #include <ext/hash_map> -00032 #else -00033 #include <hash_map> +00017 using namespace std; +00018 +00019 #include "inspircd.h" +00020 #include "inspircd_io.h" +00021 #include "inspircd_util.h" +00022 #include "inspircd_config.h" +00023 #include <unistd.h> +00024 #include <sys/errno.h> +00025 +00026 #ifdef USE_KQUEUE +00027 #include <sys/types.h> +00028 #include <sys/event.h> +00029 #include <sys/time.h> +00030 #endif +00031 +00032 #ifdef USE_EPOLL +00033 #include <sys/epoll.h> 00034 #endif -00035 #include <map> -00036 #include <sstream> -00037 #include <vector> -00038 #include <deque> -00039 #include "connection.h" -00040 #include "users.h" -00041 #include "servers.h" -00042 #include "ctables.h" -00043 #include "globals.h" -00044 #include "modules.h" -00045 #include "dynamic.h" -00046 #include "wildcard.h" -00047 #include "message.h" -00048 #include "mode.h" -00049 #include "xline.h" -00050 #include "commands.h" -00051 #include "inspstring.h" -00052 #include "helperfuncs.h" -00053 #include "hashcomp.h" -00054 -00055 using namespace std; -00056 -00057 #ifdef USE_KQUEUE -00058 extern int kq; -00059 #endif -00060 -00061 extern int MODCOUNT; -00062 extern std::vector<Module*> modules; -00063 extern std::vector<ircd_module*> factory; -00064 -00065 extern time_t TIME; -00066 -00067 extern int LogLevel; -00068 extern char ServerName[MAXBUF]; -00069 extern char Network[MAXBUF]; -00070 extern char ServerDesc[MAXBUF]; -00071 extern char AdminName[MAXBUF]; -00072 extern char AdminEmail[MAXBUF]; -00073 extern char AdminNick[MAXBUF]; -00074 extern char diepass[MAXBUF]; -00075 extern char restartpass[MAXBUF]; -00076 extern char motd[MAXBUF]; -00077 extern char rules[MAXBUF]; -00078 extern char list[MAXBUF]; -00079 extern char PrefixQuit[MAXBUF]; -00080 extern char DieValue[MAXBUF]; -00081 -00082 extern int debugging; -00083 extern int WHOWAS_STALE; -00084 extern int WHOWAS_MAX; -00085 extern int DieDelay; -00086 extern time_t startup_time; -00087 extern int NetBufferSize; -00088 extern int MaxWhoResults; -00089 extern time_t nb_start; -00090 -00091 extern std::vector<int> fd_reap; -00092 extern std::vector<std::string> module_names; -00093 -00094 extern int boundPortCount; -00095 extern int portCount; -00096 extern int SERVERportCount; -00097 extern int ports[MAXSOCKS]; -00098 extern int defaultRoute; -00099 -00100 extern std::vector<long> auth_cookies; -00101 extern std::stringstream config_f; +00035 +00036 #include <time.h> +00037 #include <string> +00038 #ifdef GCC3 +00039 #include <ext/hash_map> +00040 #else +00041 #include <hash_map> +00042 #endif +00043 #include <map> +00044 #include <sstream> +00045 #include <vector> +00046 #include <deque> +00047 #include "connection.h" +00048 #include "users.h" +00049 #include "servers.h" +00050 #include "ctables.h" +00051 #include "globals.h" +00052 #include "modules.h" +00053 #include "dynamic.h" +00054 #include "wildcard.h" +00055 #include "message.h" +00056 #include "mode.h" +00057 #include "xline.h" +00058 #include "commands.h" +00059 #include "inspstring.h" +00060 #include "helperfuncs.h" +00061 #include "hashcomp.h" +00062 +00063 #ifdef USE_KQUEUE +00064 extern int kq; +00065 #endif +00066 +00067 #ifdef USE_EPOLL +00068 int ep; +00069 #endif +00070 +00071 extern int MODCOUNT; +00072 extern std::vector<Module*> modules; +00073 extern std::vector<ircd_module*> factory; +00074 +00075 extern time_t TIME; +00076 +00077 extern int LogLevel; +00078 extern char ServerName[MAXBUF]; +00079 extern char Network[MAXBUF]; +00080 extern char ServerDesc[MAXBUF]; +00081 extern char AdminName[MAXBUF]; +00082 extern char AdminEmail[MAXBUF]; +00083 extern char AdminNick[MAXBUF]; +00084 extern char diepass[MAXBUF]; +00085 extern char restartpass[MAXBUF]; +00086 extern char motd[MAXBUF]; +00087 extern char rules[MAXBUF]; +00088 extern char list[MAXBUF]; +00089 extern char PrefixQuit[MAXBUF]; +00090 extern char DieValue[MAXBUF]; +00091 +00092 extern int debugging; +00093 extern int WHOWAS_STALE; +00094 extern int WHOWAS_MAX; +00095 extern int DieDelay; +00096 extern time_t startup_time; +00097 extern int NetBufferSize; +00098 extern int MaxWhoResults; +00099 extern time_t nb_start; +00100 +00101 extern std::vector<std::string> module_names; 00102 -00103 extern serverrec* me[32]; -00104 -00105 extern FILE *log_file; -00106 -00107 extern userrec* fd_ref_table[65536]; +00103 extern int boundPortCount; +00104 extern int portCount; +00105 extern int SERVERportCount; +00106 extern int ports[MAXSOCKS]; +00107 extern int defaultRoute; 00108 -00109 typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, irc::StrHashComp> user_hash; -00110 typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, irc::StrHashComp> chan_hash; -00111 typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, irc::InAddr_HashComp> address_cache; -00112 typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, irc::StrHashComp> whowas_hash; -00113 typedef std::deque<command_t> command_table; -00114 +00109 extern std::vector<long> auth_cookies; +00110 extern std::stringstream config_f; +00111 +00112 extern serverrec* me[32]; +00113 +00114 extern FILE *log_file; 00115 -00116 extern user_hash clientlist; -00117 extern chan_hash chanlist; -00118 extern whowas_hash whowas; -00119 extern command_table cmdlist; -00120 extern file_cache MOTD; -00121 extern file_cache RULES; -00122 extern address_cache IP; +00116 extern userrec* fd_ref_table[65536]; +00117 +00118 typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, irc::StrHashComp> user_hash; +00119 typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, irc::StrHashComp> chan_hash; +00120 typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, irc::InAddr_HashComp> address_cache; +00121 typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, irc::StrHashComp> whowas_hash; +00122 typedef std::deque<command_t> command_table; 00123 00124 -00125 // class type for holding an extended mode character - internal to core -00126 -00127 class ExtMode : public classbase -00128 { -00129 public: -00130 char modechar; -00131 int type; -00132 int params_when_on; -00133 int params_when_off; -00134 bool needsoper; -00135 bool list; -00136 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) { }; -00137 }; -00138 -00139 typedef std::vector<ExtMode> ExtModeList; -00140 typedef ExtModeList::iterator ExtModeListIter; -00141 -00142 -00143 ExtModeList EMode; -00144 -00145 // returns true if an extended mode character is in use -00146 bool ModeDefined(char modechar, int type) -00147 { -00148 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00149 { -00150 if ((i->modechar == modechar) && (i->type == type)) -00151 { -00152 return true; -00153 } -00154 } -00155 return false; -00156 } -00157 -00158 bool ModeIsListMode(char modechar, int type) -00159 { -00160 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00161 { -00162 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) -00163 { -00164 return true; -00165 } -00166 } -00167 return false; -00168 } -00169 -00170 bool ModeDefinedOper(char modechar, int type) -00171 { -00172 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00173 { -00174 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) -00175 { -00176 return true; -00177 } -00178 } -00179 return false; -00180 } -00181 -00182 // returns number of parameters for a custom mode when it is switched on -00183 int ModeDefinedOn(char modechar, int type) -00184 { -00185 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00186 { -00187 if ((i->modechar == modechar) && (i->type == type)) -00188 { -00189 return i->params_when_on; -00190 } -00191 } -00192 return 0; -00193 } -00194 -00195 // returns number of parameters for a custom mode when it is switched on -00196 int ModeDefinedOff(char modechar, int type) -00197 { -00198 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00199 { -00200 if ((i->modechar == modechar) && (i->type == type)) -00201 { -00202 return i->params_when_off; -00203 } -00204 } -00205 return 0; -00206 } -00207 -00208 // returns true if an extended mode character is in use -00209 bool DoAddExtendedMode(char modechar, int type, bool requires_oper, int params_on, int params_off) -00210 { -00211 if (ModeDefined(modechar,type)) { -00212 return false; +00125 extern user_hash clientlist; +00126 extern chan_hash chanlist; +00127 extern whowas_hash whowas; +00128 extern command_table cmdlist; +00129 extern file_cache MOTD; +00130 extern file_cache RULES; +00131 extern address_cache IP; +00132 +00133 +00134 // class type for holding an extended mode character - internal to core +00135 +00136 class ExtMode : public classbase +00137 { +00138 public: +00139 char modechar; +00140 int type; +00141 int params_when_on; +00142 int params_when_off; +00143 bool needsoper; +00144 bool list; +00145 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) { }; +00146 }; +00147 +00148 typedef std::vector<ExtMode> ExtModeList; +00149 typedef ExtModeList::iterator ExtModeListIter; +00150 +00151 +00152 ExtModeList EMode; +00153 +00154 // returns true if an extended mode character is in use +00155 bool ModeDefined(char modechar, int type) +00156 { +00157 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00158 { +00159 if ((i->modechar == modechar) && (i->type == type)) +00160 { +00161 return true; +00162 } +00163 } +00164 return false; +00165 } +00166 +00167 bool ModeIsListMode(char modechar, int type) +00168 { +00169 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00170 { +00171 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) +00172 { +00173 return true; +00174 } +00175 } +00176 return false; +00177 } +00178 +00179 bool ModeDefinedOper(char modechar, int type) +00180 { +00181 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00182 { +00183 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) +00184 { +00185 return true; +00186 } +00187 } +00188 return false; +00189 } +00190 +00191 // returns number of parameters for a custom mode when it is switched on +00192 int ModeDefinedOn(char modechar, int type) +00193 { +00194 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00195 { +00196 if ((i->modechar == modechar) && (i->type == type)) +00197 { +00198 return i->params_when_on; +00199 } +00200 } +00201 return 0; +00202 } +00203 +00204 // returns number of parameters for a custom mode when it is switched on +00205 int ModeDefinedOff(char modechar, int type) +00206 { +00207 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00208 { +00209 if ((i->modechar == modechar) && (i->type == type)) +00210 { +00211 return i->params_when_off; +00212 } 00213 } -00214 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); -00215 return true; -00216 } -00217 -00218 // turns a mode into a listmode -00219 void ModeMakeList(char modechar) -00220 { -00221 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -00222 { -00223 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) -00224 { -00225 i->list = true; -00226 return; -00227 } -00228 } -00229 return; -00230 } -00231 -00232 // version is a simple class for holding a modules version number -00233 -00234 Version::Version(int major, int minor, int revision, int build, int flags) : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; -00235 -00236 // admin is a simple class for holding a server's administrative info -00237 -00238 Admin::Admin(std::string name, std::string email, std::string nick) : Name(name), Email(email), Nick(nick) { }; -00239 -00240 Request::Request(char* anydata, Module* src, Module* dst) : data(anydata), source(src), dest(dst) { }; -00241 -00242 char* Request::GetData() -00243 { -00244 return this->data; -00245 } +00214 return 0; +00215 } +00216 +00217 // returns true if an extended mode character is in use +00218 bool DoAddExtendedMode(char modechar, int type, bool requires_oper, int params_on, int params_off) +00219 { +00220 if (ModeDefined(modechar,type)) { +00221 return false; +00222 } +00223 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); +00224 return true; +00225 } +00226 +00227 // turns a mode into a listmode +00228 void ModeMakeList(char modechar) +00229 { +00230 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +00231 { +00232 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) +00233 { +00234 i->list = true; +00235 return; +00236 } +00237 } +00238 return; +00239 } +00240 +00241 // version is a simple class for holding a modules version number +00242 +00243 Version::Version(int major, int minor, int revision, int build, int flags) : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; +00244 +00245 // admin is a simple class for holding a server's administrative info 00246 -00247 Module* Request::GetSource() -00248 { -00249 return this->source; -00250 } -00251 -00252 Module* Request::GetDest() -00253 { -00254 return this->dest; -00255 } -00256 -00257 char* Request::Send() -00258 { -00259 if (this->dest) -00260 { -00261 return dest->OnRequest(this); -00262 } -00263 else -00264 { -00265 return NULL; -00266 } -00267 } -00268 -00269 Event::Event(char* anydata, Module* src, std::string eventid) : data(anydata), source(src), id(eventid) { }; -00270 -00271 char* Event::GetData() -00272 { -00273 return this->data; -00274 } -00275 -00276 Module* Event::GetSource() -00277 { -00278 return this->source; -00279 } -00280 -00281 char* Event::Send() -00282 { -00283 FOREACH_MOD OnEvent(this); -00284 return NULL; -00285 } -00286 -00287 std::string Event::GetEventID() -00288 { -00289 return this->id; -00290 } -00291 -00292 -00293 // These declarations define the behavours of the base class Module (which does nothing at all) -00294 Module::Module() { } -00295 Module::~Module() { } -00296 void Module::OnUserConnect(userrec* user) { } -00297 void Module::OnUserQuit(userrec* user) { } -00298 void Module::OnUserDisconnect(userrec* user) { } -00299 void Module::OnUserJoin(userrec* user, chanrec* channel) { } -00300 void Module::OnUserPart(userrec* user, chanrec* channel) { } -00301 void Module::OnPacketTransmit(std::string &data, std::string serv) { } -00302 void Module::OnPacketReceive(std::string &data, std::string serv) { } -00303 void Module::OnRehash() { } -00304 void Module::OnServerRaw(std::string &raw, bool inbound, userrec* user) { } -00305 int Module::OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { return 0; } -00306 int Module::OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params) { return false; } -00307 Version Module::GetVersion() { return Version(1,0,0,0,VF_VENDOR); } -00308 void Module::OnOper(userrec* user) { }; -00309 void Module::OnInfo(userrec* user) { }; -00310 void Module::OnWhois(userrec* source, userrec* dest) { }; -00311 int Module::OnUserPreInvite(userrec* source,userrec* dest,chanrec* channel) { return 0; }; -00312 int Module::OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text) { return 0; }; -00313 int Module::OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text) { return 0; }; -00314 int Module::OnUserPreNick(userrec* user, std::string newnick) { return 0; }; -00315 void Module::OnUserPostNick(userrec* user, std::string oldnick) { }; -00316 int Module::OnAccessCheck(userrec* source,userrec* dest,chanrec* channel,int access_type) { return ACR_DEFAULT; }; -00317 string_list Module::OnUserSync(userrec* user) { string_list empty; return empty; } -00318 string_list Module::OnChannelSync(chanrec* chan) { string_list empty; return empty; } -00319 void Module::On005Numeric(std::string &output) { }; -00320 int Module::OnKill(userrec* source, userrec* dest, std::string reason) { return 0; }; -00321 void Module::OnLoadModule(Module* mod,std::string name) { }; -00322 void Module::OnBackgroundTimer(time_t curtime) { }; -00323 void Module::OnSendList(userrec* user, chanrec* channel, char mode) { }; -00324 int Module::OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user) { return 0; }; -00325 bool Module::OnCheckReady(userrec* user) { return true; }; -00326 void Module::OnUserRegister(userrec* user) { }; -00327 int Module::OnUserPreKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { return 0; }; -00328 void Module::OnUserKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { }; -00329 int Module::OnRawMode(userrec* user, chanrec* chan, char mode, std::string param, bool adding, int pcnt) { return 0; }; -00330 int Module::OnCheckInvite(userrec* user, chanrec* chan) { return 0; }; -00331 int Module::OnCheckKey(userrec* user, chanrec* chan, std::string keygiven) { return 0; }; -00332 int Module::OnCheckLimit(userrec* user, chanrec* chan) { return 0; }; -00333 int Module::OnCheckBan(userrec* user, chanrec* chan) { return 0; }; -00334 void Module::OnStats(char symbol) { }; -00335 int Module::OnChangeLocalUserHost(userrec* user, std::string newhost) { return 0; }; -00336 int Module::OnChangeLocalUserGECOS(userrec* user, std::string newhost) { return 0; }; -00337 int Module::OnLocalTopicChange(userrec* user, chanrec* chan, std::string topic) { return 0; }; -00338 int Module::OnMeshToken(char token,string_list params,serverrec* source,serverrec* reply, std::string tcp_host,std::string ipaddr,int port) { return 0; }; -00339 void Module::OnEvent(Event* event) { return; }; -00340 char* Module::OnRequest(Request* request) { return NULL; }; -00341 int Module::OnOperCompare(std::string password, std::string input) { return 0; }; -00342 void Module::OnGlobalOper(userrec* user) { }; -00343 void Module::OnGlobalConnect(userrec* user) { }; -00344 int Module::OnAddBan(userrec* source, chanrec* channel,std::string banmask) { return 0; }; -00345 int Module::OnDelBan(userrec* source, chanrec* channel,std::string banmask) { return 0; }; -00346 void Module::OnRawSocketAccept(int fd, std::string ip, int localport) { }; -00347 int Module::OnRawSocketWrite(int fd, char* buffer, int count) { return 0; }; -00348 void Module::OnRawSocketClose(int fd) { }; -00349 int Module::OnRawSocketRead(int fd, char* buffer, unsigned int count, int &readresult) { return 0; }; -00350 -00351 // server is a wrapper class that provides methods to all of the C-style -00352 // exports in the core -00353 // -00354 -00355 Server::Server() -00356 { -00357 } -00358 -00359 Server::~Server() -00360 { -00361 } -00362 -00363 void Server::SendOpers(std::string s) -00364 { -00365 WriteOpers("%s",s.c_str()); +00247 Admin::Admin(std::string name, std::string email, std::string nick) : Name(name), Email(email), Nick(nick) { }; +00248 +00249 Request::Request(char* anydata, Module* src, Module* dst) : data(anydata), source(src), dest(dst) { }; +00250 +00251 char* Request::GetData() +00252 { +00253 return this->data; +00254 } +00255 +00256 Module* Request::GetSource() +00257 { +00258 return this->source; +00259 } +00260 +00261 Module* Request::GetDest() +00262 { +00263 return this->dest; +00264 } +00265 +00266 char* Request::Send() +00267 { +00268 if (this->dest) +00269 { +00270 return dest->OnRequest(this); +00271 } +00272 else +00273 { +00274 return NULL; +00275 } +00276 } +00277 +00278 Event::Event(char* anydata, Module* src, std::string eventid) : data(anydata), source(src), id(eventid) { }; +00279 +00280 char* Event::GetData() +00281 { +00282 return this->data; +00283 } +00284 +00285 Module* Event::GetSource() +00286 { +00287 return this->source; +00288 } +00289 +00290 char* Event::Send() +00291 { +00292 FOREACH_MOD OnEvent(this); +00293 return NULL; +00294 } +00295 +00296 std::string Event::GetEventID() +00297 { +00298 return this->id; +00299 } +00300 +00301 +00302 // These declarations define the behavours of the base class Module (which does nothing at all) +00303 Module::Module() { } +00304 Module::~Module() { } +00305 void Module::OnUserConnect(userrec* user) { } +00306 void Module::OnUserQuit(userrec* user) { } +00307 void Module::OnUserDisconnect(userrec* user) { } +00308 void Module::OnUserJoin(userrec* user, chanrec* channel) { } +00309 void Module::OnUserPart(userrec* user, chanrec* channel) { } +00310 void Module::OnPacketTransmit(std::string &data, std::string serv) { } +00311 void Module::OnPacketReceive(std::string &data, std::string serv) { } +00312 void Module::OnRehash() { } +00313 void Module::OnServerRaw(std::string &raw, bool inbound, userrec* user) { } +00314 int Module::OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { return 0; } +00315 int Module::OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params) { return false; } +00316 Version Module::GetVersion() { return Version(1,0,0,0,VF_VENDOR); } +00317 void Module::OnOper(userrec* user) { }; +00318 void Module::OnInfo(userrec* user) { }; +00319 void Module::OnWhois(userrec* source, userrec* dest) { }; +00320 int Module::OnUserPreInvite(userrec* source,userrec* dest,chanrec* channel) { return 0; }; +00321 int Module::OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text) { return 0; }; +00322 int Module::OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text) { return 0; }; +00323 int Module::OnUserPreNick(userrec* user, std::string newnick) { return 0; }; +00324 void Module::OnUserPostNick(userrec* user, std::string oldnick) { }; +00325 int Module::OnAccessCheck(userrec* source,userrec* dest,chanrec* channel,int access_type) { return ACR_DEFAULT; }; +00326 string_list Module::OnUserSync(userrec* user) { string_list empty; return empty; } +00327 string_list Module::OnChannelSync(chanrec* chan) { string_list empty; return empty; } +00328 void Module::On005Numeric(std::string &output) { }; +00329 int Module::OnKill(userrec* source, userrec* dest, std::string reason) { return 0; }; +00330 void Module::OnLoadModule(Module* mod,std::string name) { }; +00331 void Module::OnBackgroundTimer(time_t curtime) { }; +00332 void Module::OnSendList(userrec* user, chanrec* channel, char mode) { }; +00333 int Module::OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user) { return 0; }; +00334 bool Module::OnCheckReady(userrec* user) { return true; }; +00335 void Module::OnUserRegister(userrec* user) { }; +00336 int Module::OnUserPreKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { return 0; }; +00337 void Module::OnUserKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { }; +00338 int Module::OnRawMode(userrec* user, chanrec* chan, char mode, std::string param, bool adding, int pcnt) { return 0; }; +00339 int Module::OnCheckInvite(userrec* user, chanrec* chan) { return 0; }; +00340 int Module::OnCheckKey(userrec* user, chanrec* chan, std::string keygiven) { return 0; }; +00341 int Module::OnCheckLimit(userrec* user, chanrec* chan) { return 0; }; +00342 int Module::OnCheckBan(userrec* user, chanrec* chan) { return 0; }; +00343 void Module::OnStats(char symbol) { }; +00344 int Module::OnChangeLocalUserHost(userrec* user, std::string newhost) { return 0; }; +00345 int Module::OnChangeLocalUserGECOS(userrec* user, std::string newhost) { return 0; }; +00346 int Module::OnLocalTopicChange(userrec* user, chanrec* chan, std::string topic) { return 0; }; +00347 int Module::OnMeshToken(char token,string_list params,serverrec* source,serverrec* reply, std::string tcp_host,std::string ipaddr,int port) { return 0; }; +00348 void Module::OnEvent(Event* event) { return; }; +00349 char* Module::OnRequest(Request* request) { return NULL; }; +00350 int Module::OnOperCompare(std::string password, std::string input) { return 0; }; +00351 void Module::OnGlobalOper(userrec* user) { }; +00352 void Module::OnGlobalConnect(userrec* user) { }; +00353 int Module::OnAddBan(userrec* source, chanrec* channel,std::string banmask) { return 0; }; +00354 int Module::OnDelBan(userrec* source, chanrec* channel,std::string banmask) { return 0; }; +00355 void Module::OnRawSocketAccept(int fd, std::string ip, int localport) { }; +00356 int Module::OnRawSocketWrite(int fd, char* buffer, int count) { return 0; }; +00357 void Module::OnRawSocketClose(int fd) { }; +00358 int Module::OnRawSocketRead(int fd, char* buffer, unsigned int count, int &readresult) { return 0; }; +00359 +00360 // server is a wrapper class that provides methods to all of the C-style +00361 // exports in the core +00362 // +00363 +00364 Server::Server() +00365 { 00366 } 00367 -00368 bool Server::MatchText(std::string sliteral, std::string spattern) +00368 Server::~Server() 00369 { -00370 char literal[MAXBUF],pattern[MAXBUF]; -00371 strlcpy(literal,sliteral.c_str(),MAXBUF); -00372 strlcpy(pattern,spattern.c_str(),MAXBUF); -00373 return match(literal,pattern); -00374 } -00375 -00376 void Server::SendToModeMask(std::string modes, int flags, std::string text) -00377 { -00378 WriteMode(modes.c_str(),flags,"%s",text.c_str()); -00379 } -00380 -00381 chanrec* Server::JoinUserToChannel(userrec* user, std::string cname, std::string key) -00382 { -00383 return add_channel(user,cname.c_str(),key.c_str(),false); -00384 } -00385 -00386 chanrec* Server::PartUserFromChannel(userrec* user, std::string cname, std::string reason) -00387 { -00388 return del_channel(user,cname.c_str(),reason.c_str(),false); -00389 } -00390 -00391 chanuserlist Server::GetUsers(chanrec* chan) -00392 { -00393 chanuserlist userl; -00394 userl.clear(); -00395 std::vector<char*> *list = chan->GetUsers(); -00396 for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++) -00397 { -00398 char* o = *i; -00399 userl.push_back((userrec*)o); -00400 } -00401 return userl; -00402 } -00403 void Server::ChangeUserNick(userrec* user, std::string nickname) -00404 { -00405 force_nickchange(user,nickname.c_str()); -00406 } -00407 -00408 void Server::QuitUser(userrec* user, std::string reason) -00409 { -00410 kill_link(user,reason.c_str()); +00370 } +00371 +00372 void Server::SendOpers(std::string s) +00373 { +00374 WriteOpers("%s",s.c_str()); +00375 } +00376 +00377 bool Server::MatchText(std::string sliteral, std::string spattern) +00378 { +00379 char literal[MAXBUF],pattern[MAXBUF]; +00380 strlcpy(literal,sliteral.c_str(),MAXBUF); +00381 strlcpy(pattern,spattern.c_str(),MAXBUF); +00382 return match(literal,pattern); +00383 } +00384 +00385 void Server::SendToModeMask(std::string modes, int flags, std::string text) +00386 { +00387 WriteMode(modes.c_str(),flags,"%s",text.c_str()); +00388 } +00389 +00390 chanrec* Server::JoinUserToChannel(userrec* user, std::string cname, std::string key) +00391 { +00392 return add_channel(user,cname.c_str(),key.c_str(),false); +00393 } +00394 +00395 chanrec* Server::PartUserFromChannel(userrec* user, std::string cname, std::string reason) +00396 { +00397 return del_channel(user,cname.c_str(),reason.c_str(),false); +00398 } +00399 +00400 chanuserlist Server::GetUsers(chanrec* chan) +00401 { +00402 chanuserlist userl; +00403 userl.clear(); +00404 std::vector<char*> *list = chan->GetUsers(); +00405 for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++) +00406 { +00407 char* o = *i; +00408 userl.push_back((userrec*)o); +00409 } +00410 return userl; 00411 } -00412 -00413 bool Server::IsUlined(std::string server) -00414 { -00415 return is_uline(server.c_str()); -00416 } -00417 -00418 void Server::CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user) -00419 { -00420 call_handler(commandname.c_str(),parameters,pcnt,user); -00421 } -00422 -00423 void Server::Log(int level, std::string s) -00424 { -00425 log(level,"%s",s.c_str()); -00426 } -00427 -00428 void Server::AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source) -00429 { -00430 createcommand(cmd,f,flags,minparams,source); -00431 } -00432 -00433 void Server::SendMode(char **parameters, int pcnt, userrec *user) -00434 { -00435 server_mode(parameters,pcnt,user); -00436 } -00437 -00438 void Server::Send(int Socket, std::string s) -00439 { -00440 Write(Socket,"%s",s.c_str()); -00441 } -00442 -00443 void Server::SendServ(int Socket, std::string s) -00444 { -00445 WriteServ(Socket,"%s",s.c_str()); -00446 } -00447 -00448 void Server::SendFrom(int Socket, userrec* User, std::string s) -00449 { -00450 WriteFrom(Socket,User,"%s",s.c_str()); -00451 } -00452 -00453 void Server::SendTo(userrec* Source, userrec* Dest, std::string s) -00454 { -00455 if (!Source) -00456 { -00457 // if source is NULL, then the message originates from the local server -00458 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str()); -00459 } -00460 else -00461 { -00462 // otherwise it comes from the user specified -00463 WriteTo(Source,Dest,"%s",s.c_str()); -00464 } -00465 } -00466 -00467 void Server::SendChannelServerNotice(std::string ServName, chanrec* Channel, std::string text) -00468 { -00469 WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str()); -00470 } -00471 -00472 void Server::SendChannel(userrec* User, chanrec* Channel, std::string s,bool IncludeSender) -00473 { -00474 if (IncludeSender) -00475 { -00476 WriteChannel(Channel,User,"%s",s.c_str()); -00477 } -00478 else -00479 { -00480 ChanExceptSender(Channel,User,"%s",s.c_str()); -00481 } -00482 } -00483 -00484 bool Server::CommonChannels(userrec* u1, userrec* u2) -00485 { -00486 return (common_channels(u1,u2) != 0); -00487 } -00488 -00489 void Server::SendCommon(userrec* User, std::string text,bool IncludeSender) -00490 { -00491 if (IncludeSender) -00492 { -00493 WriteCommon(User,"%s",text.c_str()); -00494 } -00495 else -00496 { -00497 WriteCommonExcept(User,"%s",text.c_str()); -00498 } -00499 } -00500 -00501 void Server::SendWallops(userrec* User, std::string text) -00502 { -00503 WriteWallOps(User,false,"%s",text.c_str()); -00504 } -00505 -00506 void Server::ChangeHost(userrec* user, std::string host) -00507 { -00508 ChangeDisplayedHost(user,host.c_str()); -00509 } -00510 -00511 void Server::ChangeGECOS(userrec* user, std::string gecos) -00512 { -00513 ChangeName(user,gecos.c_str()); -00514 } -00515 -00516 bool Server::IsNick(std::string nick) -00517 { -00518 return (isnick(nick.c_str()) != 0); -00519 } -00520 -00521 userrec* Server::FindNick(std::string nick) -00522 { -00523 return Find(nick); -00524 } -00525 -00526 userrec* Server::FindDescriptor(int socket) -00527 { -00528 return (socket < 65536 ? fd_ref_table[socket] : NULL); -00529 } -00530 -00531 chanrec* Server::FindChannel(std::string channel) -00532 { -00533 return FindChan(channel.c_str()); -00534 } -00535 -00536 std::string Server::ChanMode(userrec* User, chanrec* Chan) -00537 { -00538 return cmode(User,Chan); -00539 } -00540 -00541 bool Server::IsOnChannel(userrec* User, chanrec* Chan) -00542 { -00543 return has_channel(User,Chan); -00544 } -00545 -00546 std::string Server::GetServerName() -00547 { -00548 return getservername(); -00549 } -00550 -00551 std::string Server::GetNetworkName() -00552 { -00553 return getnetworkname(); -00554 } -00555 -00556 std::string Server::GetServerDescription() -00557 { -00558 return getserverdesc(); -00559 } -00560 -00561 Admin Server::GetAdmin() -00562 { -00563 return Admin(getadminname(),getadminemail(),getadminnick()); -00564 } -00565 -00566 -00567 -00568 bool Server::AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off) -00569 { -00570 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) -00571 { -00572 if (type == MT_SERVER) -00573 { -00574 log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion"); -00575 return false; -00576 } -00577 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) -00578 { -00579 log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported"); -00580 return false; -00581 } -00582 if ((params_when_on>1) || (params_when_off>1)) -00583 { -00584 log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported"); -00585 return false; -00586 } -00587 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); -00588 } -00589 else -00590 { -00591 log(DEBUG,"*** API ERROR *** Muppet modechar detected."); -00592 } -00593 return false; -00594 } -00595 -00596 bool Server::AddExtendedListMode(char modechar) -00597 { -00598 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); -00599 if (res) -00600 ModeMakeList(modechar); -00601 return res; -00602 } -00603 -00604 int Server::CountUsers(chanrec* c) -00605 { -00606 return usercount(c); -00607 } -00608 -00609 -00610 bool Server::UserToPseudo(userrec* user,std::string message) -00611 { -00612 unsigned int old_fd = user->fd; -00613 user->fd = FD_MAGIC_NUMBER; -00614 user->ClearBuffer(); -00615 Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str()); -00616 #ifdef USE_KQUEUE -00617 struct kevent ke; -00618 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); -00619 int i = kevent(kq, &ke, 1, 0, 0, NULL); -00620 if (i == -1) -00621 { -00622 log(DEBUG,"kqueue: Failed to remove user from queue!"); -00623 } -00624 #endif -00625 shutdown(old_fd,2); -00626 close(old_fd); -00627 } -00628 -00629 bool Server::PseudoToUser(userrec* alive,userrec* zombie,std::string message) -00630 { -00631 zombie->fd = alive->fd; -00632 alive->fd = FD_MAGIC_NUMBER; -00633 alive->ClearBuffer(); -00634 Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick); -00635 kill_link(alive,message.c_str()); -00636 fd_ref_table[zombie->fd] = zombie; -00637 for (int i = 0; i != MAXCHANS; i++) -00638 { -00639 if (zombie->chans[i].channel != NULL) -00640 { -00641 if (zombie->chans[i].channel->name) -00642 { -00643 chanrec* Ptr = zombie->chans[i].channel; -00644 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name); -00645 if (Ptr->topicset) -00646 { -00647 WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic); -00648 WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); -00649 } -00650 userlist(zombie,Ptr); -00651 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name); -00652 -00653 } -00654 } -00655 } -00656 -00657 } -00658 -00659 void Server::AddGLine(long duration, std::string source, std::string reason, std::string hostmask) -00660 { -00661 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -00662 } -00663 -00664 void Server::AddQLine(long duration, std::string source, std::string reason, std::string nickname) -00665 { -00666 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); -00667 } -00668 -00669 void Server::AddZLine(long duration, std::string source, std::string reason, std::string ipaddr) -00670 { -00671 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); -00672 } -00673 -00674 void Server::AddKLine(long duration, std::string source, std::string reason, std::string hostmask) -00675 { -00676 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +00412 void Server::ChangeUserNick(userrec* user, std::string nickname) +00413 { +00414 force_nickchange(user,nickname.c_str()); +00415 } +00416 +00417 void Server::QuitUser(userrec* user, std::string reason) +00418 { +00419 kill_link(user,reason.c_str()); +00420 } +00421 +00422 bool Server::IsUlined(std::string server) +00423 { +00424 return is_uline(server.c_str()); +00425 } +00426 +00427 void Server::CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user) +00428 { +00429 call_handler(commandname.c_str(),parameters,pcnt,user); +00430 } +00431 +00432 void Server::Log(int level, std::string s) +00433 { +00434 log(level,"%s",s.c_str()); +00435 } +00436 +00437 void Server::AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source) +00438 { +00439 createcommand(cmd,f,flags,minparams,source); +00440 } +00441 +00442 void Server::SendMode(char **parameters, int pcnt, userrec *user) +00443 { +00444 server_mode(parameters,pcnt,user); +00445 } +00446 +00447 void Server::Send(int Socket, std::string s) +00448 { +00449 Write(Socket,"%s",s.c_str()); +00450 } +00451 +00452 void Server::SendServ(int Socket, std::string s) +00453 { +00454 WriteServ(Socket,"%s",s.c_str()); +00455 } +00456 +00457 void Server::SendFrom(int Socket, userrec* User, std::string s) +00458 { +00459 WriteFrom(Socket,User,"%s",s.c_str()); +00460 } +00461 +00462 void Server::SendTo(userrec* Source, userrec* Dest, std::string s) +00463 { +00464 if (!Source) +00465 { +00466 // if source is NULL, then the message originates from the local server +00467 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str()); +00468 } +00469 else +00470 { +00471 // otherwise it comes from the user specified +00472 WriteTo(Source,Dest,"%s",s.c_str()); +00473 } +00474 } +00475 +00476 void Server::SendChannelServerNotice(std::string ServName, chanrec* Channel, std::string text) +00477 { +00478 WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str()); +00479 } +00480 +00481 void Server::SendChannel(userrec* User, chanrec* Channel, std::string s,bool IncludeSender) +00482 { +00483 if (IncludeSender) +00484 { +00485 WriteChannel(Channel,User,"%s",s.c_str()); +00486 } +00487 else +00488 { +00489 ChanExceptSender(Channel,User,"%s",s.c_str()); +00490 } +00491 } +00492 +00493 bool Server::CommonChannels(userrec* u1, userrec* u2) +00494 { +00495 return (common_channels(u1,u2) != 0); +00496 } +00497 +00498 void Server::SendCommon(userrec* User, std::string text,bool IncludeSender) +00499 { +00500 if (IncludeSender) +00501 { +00502 WriteCommon(User,"%s",text.c_str()); +00503 } +00504 else +00505 { +00506 WriteCommonExcept(User,"%s",text.c_str()); +00507 } +00508 } +00509 +00510 void Server::SendWallops(userrec* User, std::string text) +00511 { +00512 WriteWallOps(User,false,"%s",text.c_str()); +00513 } +00514 +00515 void Server::ChangeHost(userrec* user, std::string host) +00516 { +00517 ChangeDisplayedHost(user,host.c_str()); +00518 } +00519 +00520 void Server::ChangeGECOS(userrec* user, std::string gecos) +00521 { +00522 ChangeName(user,gecos.c_str()); +00523 } +00524 +00525 bool Server::IsNick(std::string nick) +00526 { +00527 return (isnick(nick.c_str()) != 0); +00528 } +00529 +00530 userrec* Server::FindNick(std::string nick) +00531 { +00532 return Find(nick); +00533 } +00534 +00535 userrec* Server::FindDescriptor(int socket) +00536 { +00537 return (socket < 65536 ? fd_ref_table[socket] : NULL); +00538 } +00539 +00540 chanrec* Server::FindChannel(std::string channel) +00541 { +00542 return FindChan(channel.c_str()); +00543 } +00544 +00545 std::string Server::ChanMode(userrec* User, chanrec* Chan) +00546 { +00547 return cmode(User,Chan); +00548 } +00549 +00550 bool Server::IsOnChannel(userrec* User, chanrec* Chan) +00551 { +00552 return has_channel(User,Chan); +00553 } +00554 +00555 std::string Server::GetServerName() +00556 { +00557 return getservername(); +00558 } +00559 +00560 std::string Server::GetNetworkName() +00561 { +00562 return getnetworkname(); +00563 } +00564 +00565 std::string Server::GetServerDescription() +00566 { +00567 return getserverdesc(); +00568 } +00569 +00570 Admin Server::GetAdmin() +00571 { +00572 return Admin(getadminname(),getadminemail(),getadminnick()); +00573 } +00574 +00575 +00576 +00577 bool Server::AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off) +00578 { +00579 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) +00580 { +00581 if (type == MT_SERVER) +00582 { +00583 log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion"); +00584 return false; +00585 } +00586 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) +00587 { +00588 log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported"); +00589 return false; +00590 } +00591 if ((params_when_on>1) || (params_when_off>1)) +00592 { +00593 log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported"); +00594 return false; +00595 } +00596 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); +00597 } +00598 else +00599 { +00600 log(DEBUG,"*** API ERROR *** Muppet modechar detected."); +00601 } +00602 return false; +00603 } +00604 +00605 bool Server::AddExtendedListMode(char modechar) +00606 { +00607 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); +00608 if (res) +00609 ModeMakeList(modechar); +00610 return res; +00611 } +00612 +00613 int Server::CountUsers(chanrec* c) +00614 { +00615 return usercount(c); +00616 } +00617 +00618 +00619 bool Server::UserToPseudo(userrec* user,std::string message) +00620 { +00621 unsigned int old_fd = user->fd; +00622 user->fd = FD_MAGIC_NUMBER; +00623 user->ClearBuffer(); +00624 Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str()); +00625 #ifdef USE_KQUEUE +00626 struct kevent ke; +00627 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); +00628 int i = kevent(kq, &ke, 1, 0, 0, NULL); +00629 if (i == -1) +00630 { +00631 log(DEBUG,"kqueue: Failed to remove user from queue!"); +00632 } +00633 #endif +00634 #ifdef USE_EPOLL +00635 struct epoll_event ev; +00636 ev.events = EPOLLIN | EPOLLET; +00637 ev.data.fd = old_fd; +00638 int i = epoll_ctl(ep, EPOLL_CTL_DEL, old_fd, &ev); +00639 if (i < 0) +00640 { +00641 log(DEBUG,"epoll: List deletion failure!"); +00642 } +00643 #endif +00644 +00645 shutdown(old_fd,2); +00646 close(old_fd); +00647 } +00648 +00649 bool Server::PseudoToUser(userrec* alive,userrec* zombie,std::string message) +00650 { +00651 zombie->fd = alive->fd; +00652 alive->fd = FD_MAGIC_NUMBER; +00653 alive->ClearBuffer(); +00654 Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick); +00655 kill_link(alive,message.c_str()); +00656 fd_ref_table[zombie->fd] = zombie; +00657 for (int i = 0; i != MAXCHANS; i++) +00658 { +00659 if (zombie->chans[i].channel != NULL) +00660 { +00661 if (zombie->chans[i].channel->name) +00662 { +00663 chanrec* Ptr = zombie->chans[i].channel; +00664 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name); +00665 if (Ptr->topicset) +00666 { +00667 WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic); +00668 WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); +00669 } +00670 userlist(zombie,Ptr); +00671 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name); +00672 +00673 } +00674 } +00675 } +00676 00677 } 00678 -00679 void Server::AddELine(long duration, std::string source, std::string reason, std::string hostmask) +00679 void Server::AddGLine(long duration, std::string source, std::string reason, std::string hostmask) 00680 { -00681 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +00681 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); 00682 } 00683 -00684 bool Server::DelGLine(std::string hostmask) +00684 void Server::AddQLine(long duration, std::string source, std::string reason, std::string nickname) 00685 { -00686 del_gline(hostmask.c_str()); +00686 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); 00687 } 00688 -00689 bool Server::DelQLine(std::string nickname) +00689 void Server::AddZLine(long duration, std::string source, std::string reason, std::string ipaddr) 00690 { -00691 del_qline(nickname.c_str()); +00691 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); 00692 } 00693 -00694 bool Server::DelZLine(std::string ipaddr) +00694 void Server::AddKLine(long duration, std::string source, std::string reason, std::string hostmask) 00695 { -00696 del_zline(ipaddr.c_str()); +00696 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); 00697 } 00698 -00699 bool Server::DelKLine(std::string hostmask) +00699 void Server::AddELine(long duration, std::string source, std::string reason, std::string hostmask) 00700 { -00701 del_kline(hostmask.c_str()); +00701 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); 00702 } 00703 -00704 bool Server::DelELine(std::string hostmask) +00704 bool Server::DelGLine(std::string hostmask) 00705 { -00706 del_eline(hostmask.c_str()); +00706 del_gline(hostmask.c_str()); 00707 } 00708 -00709 long Server::CalcDuration(std::string delta) +00709 bool Server::DelQLine(std::string nickname) 00710 { -00711 return duration(delta.c_str()); +00711 del_qline(nickname.c_str()); 00712 } 00713 -00714 bool Server::IsValidMask(std::string mask) +00714 bool Server::DelZLine(std::string ipaddr) 00715 { -00716 const char* dest = mask.c_str(); -00717 if (strchr(dest,'!')==0) -00718 return false; -00719 if (strchr(dest,'@')==0) -00720 return false; -00721 for (int i = 0; i < strlen(dest); i++) -00722 if (dest[i] < 32) -00723 return false; -00724 for (int i = 0; i < strlen(dest); i++) -00725 if (dest[i] > 126) -00726 return false; -00727 int c = 0; -00728 for (int i = 0; i < strlen(dest); i++) -00729 if (dest[i] == '!') -00730 c++; -00731 if (c>1) -00732 return false; -00733 c = 0; -00734 for (int i = 0; i < strlen(dest); i++) -00735 if (dest[i] == '@') -00736 c++; -00737 if (c>1) +00716 del_zline(ipaddr.c_str()); +00717 } +00718 +00719 bool Server::DelKLine(std::string hostmask) +00720 { +00721 del_kline(hostmask.c_str()); +00722 } +00723 +00724 bool Server::DelELine(std::string hostmask) +00725 { +00726 del_eline(hostmask.c_str()); +00727 } +00728 +00729 long Server::CalcDuration(std::string delta) +00730 { +00731 return duration(delta.c_str()); +00732 } +00733 +00734 bool Server::IsValidMask(std::string mask) +00735 { +00736 const char* dest = mask.c_str(); +00737 if (strchr(dest,'!')==0) 00738 return false; -00739 -00740 return true; -00741 } -00742 -00743 void Server::MeshSendAll(std::string text) -00744 { -00745 NetSendToAll((char*)text.c_str()); -00746 } -00747 -00748 void Server::MeshSendCommon(userrec* user, std::string text) -00749 { -00750 if (user) -00751 NetSendToCommon(user,(char*)text.c_str()); -00752 } -00753 -00754 void Server::MeshSendAllAlive(std::string text) -00755 { -00756 NetSendToAllAlive((char*)text.c_str()); -00757 } -00758 -00759 void Server::MeshSendUnicast(std::string destination, std::string text) -00760 { -00761 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); -00762 } -00763 -00764 void Server::MeshSendAllExcept(std::string target, std::string text) -00765 { -00766 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); -00767 } -00768 -00769 bool Server::MeshCheckChan(chanrec *c,std::string servername) -00770 { -00771 if (c) -00772 { -00773 return ChanAnyOnThisServer(c,(char*)servername.c_str()); -00774 } -00775 else return false; -00776 } -00777 -00778 bool Server::MeshCheckCommon(userrec* u,std::string servername) -00779 { -00780 if (u) -00781 { -00782 return CommonOnThisServer(u,(char*)servername.c_str()); -00783 } -00784 else return false; -00785 } -00786 -00787 Module* Server::FindModule(std::string name) -00788 { -00789 for (int i = 0; i <= MODCOUNT; i++) -00790 { -00791 if (module_names[i] == name) -00792 { -00793 return modules[i]; -00794 } -00795 } -00796 return NULL; -00797 } -00798 -00799 ConfigReader::ConfigReader() -00800 { -00801 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -00802 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -00803 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); -00804 if (!this->readerror) -00805 this->error = CONF_FILE_NOT_FOUND; -00806 } -00807 -00808 -00809 ConfigReader::~ConfigReader() -00810 { -00811 if (this->cache) -00812 delete this->cache; -00813 if (this->errorlog) -00814 delete this->errorlog; -00815 } -00816 -00817 -00818 ConfigReader::ConfigReader(std::string filename) -00819 { -00820 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -00821 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -00822 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); -00823 if (!this->readerror) -00824 this->error = CONF_FILE_NOT_FOUND; -00825 }; -00826 -00827 std::string ConfigReader::ReadValue(std::string tag, std::string name, int index) -00828 { -00829 char val[MAXBUF]; -00830 char t[MAXBUF]; -00831 char n[MAXBUF]; -00832 strlcpy(t,tag.c_str(),MAXBUF); -00833 strlcpy(n,name.c_str(),MAXBUF); -00834 int res = ReadConf(cache,t,n,index,val); -00835 if (!res) -00836 { -00837 this->error = CONF_VALUE_NOT_FOUND; -00838 return ""; -00839 } -00840 return val; -00841 } -00842 -00843 bool ConfigReader::ReadFlag(std::string tag, std::string name, int index) -00844 { -00845 char val[MAXBUF]; -00846 char t[MAXBUF]; -00847 char n[MAXBUF]; -00848 strlcpy(t,tag.c_str(),MAXBUF); -00849 strlcpy(n,name.c_str(),MAXBUF); -00850 int res = ReadConf(cache,t,n,index,val); -00851 if (!res) -00852 { -00853 this->error = CONF_VALUE_NOT_FOUND; -00854 return false; -00855 } -00856 std::string s = val; -00857 return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1")); -00858 } -00859 -00860 long ConfigReader::ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned) -00861 { -00862 char val[MAXBUF]; -00863 char t[MAXBUF]; -00864 char n[MAXBUF]; -00865 strlcpy(t,tag.c_str(),MAXBUF); -00866 strlcpy(n,name.c_str(),MAXBUF); -00867 int res = ReadConf(cache,t,n,index,val); -00868 if (!res) -00869 { -00870 this->error = CONF_VALUE_NOT_FOUND; -00871 return 0; -00872 } -00873 for (int i = 0; i < strlen(val); i++) -00874 { -00875 if (!isdigit(val[i])) -00876 { -00877 this->error = CONF_NOT_A_NUMBER; -00878 return 0; -00879 } -00880 } -00881 if ((needs_unsigned) && (atoi(val)<0)) -00882 { -00883 this->error = CONF_NOT_UNSIGNED; -00884 return 0; -00885 } -00886 return atoi(val); -00887 } -00888 -00889 long ConfigReader::GetError() -00890 { -00891 long olderr = this->error; -00892 this->error = 0; -00893 return olderr; -00894 } -00895 -00896 void ConfigReader::DumpErrors(bool bail, userrec* user) -00897 { -00898 if (bail) -00899 { -00900 printf("There were errors in your configuration:\n%s",errorlog->str().c_str()); -00901 exit(0); -00902 } -00903 else -00904 { -00905 char dataline[1024]; -00906 if (user) -00907 { -00908 WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick); -00909 while (!errorlog->eof()) -00910 { -00911 errorlog->getline(dataline,1024); -00912 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline); -00913 } -00914 } -00915 else -00916 { -00917 WriteOpers("There were errors in the configuration file:",user->nick); -00918 while (!errorlog->eof()) -00919 { -00920 errorlog->getline(dataline,1024); -00921 WriteOpers(dataline); -00922 } -00923 } -00924 return; -00925 } -00926 } -00927 -00928 -00929 int ConfigReader::Enumerate(std::string tag) -00930 { -00931 return EnumConf(cache,tag.c_str()); -00932 } -00933 -00934 int ConfigReader::EnumerateValues(std::string tag, int index) -00935 { -00936 return EnumValues(cache, tag.c_str(), index); -00937 } -00938 -00939 bool ConfigReader::Verify() -00940 { -00941 return this->readerror; -00942 } -00943 -00944 -00945 FileReader::FileReader(std::string filename) -00946 { -00947 file_cache c; -00948 readfile(c,filename.c_str()); -00949 this->fc = c; -00950 } -00951 -00952 FileReader::FileReader() -00953 { -00954 } -00955 -00956 void FileReader::LoadFile(std::string filename) -00957 { -00958 file_cache c; -00959 readfile(c,filename.c_str()); -00960 this->fc = c; -00961 } -00962 +00739 if (strchr(dest,'@')==0) +00740 return false; +00741 for (int i = 0; i < strlen(dest); i++) +00742 if (dest[i] < 32) +00743 return false; +00744 for (int i = 0; i < strlen(dest); i++) +00745 if (dest[i] > 126) +00746 return false; +00747 int c = 0; +00748 for (int i = 0; i < strlen(dest); i++) +00749 if (dest[i] == '!') +00750 c++; +00751 if (c>1) +00752 return false; +00753 c = 0; +00754 for (int i = 0; i < strlen(dest); i++) +00755 if (dest[i] == '@') +00756 c++; +00757 if (c>1) +00758 return false; +00759 +00760 return true; +00761 } +00762 +00763 void Server::MeshSendAll(std::string text) +00764 { +00765 NetSendToAll((char*)text.c_str()); +00766 } +00767 +00768 void Server::MeshSendCommon(userrec* user, std::string text) +00769 { +00770 if (user) +00771 NetSendToCommon(user,(char*)text.c_str()); +00772 } +00773 +00774 void Server::MeshSendAllAlive(std::string text) +00775 { +00776 NetSendToAllAlive((char*)text.c_str()); +00777 } +00778 +00779 void Server::MeshSendUnicast(std::string destination, std::string text) +00780 { +00781 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); +00782 } +00783 +00784 void Server::MeshSendAllExcept(std::string target, std::string text) +00785 { +00786 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); +00787 } +00788 +00789 bool Server::MeshCheckChan(chanrec *c,std::string servername) +00790 { +00791 if (c) +00792 { +00793 return ChanAnyOnThisServer(c,(char*)servername.c_str()); +00794 } +00795 else return false; +00796 } +00797 +00798 bool Server::MeshCheckCommon(userrec* u,std::string servername) +00799 { +00800 if (u) +00801 { +00802 return CommonOnThisServer(u,(char*)servername.c_str()); +00803 } +00804 else return false; +00805 } +00806 +00807 Module* Server::FindModule(std::string name) +00808 { +00809 for (int i = 0; i <= MODCOUNT; i++) +00810 { +00811 if (module_names[i] == name) +00812 { +00813 return modules[i]; +00814 } +00815 } +00816 return NULL; +00817 } +00818 +00819 ConfigReader::ConfigReader() +00820 { +00821 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +00822 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +00823 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); +00824 if (!this->readerror) +00825 this->error = CONF_FILE_NOT_FOUND; +00826 } +00827 +00828 +00829 ConfigReader::~ConfigReader() +00830 { +00831 if (this->cache) +00832 delete this->cache; +00833 if (this->errorlog) +00834 delete this->errorlog; +00835 } +00836 +00837 +00838 ConfigReader::ConfigReader(std::string filename) +00839 { +00840 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +00841 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +00842 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); +00843 if (!this->readerror) +00844 this->error = CONF_FILE_NOT_FOUND; +00845 }; +00846 +00847 std::string ConfigReader::ReadValue(std::string tag, std::string name, int index) +00848 { +00849 char val[MAXBUF]; +00850 char t[MAXBUF]; +00851 char n[MAXBUF]; +00852 strlcpy(t,tag.c_str(),MAXBUF); +00853 strlcpy(n,name.c_str(),MAXBUF); +00854 int res = ReadConf(cache,t,n,index,val); +00855 if (!res) +00856 { +00857 this->error = CONF_VALUE_NOT_FOUND; +00858 return ""; +00859 } +00860 return val; +00861 } +00862 +00863 bool ConfigReader::ReadFlag(std::string tag, std::string name, int index) +00864 { +00865 char val[MAXBUF]; +00866 char t[MAXBUF]; +00867 char n[MAXBUF]; +00868 strlcpy(t,tag.c_str(),MAXBUF); +00869 strlcpy(n,name.c_str(),MAXBUF); +00870 int res = ReadConf(cache,t,n,index,val); +00871 if (!res) +00872 { +00873 this->error = CONF_VALUE_NOT_FOUND; +00874 return false; +00875 } +00876 std::string s = val; +00877 return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1")); +00878 } +00879 +00880 long ConfigReader::ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned) +00881 { +00882 char val[MAXBUF]; +00883 char t[MAXBUF]; +00884 char n[MAXBUF]; +00885 strlcpy(t,tag.c_str(),MAXBUF); +00886 strlcpy(n,name.c_str(),MAXBUF); +00887 int res = ReadConf(cache,t,n,index,val); +00888 if (!res) +00889 { +00890 this->error = CONF_VALUE_NOT_FOUND; +00891 return 0; +00892 } +00893 for (int i = 0; i < strlen(val); i++) +00894 { +00895 if (!isdigit(val[i])) +00896 { +00897 this->error = CONF_NOT_A_NUMBER; +00898 return 0; +00899 } +00900 } +00901 if ((needs_unsigned) && (atoi(val)<0)) +00902 { +00903 this->error = CONF_NOT_UNSIGNED; +00904 return 0; +00905 } +00906 return atoi(val); +00907 } +00908 +00909 long ConfigReader::GetError() +00910 { +00911 long olderr = this->error; +00912 this->error = 0; +00913 return olderr; +00914 } +00915 +00916 void ConfigReader::DumpErrors(bool bail, userrec* user) +00917 { +00918 if (bail) +00919 { +00920 printf("There were errors in your configuration:\n%s",errorlog->str().c_str()); +00921 exit(0); +00922 } +00923 else +00924 { +00925 char dataline[1024]; +00926 if (user) +00927 { +00928 WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick); +00929 while (!errorlog->eof()) +00930 { +00931 errorlog->getline(dataline,1024); +00932 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline); +00933 } +00934 } +00935 else +00936 { +00937 WriteOpers("There were errors in the configuration file:",user->nick); +00938 while (!errorlog->eof()) +00939 { +00940 errorlog->getline(dataline,1024); +00941 WriteOpers(dataline); +00942 } +00943 } +00944 return; +00945 } +00946 } +00947 +00948 +00949 int ConfigReader::Enumerate(std::string tag) +00950 { +00951 return EnumConf(cache,tag.c_str()); +00952 } +00953 +00954 int ConfigReader::EnumerateValues(std::string tag, int index) +00955 { +00956 return EnumValues(cache, tag.c_str(), index); +00957 } +00958 +00959 bool ConfigReader::Verify() +00960 { +00961 return this->readerror; +00962 } 00963 -00964 FileReader::~FileReader() -00965 { -00966 } -00967 -00968 bool FileReader::Exists() -00969 { -00970 if (fc.size() == 0) -00971 { -00972 return(false); -00973 } -00974 else -00975 { -00976 return(true); -00977 } -00978 } -00979 -00980 std::string FileReader::GetLine(int x) -00981 { -00982 if ((x<0) || (x>fc.size())) -00983 return ""; -00984 return fc[x]; -00985 } -00986 -00987 int FileReader::FileSize() -00988 { -00989 return fc.size(); -00990 } -00991 -00992 -00993 std::vector<Module*> modules(255); -00994 std::vector<ircd_module*> factory(255); -00995 -00996 int MODCOUNT = -1; -00997 -00998 -

    Generated on Sun May 15 18:36:02 2005 for InspIRCd by +00964 +00965 FileReader::FileReader(std::string filename) +00966 { +00967 file_cache c; +00968 readfile(c,filename.c_str()); +00969 this->fc = c; +00970 } +00971 +00972 FileReader::FileReader() +00973 { +00974 } +00975 +00976 void FileReader::LoadFile(std::string filename) +00977 { +00978 file_cache c; +00979 readfile(c,filename.c_str()); +00980 this->fc = c; +00981 } +00982 +00983 +00984 FileReader::~FileReader() +00985 { +00986 } +00987 +00988 bool FileReader::Exists() +00989 { +00990 if (fc.size() == 0) +00991 { +00992 return(false); +00993 } +00994 else +00995 { +00996 return(true); +00997 } +00998 } +00999 +01000 std::string FileReader::GetLine(int x) +01001 { +01002 if ((x<0) || (x>fc.size())) +01003 return ""; +01004 return fc[x]; +01005 } +01006 +01007 int FileReader::FileSize() +01008 { +01009 return fc.size(); +01010 } +01011 +01012 +01013 std::vector<Module*> modules(255); +01014 std::vector<ircd_module*> factory(255); +01015 +01016 int MODCOUNT = -1; +01017 +01018 +

    Generated on Tue May 24 02:30:04 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8cpp.html b/docs/module-doc/modules_8cpp.html index f7c0e4c3c..f1dbc24f0 100644 --- a/docs/module-doc/modules_8cpp.html +++ b/docs/module-doc/modules_8cpp.html @@ -58,44 +58,44 @@ Include dependency graph for modules.cpp:

    typedef nspace::hash_map<
    std::string, userrec *, nspace::hash<
    - string >, irc::StrHashCompuser_hash + string >, irc::StrHashCompuser_hash typedef nspace::hash_map<
    std::string, chanrec *, nspace::hash<
    - string >, irc::StrHashCompchan_hash + string >, irc::StrHashCompchan_hash typedef nspace::hash_map<
    in_addr, string *, nspace::hash<
    - in_addr >, irc::InAddr_HashCompaddress_cache + in_addr >, irc::InAddr_HashCompaddress_cache typedef nspace::hash_map<
    std::string, WhoWasUser *,
    - nspace::hash< string >, irc::StrHashCompwhowas_hash + nspace::hash< string >, irc::StrHashCompwhowas_hash -typedef std::deque< command_tcommand_table +typedef std::deque< command_tcommand_table -typedef std::vector< ExtModeExtModeList +typedef std::vector< ExtModeExtModeList -typedef ExtModeList::iterator ExtModeListIter +typedef ExtModeList::iterator ExtModeListIter

    Functions

    -bool ModeDefined (char modechar, int type) +bool ModeDefined (char modechar, int type) -bool ModeIsListMode (char modechar, int type) +bool ModeIsListMode (char modechar, int type) -bool ModeDefinedOper (char modechar, int type) +bool ModeDefinedOper (char modechar, int type) -int ModeDefinedOn (char modechar, int type) +int ModeDefinedOn (char modechar, int type) -int ModeDefinedOff (char modechar, int type) +int ModeDefinedOff (char modechar, int type) -bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off) +bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off) -void ModeMakeList (char modechar) +void ModeMakeList (char modechar) -std::vector< Module * > modules (255) +std::vector< Module * > modules (255) -std::vector< ircd_module * > factory (255) +std::vector< ircd_module * > factory (255)

    Variables

    int MODCOUNT = -1 @@ -150,55 +150,53 @@ Include dependency graph for modules.cpp:

    time_t nb_start -std::vector< int > fd_reap +std::vector< std::string > module_names -std::vector< std::string > module_names +int boundPortCount -int boundPortCount +int portCount -int portCount +int SERVERportCount -int SERVERportCount +int ports [MAXSOCKS] -int ports [MAXSOCKS] +int defaultRoute -int defaultRoute +std::vector< long > auth_cookies -std::vector< long > auth_cookies +std::stringstream config_f -std::stringstream config_f +serverrecme [32] -serverrecme [32] +FILE * log_file -FILE * log_file +userrecfd_ref_table [65536] -userrecfd_ref_table [65536] +user_hash clientlist -user_hash clientlist +chan_hash chanlist -chan_hash chanlist +whowas_hash whowas -whowas_hash whowas +command_table cmdlist -command_table cmdlist +file_cache MOTD -file_cache MOTD +file_cache RULES -file_cache RULES +address_cache IP -address_cache IP - -ExtModeList EMode +ExtModeList EMode

    Typedef Documentation

    -

    +

    @@ -213,16 +211,16 @@ Include dependency graph for modules.cpp:

    111 of file modules.cpp. +Definition at line 120 of file modules.cpp.
    -
    typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, irc::InAddr_HashComp> address_cache + typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, irc::InAddr_HashComp> address_cache
    -

    +

    @@ -237,16 +235,16 @@ Definition at line 111

    -Definition at line 110 of file modules.cpp. +Definition at line 119 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, irc::StrHashComp> chan_hash + typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, irc::StrHashComp> chan_hash
    -

    +

    @@ -261,16 +259,16 @@ Definition at line 110

    -Definition at line 113 of file modules.cpp. +Definition at line 122 of file modules.cpp.

    -
    typedef std::deque<command_t> command_table + typedef std::deque<command_t> command_table
    -

    +

    @@ -285,16 +283,16 @@ Definition at line 113

    -Definition at line 139 of file modules.cpp. +Definition at line 148 of file modules.cpp.

    -
    typedef std::vector<ExtMode> ExtModeList + typedef std::vector<ExtMode> ExtModeList
    -

    +

    @@ -309,18 +307,18 @@ Definition at line 139

    -Definition at line 140 of file modules.cpp. +Definition at line 149 of file modules.cpp.

    -Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). +Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList().

    -
    typedef ExtModeList::iterator ExtModeListIter + typedef ExtModeList::iterator ExtModeListIter
    -

    +

    @@ -335,16 +333,16 @@ Referenced by ModeDefined()

    -Definition at line 109 of file modules.cpp. +Definition at line 118 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, irc::StrHashComp> user_hash + typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, irc::StrHashComp> user_hash
    -

    +

    @@ -359,11 +357,11 @@ Definition at line 109

    -Definition at line 112 of file modules.cpp. +Definition at line 121 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, irc::StrHashComp> whowas_hash + typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, irc::StrHashComp> whowas_hash


    Function Documentation

    -

    +

    @@ -418,23 +416,23 @@ Definition at line 112

    -Definition at line 209 of file modules.cpp. +Definition at line 218 of file modules.cpp.

    -References EMode, and ModeDefined(). +References EMode, and ModeDefined().

    -Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode(). +Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode().

    -

    00210 {
    -00211         if (ModeDefined(modechar,type)) {
    -00212                 return false;
    -00213         }
    -00214         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    -00215         return true;
    -00216 }
    +
    00219 {
    +00220         if (ModeDefined(modechar,type)) {
    +00221                 return false;
    +00222         }
    +00223         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    +00224         return true;
    +00225 }
     
    -

    +

    @@ -463,7 +461,7 @@ Referenced by Server::AddEx
    -

    +

    @@ -500,26 +498,26 @@ Referenced by Server::AddEx

    -Definition at line 146 of file modules.cpp. +Definition at line 155 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -Referenced by DoAddExtendedMode(). +Referenced by DoAddExtendedMode().

    -

    00147 {
    -00148         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00149         {
    -00150                 if ((i->modechar == modechar) && (i->type == type))
    -00151                 {
    -00152                         return true;
    -00153                 }
    -00154         }
    -00155         return false;
    -00156 }
    +
    00156 {
    +00157         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00158         {
    +00159                 if ((i->modechar == modechar) && (i->type == type))
    +00160                 {
    +00161                         return true;
    +00162                 }
    +00163         }
    +00164         return false;
    +00165 }
     
    -

    +

    @@ -556,24 +554,24 @@ Referenced by DoAddExtended

    -Definition at line 196 of file modules.cpp. +Definition at line 205 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00197 {
    -00198         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00199         {
    -00200                 if ((i->modechar == modechar) && (i->type == type))
    -00201                 {
    -00202                         return i->params_when_off;
    -00203                 }
    -00204         }
    -00205         return 0;
    -00206 }
    +
    00206 {
    +00207         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00208         {
    +00209                 if ((i->modechar == modechar) && (i->type == type))
    +00210                 {
    +00211                         return i->params_when_off;
    +00212                 }
    +00213         }
    +00214         return 0;
    +00215 }
     
    -

    +

    @@ -610,24 +608,24 @@ References EMode, and <

    -Definition at line 183 of file modules.cpp. +Definition at line 192 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00184 {
    -00185         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00186         {
    -00187                 if ((i->modechar == modechar) && (i->type == type))
    -00188                 {
    -00189                         return i->params_when_on;
    -00190                 }
    -00191         }
    -00192         return 0;
    -00193 }
    +
    00193 {
    +00194         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00195         {
    +00196                 if ((i->modechar == modechar) && (i->type == type))
    +00197                 {
    +00198                         return i->params_when_on;
    +00199                 }
    +00200         }
    +00201         return 0;
    +00202 }
     
    -

    +

    @@ -664,24 +662,24 @@ References EMode, and <

    -Definition at line 170 of file modules.cpp. +Definition at line 179 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00171 {
    -00172         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00173         {
    -00174                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    -00175                 {
    -00176                         return true;
    -00177                 }
    -00178         }
    -00179         return false;
    -00180 }
    +
    00180 {
    +00181         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00182         {
    +00183                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    +00184                 {
    +00185                         return true;
    +00186                 }
    +00187         }
    +00188         return false;
    +00189 }
     
    -

    +

    @@ -718,24 +716,24 @@ References EMode, and <

    -Definition at line 158 of file modules.cpp. +Definition at line 167 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00159 {
    -00160         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00161         {
    -00162                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    -00163                 {
    -00164                         return true;
    -00165                 }
    -00166         }
    -00167         return false;
    -00168 }
    +
    00168 {
    +00169         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00170         {
    +00171                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    +00172                 {
    +00173                         return true;
    +00174                 }
    +00175         }
    +00176         return false;
    +00177 }
     
    -

    +

    @@ -763,27 +761,27 @@ References EMode, and <

    -Definition at line 219 of file modules.cpp. +Definition at line 228 of file modules.cpp.

    -References EMode, ExtModeListIter, and MT_CHANNEL. +References EMode, ExtModeListIter, and MT_CHANNEL.

    -Referenced by Server::AddExtendedListMode(). +Referenced by Server::AddExtendedListMode().

    -

    00220 {
    -00221         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00222         {
    -00223                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    -00224                 {
    -00225                         i->list = true;
    -00226                         return;
    -00227                 }
    -00228         }
    -00229         return;
    -00230 }
    +
    00229 {
    +00230         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00231         {
    +00232                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    +00233                 {
    +00234                         i->list = true;
    +00235                         return;
    +00236                 }
    +00237         }
    +00238         return;
    +00239 }
     
    -

    +

    +Definition at line 82 of file modules.cpp.
    @@ -834,7 +832,7 @@ Referenced by Server::AddEx

    -Definition at line 72 of file modules.cpp.

    @@ -858,7 +856,7 @@ Definition at line 72 o

    -Definition at line 71 of file modules.cpp. +Definition at line 81 of file modules.cpp.

    @@ -882,16 +880,16 @@ Definition at line 71 o

    -Definition at line 73 of file modules.cpp. +Definition at line 83 of file modules.cpp. -

    +

    @@ -906,16 +904,16 @@ Definition at line 73 o

    -Definition at line 100 of file modules.cpp. +Definition at line 109 of file modules.cpp.

    -
    std::vector<long> auth_cookies + std::vector<long> auth_cookies
    -

    +

    @@ -930,16 +928,16 @@ Definition at line 100

    -Definition at line 94 of file modules.cpp. +Definition at line 103 of file modules.cpp.

    -
    int boundPortCount + int boundPortCount
    -

    +

    @@ -954,16 +952,16 @@ Definition at line 94 o

    -Definition at line 117 of file modules.cpp. +Definition at line 126 of file modules.cpp.

    -
    chan_hash chanlist + chan_hash chanlist
    -

    +

    @@ -978,16 +976,16 @@ Definition at line 117

    -Definition at line 116 of file modules.cpp. +Definition at line 125 of file modules.cpp.

    -
    user_hash clientlist + user_hash clientlist
    -

    +

    @@ -1002,10 +1000,10 @@ Definition at line 116

    -Definition at line 119 of file modules.cpp. +Definition at line 128 of file modules.cpp.

    -
    command_table cmdlist + command_table cmdlist
    -

    +

    +Definition at line 110 of file modules.cpp.
    @@ -1026,7 +1024,7 @@ Definition at line 119

    -Definition at line 101 of file modules.cpp.

    @@ -1050,16 +1048,16 @@ Definition at line 101

    -Definition at line 82 of file modules.cpp. +Definition at line 92 of file modules.cpp. -

    +

    @@ -1074,7 +1072,7 @@ Definition at line 82 o

    -Definition at line 98 of file modules.cpp. +Definition at line 107 of file modules.cpp.

    -
    int defaultRoute + int defaultRoute

    @@ -1098,7 +1096,7 @@ Definition at line 98 o

    -Definition at line 85 of file modules.cpp. +Definition at line 95 of file modules.cpp.

    @@ -1122,7 +1120,7 @@ Definition at line 85 o

    -Definition at line 74 of file modules.cpp. +Definition at line 84 of file modules.cpp.

    @@ -1146,16 +1144,16 @@ Definition at line 74 o

    -Definition at line 80 of file modules.cpp. +Definition at line 90 of file modules.cpp. -

    +

    @@ -1170,9 +1168,9 @@ Definition at line 80 o

    -Definition at line 143 of file modules.cpp. +Definition at line 152 of file modules.cpp.

    -Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). +Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList().

    -
    ExtModeList EMode + ExtModeList EMode

    @@ -1196,40 +1194,16 @@ Referenced by DoAddExtended

    -Definition at line 63 of file modules.cpp. - - -

    - - - - -
    - - -
    std::vector<int> fd_reap -
    -
    - - - - +Definition at line 73 of file modules.cpp.
    -   - - -

    - -

    -Definition at line 91 of file modules.cpp.

    -

    +

    @@ -1244,18 +1218,18 @@ Definition at line 91 o

    -Definition at line 107 of file modules.cpp. +Definition at line 116 of file modules.cpp.

    -Referenced by Server::FindDescriptor(), and Server::PseudoToUser(). +Referenced by Server::FindDescriptor(), and Server::PseudoToUser().

    -
    userrec* fd_ref_table[65536] + userrec* fd_ref_table[65536]
    -

    +

    @@ -1270,7 +1244,7 @@ Referenced by Server::FindD

    -Definition at line 122 of file modules.cpp. +Definition at line 131 of file modules.cpp.

    -
    address_cache IP + address_cache IP

    @@ -1294,16 +1268,16 @@ Definition at line 122

    -Definition at line 78 of file modules.cpp. +Definition at line 88 of file modules.cpp. -

    +

    @@ -1318,7 +1292,7 @@ Definition at line 78 o

    -Definition at line 105 of file modules.cpp. +Definition at line 114 of file modules.cpp.

    -
    FILE* log_file + FILE* log_file

    @@ -1342,7 +1316,7 @@ Definition at line 105

    -Definition at line 67 of file modules.cpp. +Definition at line 77 of file modules.cpp.

    @@ -1366,16 +1340,16 @@ Definition at line 67 o

    -Definition at line 88 of file modules.cpp. +Definition at line 98 of file modules.cpp. -

    +

    @@ -1390,7 +1364,7 @@ Definition at line 88 o

    -Definition at line 103 of file modules.cpp. +Definition at line 112 of file modules.cpp.

    -
    serverrec* me[32] + serverrec* me[32]

    @@ -1414,16 +1388,16 @@ Definition at line 103

    -Definition at line 996 of file modules.cpp. +Definition at line 1016 of file modules.cpp. -

    +

    @@ -1438,7 +1412,7 @@ Definition at line 996

    -Definition at line 92 of file modules.cpp. +Definition at line 101 of file modules.cpp.

    -
    std::vector<std::string> module_names + std::vector<std::string> module_names

    @@ -1462,16 +1436,16 @@ Definition at line 92 o

    -Definition at line 62 of file modules.cpp. +Definition at line 72 of file modules.cpp. -

    +

    @@ -1486,7 +1460,7 @@ Definition at line 62 o

    -Definition at line 120 of file modules.cpp. +Definition at line 129 of file modules.cpp.

    -
    file_cache MOTD + file_cache MOTD

    @@ -1510,7 +1484,7 @@ Definition at line 120

    -Definition at line 76 of file modules.cpp. +Definition at line 86 of file modules.cpp.

    @@ -1534,7 +1508,7 @@ Definition at line 76 o

    -Definition at line 89 of file modules.cpp. +Definition at line 99 of file modules.cpp.

    @@ -1558,7 +1532,7 @@ Definition at line 89 o

    -Definition at line 87 of file modules.cpp. +Definition at line 97 of file modules.cpp.

    @@ -1582,16 +1556,16 @@ Definition at line 87 o

    -Definition at line 69 of file modules.cpp. +Definition at line 79 of file modules.cpp. -

    +

    @@ -1606,16 +1580,16 @@ Definition at line 69 o

    -Definition at line 95 of file modules.cpp. +Definition at line 104 of file modules.cpp.

    -
    int portCount + int portCount
    -

    +

    @@ -1630,7 +1604,7 @@ Definition at line 95 o

    -Definition at line 97 of file modules.cpp. +Definition at line 106 of file modules.cpp.

    -
    int ports[MAXSOCKS] + int ports[MAXSOCKS]

    @@ -1654,7 +1628,7 @@ Definition at line 97 o

    -Definition at line 79 of file modules.cpp. +Definition at line 89 of file modules.cpp.

    @@ -1678,16 +1652,16 @@ Definition at line 79 o

    -Definition at line 75 of file modules.cpp. +Definition at line 85 of file modules.cpp. -

    +

    @@ -1702,7 +1676,7 @@ Definition at line 75 o

    -Definition at line 121 of file modules.cpp. +Definition at line 130 of file modules.cpp.

    -
    file_cache RULES + file_cache RULES

    @@ -1726,7 +1700,7 @@ Definition at line 121

    -Definition at line 77 of file modules.cpp. +Definition at line 87 of file modules.cpp.

    @@ -1750,7 +1724,7 @@ Definition at line 77 o

    -Definition at line 70 of file modules.cpp. +Definition at line 80 of file modules.cpp.

    @@ -1774,16 +1748,16 @@ Definition at line 70 o

    -Definition at line 68 of file modules.cpp. +Definition at line 78 of file modules.cpp. -

    +

    @@ -1798,7 +1772,7 @@ Definition at line 68 o

    -Definition at line 96 of file modules.cpp. +Definition at line 105 of file modules.cpp.

    -
    int SERVERportCount + int SERVERportCount

    @@ -1822,7 +1796,7 @@ Definition at line 96 o

    -Definition at line 86 of file modules.cpp. +Definition at line 96 of file modules.cpp.

    @@ -1846,16 +1820,16 @@ Definition at line 86 o

    -Definition at line 65 of file modules.cpp. +Definition at line 75 of file modules.cpp. -

    +

    @@ -1870,7 +1844,7 @@ Definition at line 65 o

    -Definition at line 118 of file modules.cpp. +Definition at line 127 of file modules.cpp.

    -
    whowas_hash whowas + whowas_hash whowas

    @@ -1894,7 +1868,7 @@ Definition at line 118

    -Definition at line 84 of file modules.cpp. +Definition at line 94 of file modules.cpp.

    @@ -1918,10 +1892,10 @@ Definition at line 84 o

    -Definition at line 83 of file modules.cpp. +Definition at line 93 of file modules.cpp. -


    Generated on Sun May 15 18:37:18 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:08 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8h-source.html b/docs/module-doc/modules_8h-source.html index 1eb1e2182..94b07f708 100644 --- a/docs/module-doc/modules_8h-source.html +++ b/docs/module-doc/modules_8h-source.html @@ -345,15 +345,15 @@ 01006 01013 virtual bool PseudoToUser(userrec* alive,userrec* zombie,std::string message); 01014 -01022 virtual void AddGLine(long duration, std::string source, std::string reason, std::string hostmask); +01022 virtual void AddGLine(long duration, std::string source, std::string reason, std::string hostmask); 01023 -01031 virtual void AddQLine(long duration, std::string source, std::string reason, std::string nickname); +01031 virtual void AddQLine(long duration, std::string source, std::string reason, std::string nickname); 01032 -01040 virtual void AddZLine(long duration, std::string source, std::string reason, std::string ipaddr); +01040 virtual void AddZLine(long duration, std::string source, std::string reason, std::string ipaddr); 01041 -01049 virtual void AddKLine(long duration, std::string source, std::string reason, std::string hostmask); +01049 virtual void AddKLine(long duration, std::string source, std::string reason, std::string hostmask); 01050 -01058 virtual void AddELine(long duration, std::string source, std::string reason, std::string hostmask); +01058 virtual void AddELine(long duration, std::string source, std::string reason, std::string hostmask); 01059 01062 virtual bool DelGLine(std::string hostmask); 01063 @@ -365,7 +365,7 @@ 01075 01078 virtual bool DelELine(std::string hostmask); 01079 -01085 virtual long CalcDuration(std::string duration); +01085 virtual long CalcDuration(std::string duration); 01086 01089 virtual bool IsValidMask(std::string mask); 01090 @@ -450,7 +450,7 @@ 01307 typedef DLLFactory<ModuleFactory> ircd_module; 01308 01309 #endif -

    Generated on Sun May 15 18:36:02 2005 for InspIRCd by +

    Generated on Tue May 24 02:30:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8h.html b/docs/module-doc/modules_8h.html index 80ab4c32a..12c36a8ff 100644 --- a/docs/module-doc/modules_8h.html +++ b/docs/module-doc/modules_8h.html @@ -404,7 +404,7 @@ Definition at line 39 of

    Definition at line 37 of file modules.h.

    -Referenced by Module::OnAccessCheck(). +Referenced by Module::OnAccessCheck().

    @@ -454,7 +454,7 @@ Definition at line 38 of

    Definition at line 1141 of file modules.h.

    -Referenced by ConfigReader::ConfigReader(). +Referenced by ConfigReader::ConfigReader().

    @@ -480,7 +480,7 @@ Referenced by ConfigReader:

    Definition at line 1138 of file modules.h.

    -Referenced by ConfigReader::ReadInteger(). +Referenced by ConfigReader::ReadInteger().

    @@ -506,7 +506,7 @@ Referenced by ConfigReader:

    Definition at line 1139 of file modules.h.

    -Referenced by ConfigReader::ReadInteger(). +Referenced by ConfigReader::ReadInteger().

    @@ -532,7 +532,7 @@ Referenced by ConfigReader:

    Definition at line 1140 of file modules.h.

    -Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigReader::ReadValue(). +Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigReader::ReadValue().

    @@ -558,7 +558,7 @@ Referenced by ConfigReader:

    Definition at line 23 of file modules.h.

    -Referenced by Server::AddExtendedMode(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), userrec::RemoveInvite(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo(). +Referenced by Server::AddExtendedMode(), serverrec::AddIncoming(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), serverrec::RecvPacket(), userrec::RemoveInvite(), serverrec::SendPacket(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo().

    @@ -608,7 +608,7 @@ Definition at line 25 of

    Definition at line 99 of file modules.h.

    -Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). +Referenced by Server::PseudoToUser(), and Server::UserToPseudo().

    @@ -634,7 +634,7 @@ Referenced by Server::Pseud

    Definition at line 79 of file modules.h.

    -Referenced by Event::Send(). +Referenced by Event::Send().

    @@ -698,7 +698,7 @@ Definition at line 87 of

    Definition at line 31 of file modules.h.

    -Referenced by Server::AddExtendedListMode(), and ModeMakeList(). +Referenced by Server::AddExtendedListMode(), and ModeMakeList().

    @@ -724,7 +724,7 @@ Referenced by Server::AddEx

    Definition at line 32 of file modules.h.

    -Referenced by Server::AddExtendedMode(). +Referenced by Server::AddExtendedMode().

    @@ -750,7 +750,7 @@ Referenced by Server::AddEx

    Definition at line 33 of file modules.h.

    -Referenced by Server::AddExtendedMode(). +Referenced by Server::AddExtendedMode().

    @@ -920,7 +920,7 @@ Definition at line 53 of

    Definition at line 54 of file modules.h.

    -Referenced by Module::GetVersion(). +Referenced by Module::GetVersion().


    Typedef Documentation

    @@ -949,7 +949,7 @@ Holds a list of users in a channel.

    Definition at line 72 of file modules.h.

    -Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

    @@ -977,7 +977,7 @@ Low level definition of a FileReader Definition at line 67 of file modules.h.

    -Referenced by FileReader::FileReader(), and FileReader::LoadFile(). +Referenced by FileReader::FileReader(), and FileReader::LoadFile().

    @@ -1027,7 +1027,7 @@ Definition at line 1307 o

    Definition at line 68 of file modules.h.

    -Referenced by Module::OnChannelSync(), and Module::OnUserSync(). +Referenced by Module::OnChannelSync(), and Module::OnUserSync().


    Function Documentation

    @@ -1086,7 +1086,7 @@ Referenced by Module::OnCha

    -Referenced by Server::AddCommand(). +Referenced by Server::AddCommand().

    @@ -1132,10 +1132,10 @@ Referenced by Server::AddCo

    -Referenced by Server::SendMode(). +Referenced by Server::SendMode(). -


    Generated on Sun May 15 18:37:21 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:11 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespaceirc.html b/docs/module-doc/namespaceirc.html index 0c3ab2d62..10e0e126a 100644 --- a/docs/module-doc/namespaceirc.html +++ b/docs/module-doc/namespaceirc.html @@ -52,10 +52,10 @@ This typedef declares irc::string

    -Definition at line 114 of file hashcomp.h. +Definition at line 129 of file hashcomp.h. -


    Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespacemembers.html b/docs/module-doc/namespacemembers.html index 28d839f42..2e90e9ba5 100644 --- a/docs/module-doc/namespacemembers.html +++ b/docs/module-doc/namespacemembers.html @@ -11,7 +11,7 @@ Here is a list of all namespace members with links to the namespace documentation for each member: -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespacemembers_type.html b/docs/module-doc/namespacemembers_type.html index 990f410e3..79aaac483 100644 --- a/docs/module-doc/namespacemembers_type.html +++ b/docs/module-doc/namespacemembers_type.html @@ -11,7 +11,7 @@ -
    Generated on Sun May 15 18:39:28 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespacenspace.html b/docs/module-doc/namespacenspace.html index 89246e13c..cff039cf0 100644 --- a/docs/module-doc/namespacenspace.html +++ b/docs/module-doc/namespacenspace.html @@ -15,7 +15,7 @@ struct  nspace.hash< string > -
    Generated on Sun May 15 18:39:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespaces.html b/docs/module-doc/namespaces.html index 78486bc61..8e4d3d677 100644 --- a/docs/module-doc/namespaces.html +++ b/docs/module-doc/namespaces.html @@ -10,7 +10,7 @@ nspace std -
    Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespacestd.html b/docs/module-doc/namespacestd.html index a919c1b8c..aff42accb 100644 --- a/docs/module-doc/namespacestd.html +++ b/docs/module-doc/namespacestd.html @@ -10,7 +10,7 @@
    -
    Generated on Sun May 15 18:39:27 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp-source.html b/docs/module-doc/servers_8cpp-source.html index 64824c917..306245ef0 100644 --- a/docs/module-doc/servers_8cpp-source.html +++ b/docs/module-doc/servers_8cpp-source.html @@ -21,50 +21,447 @@ 00014 * --------------------------------------------------- 00015 */ 00016 -00017 #include "inspircd_config.h" -00018 #include "servers.h" -00019 #include "inspircd.h" -00020 #include <stdio.h> -00021 #include <map> -00022 #include "inspstring.h" -00023 #include "helperfuncs.h" -00024 -00025 extern time_t TIME; -00026 -00027 serverrec::serverrec() -00028 { -00029 strlcpy(name,"",256); -00030 pingtime = 0; -00031 lastping = TIME; -00032 usercount_i = usercount = opercount = version = 0; -00033 hops_away = 1; -00034 signon = TIME; -00035 jupiter = false; -00036 fd = 0; -00037 sync_soon = false; -00038 strlcpy(nickserv,"",NICKMAX); -00039 } -00040 -00041 -00042 serverrec::~serverrec() +00017 using namespace std; +00018 +00019 #include "inspircd_config.h" +00020 #include "servers.h" +00021 #include "inspircd.h" +00022 #include <unistd.h> +00023 #include <fcntl.h> +00024 #include <poll.h> +00025 #include <sys/errno.h> +00026 #include <sys/ioctl.h> +00027 #include <sys/utsname.h> +00028 #include <vector> +00029 #include <string> +00030 #include <deque> +00031 #include <sstream> +00032 #include <map> +00033 #include "inspstring.h" +00034 #include "helperfuncs.h" +00035 #include "connection.h" +00036 +00037 extern time_t TIME; +00038 extern int MaxConn; +00039 +00040 std::deque<std::string> xsums; +00041 +00042 serverrec::serverrec() 00043 { -00044 } -00045 -00046 serverrec::serverrec(char* n, long ver, bool jupe) -00047 { -00048 strlcpy(name,n,256); -00049 lastping = TIME; -00050 usercount_i = usercount = opercount = 0; -00051 version = ver; -00052 hops_away = 1; -00053 signon = TIME; -00054 jupiter = jupe; -00055 fd = 0; -00056 sync_soon = false; -00057 strlcpy(nickserv,"",NICKMAX); -00058 } -00059 -

    Generated on Sun May 15 18:36:02 2005 for InspIRCd by +00044 strlcpy(name,"",256); +00045 pingtime = 0; +00046 lastping = TIME; +00047 usercount_i = usercount = opercount = version = 0; +00048 hops_away = 1; +00049 signon = TIME; +00050 jupiter = false; +00051 fd = 0; +00052 sync_soon = false; +00053 strlcpy(nickserv,"",NICKMAX); +00054 connectors.clear(); +00055 } +00056 +00057 +00058 serverrec::~serverrec() +00059 { +00060 } +00061 +00062 serverrec::serverrec(char* n, long ver, bool jupe) +00063 { +00064 strlcpy(name,n,256); +00065 lastping = TIME; +00066 usercount_i = usercount = opercount = 0; +00067 version = ver; +00068 hops_away = 1; +00069 signon = TIME; +00070 jupiter = jupe; +00071 fd = 0; +00072 sync_soon = false; +00073 strlcpy(nickserv,"",NICKMAX); +00074 connectors.clear(); +00075 } +00076 +00077 bool serverrec::CreateListener(char* newhost, int p) +00078 { +00079 sockaddr_in host_address; +00080 int flags; +00081 in_addr addy; +00082 int on = 0; +00083 struct linger linger = { 0 }; +00084 +00085 this->port = p; +00086 +00087 fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); +00088 if (fd <= 0) +00089 { +00090 return false; +00091 } +00092 +00093 setsockopt(fd,SOL_SOCKET,SO_REUSEADDR,(const char*)&on,sizeof(on)); +00094 linger.l_onoff = 1; +00095 linger.l_linger = 1; +00096 setsockopt(fd,SOL_SOCKET,SO_LINGER,(const char*)&linger,sizeof(linger)); +00097 +00098 // attempt to increase socket sendq and recvq as high as its possible +00099 // to get them on linux. +00100 int sendbuf = 32768; +00101 int recvbuf = 32768; +00102 setsockopt(fd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf)); +00103 setsockopt(fd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf)); +00104 +00105 memset((void*)&host_address, 0, sizeof(host_address)); +00106 +00107 host_address.sin_family = AF_INET; +00108 +00109 if (!strcmp(newhost,"")) +00110 { +00111 host_address.sin_addr.s_addr = htonl(INADDR_ANY); +00112 } +00113 else +00114 { +00115 inet_aton(newhost,&addy); +00116 host_address.sin_addr = addy; +00117 } +00118 +00119 host_address.sin_port = htons(p); +00120 +00121 if (bind(fd,(sockaddr*)&host_address,sizeof(host_address))<0) +00122 { +00123 return false; +00124 } +00125 +00126 // make the socket non-blocking +00127 flags = fcntl(fd, F_GETFL, 0); +00128 fcntl(fd, F_SETFL, flags | O_NONBLOCK); +00129 +00130 this->port = p; +00131 +00132 listen(this->fd, MaxConn); +00133 +00134 return true; +00135 } +00136 +00137 +00138 bool serverrec::BeginLink(char* targethost, int newport, char* password, char* servername, int myport) +00139 { +00140 char connect[MAXBUF]; +00141 +00142 ircd_connector connector; +00143 ircd_connector *cn = this->FindHost(servername); +00144 +00145 +00146 if (cn) +00147 { +00148 WriteOpers("CONNECT aborted: Server %s already exists",servername); +00149 return false; +00150 } +00151 +00152 +00153 if (this->fd) +00154 { +00155 if (connector.MakeOutboundConnection(targethost,newport)) +00156 { +00157 // targethost has been turned into an ip... +00158 // we dont want this as the server name. +00159 connector.SetServerName(servername); +00160 snprintf(connect,MAXBUF,"S %s %s %lu %s :%s",getservername().c_str(),password,(unsigned long)myport,GetRevision().c_str(),getserverdesc().c_str()); +00161 connector.SetState(STATE_NOAUTH_OUTBOUND); +00162 connector.SetHostAndPort(targethost, newport); +00163 this->connectors.push_back(connector); +00164 return this->SendPacket(connect, servername); +00165 } +00166 else +00167 { +00168 connector.SetState(STATE_DISCONNECTED); +00169 WriteOpers("Could not create outbound connection to %s:%d",targethost,newport); +00170 } +00171 } +00172 return false; +00173 } +00174 +00175 +00176 bool serverrec::MeshCookie(char* targethost, int newport, unsigned long cookie, char* servername) +00177 { +00178 char connect[MAXBUF]; +00179 +00180 ircd_connector connector; +00181 +00182 WriteOpers("Establishing meshed link to %s:%d",servername,newport); +00183 +00184 if (this->fd) +00185 { +00186 if (connector.MakeOutboundConnection(targethost,newport)) +00187 { +00188 // targethost has been turned into an ip... +00189 // we dont want this as the server name. +00190 connector.SetServerName(servername); +00191 snprintf(connect,MAXBUF,"- %lu %s :%s",cookie,getservername().c_str(),getserverdesc().c_str()); +00192 connector.SetState(STATE_NOAUTH_OUTBOUND); +00193 connector.SetHostAndPort(targethost, newport); +00194 connector.SetState(STATE_CONNECTED); +00195 this->connectors.push_back(connector); +00196 return this->SendPacket(connect, servername); +00197 } +00198 else +00199 { +00200 connector.SetState(STATE_DISCONNECTED); +00201 WriteOpers("Could not create outbound connection to %s:%d",targethost,newport); +00202 } +00203 } +00204 return false; +00205 } +00206 +00207 bool serverrec::AddIncoming(int newfd, char* targethost, int sourceport) +00208 { +00209 ircd_connector connector; +00210 +00211 // targethost has been turned into an ip... +00212 // we dont want this as the server name. +00213 connector.SetServerName(targethost); +00214 connector.SetDescriptor(newfd); +00215 connector.SetState(STATE_NOAUTH_INBOUND); +00216 int flags = fcntl(newfd, F_GETFL, 0); +00217 fcntl(newfd, F_SETFL, flags | O_NONBLOCK); +00218 int sendbuf = 32768; +00219 int recvbuf = 32768; +00220 setsockopt(newfd,SOL_SOCKET,SO_SNDBUF,(const void *)&sendbuf,sizeof(sendbuf)); +00221 setsockopt(newfd,SOL_SOCKET,SO_RCVBUF,(const void *)&recvbuf,sizeof(sendbuf)); +00222 connector.SetHostAndPort(targethost, sourceport); +00223 connector.SetState(STATE_NOAUTH_INBOUND); +00224 log(DEBUG,"serverrec::AddIncoming() Added connection: %s:%d",targethost,sourceport); +00225 this->connectors.push_back(connector); +00226 return true; +00227 } +00228 +00229 void serverrec::TerminateLink(char* targethost) +00230 { +00231 // this locates the targethost in the serverrec::connectors vector of the class, +00232 // and terminates it by sending it an SQUIT token and closing its descriptor. +00233 // TerminateLink with a null string causes a terminate of ALL links +00234 } +00235 +00236 // Returns a pointer to the connector for 'host' +00237 ircd_connector* serverrec::FindHost(std::string findhost) +00238 { +00239 for (int i = 0; i < this->connectors.size(); i++) +00240 { +00241 if (this->connectors[i].GetServerName() == findhost) +00242 { +00243 return &this->connectors[i]; +00244 } +00245 } +00246 return NULL; +00247 } +00248 +00249 void serverrec::FlushWriteBuffers() +00250 { +00251 for (int i = 0; i < this->connectors.size(); i++) +00252 { +00253 if (this->connectors[i].GetState() != STATE_DISCONNECTED) +00254 { +00255 if (!this->connectors[i].CheckPing()) +00256 { +00257 WriteOpers("*** Lost single connection to %s: Ping timeout",this->connectors[i].GetServerName().c_str()); +00258 this->connectors[i].CloseConnection(); +00259 this->connectors[i].SetState(STATE_DISCONNECTED); +00260 } +00261 } +00262 if (this->connectors[i].HasBufferedOutput()) +00263 { +00264 if (!this->connectors[i].FlushWriteBuf()) +00265 { +00266 // if we're here the write() caused an error, we cannot proceed +00267 WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",this->connectors[i].GetServerName().c_str(),this->connectors[i].GetWriteError().c_str()); +00268 this->connectors[i].CloseConnection(); +00269 this->connectors[i].SetState(STATE_DISCONNECTED); +00270 } +00271 } +00272 } +00273 } +00274 +00275 bool serverrec::SendPacket(char *message, const char* sendhost) +00276 { +00277 if ((!message) || (!sendhost)) +00278 return true; +00279 +00280 ircd_connector* cn = this->FindHost(sendhost); +00281 +00282 if (!strchr(message,'\n')) +00283 { +00284 strlcat(message,"\n",MAXBUF); +00285 } +00286 +00287 if (cn) +00288 { +00289 log(DEBUG,"main: serverrec::SendPacket() sent '%s' to %s",message,cn->GetServerName().c_str()); +00290 +00291 if (cn->GetState() == STATE_DISCONNECTED) +00292 { +00293 // fix: can only route one hop to avoid a loop +00294 if (strncmp(message,"R ",2)) +00295 { +00296 log(DEBUG,"Not a double reroute"); +00297 // this route is down, we must re-route the packet through an available point in the mesh. +00298 for (int k = 0; k < this->connectors.size(); k++) +00299 { +00300 log(DEBUG,"Check connector %d: %s",k,this->connectors[k].GetServerName().c_str()); +00301 // search for another point in the mesh which can 'reach' where we want to go +00302 for (int m = 0; m < this->connectors[k].routes.size(); m++) +00303 { +00304 if (!strcasecmp(this->connectors[k].routes[m].c_str(),sendhost)) +00305 { +00306 log(DEBUG,"Found alternative route for packet: %s",this->connectors[k].GetServerName().c_str()); +00307 char buffer[MAXBUF]; +00308 snprintf(buffer,MAXBUF,"R %s %s",sendhost,message); +00309 this->SendPacket(buffer,this->connectors[k].GetServerName().c_str()); +00310 return true; +00311 } +00312 } +00313 } +00314 } +00315 char buffer[MAXBUF]; +00316 snprintf(buffer,MAXBUF,"& %s",sendhost); +00317 WriteOpers("*** All connections to %s lost.",sendhost); +00318 NetSendToAllExcept(sendhost,buffer); +00319 DoSplit(sendhost); +00320 return false; +00321 } +00322 +00323 // returns false if the packet could not be sent (e.g. target host down) +00324 if (!cn->AddWriteBuf(message)) +00325 { +00326 // if we're here, there was an error pending, and the send cannot proceed +00327 log(DEBUG,"cn->AddWriteBuf() failed for serverrec::SendPacket(): %s",cn->GetWriteError().c_str()); +00328 log(DEBUG,"Disabling connector: %s",cn->GetServerName().c_str()); +00329 cn->CloseConnection(); +00330 cn->SetState(STATE_DISCONNECTED); +00331 WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",cn->GetServerName().c_str(),cn->GetWriteError().c_str()); +00332 // retry the packet along a new route so either arrival OR failure are gauranteed (bugfix) +00333 return this->SendPacket(message,sendhost); +00334 } +00335 if (!cn->FlushWriteBuf()) +00336 { +00337 // if we're here the write() caused an error, we cannot proceed +00338 log(DEBUG,"cn->FlushWriteBuf() failed for serverrec::SendPacket(): %s",cn->GetWriteError().c_str()); +00339 log(DEBUG,"Disabling connector: %s",cn->GetServerName().c_str()); +00340 cn->CloseConnection(); +00341 cn->SetState(STATE_DISCONNECTED); +00342 WriteOpers("*** Lost single connection to %s, link inactive and retrying: %s",cn->GetServerName().c_str(),cn->GetWriteError().c_str()); +00343 // retry the packet along a new route so either arrival OR failure are gauranteed +00344 return this->SendPacket(message,sendhost); +00345 } +00346 return true; +00347 } +00348 } +00349 +00350 bool already_have_sum(std::string sum) +00351 { +00352 for (int i = 0; i < xsums.size(); i++) +00353 { +00354 if (xsums[i] == sum) +00355 { +00356 return true; +00357 } +00358 } +00359 if (xsums.size() >= 128) +00360 { +00361 xsums.pop_front(); +00362 } +00363 xsums.push_back(sum); +00364 return false; +00365 } +00366 +00367 // receives a packet from any where there is data waiting, first come, first served +00368 // fills the message and host values with the host where the data came from. +00369 +00370 bool serverrec::RecvPacket(std::deque<std::string> &messages, char* recvhost,std::deque<std::string> &sums) +00371 { +00372 char data[65536]; +00373 memset(data, 0, 65536); +00374 for (int i = 0; i < this->connectors.size(); i++) +00375 { +00376 if (this->connectors[i].GetState() != STATE_DISCONNECTED) +00377 { +00378 // returns false if the packet could not be sent (e.g. target host down) +00379 int rcvsize = 0; +00380 +00381 // check if theres any data on this socket +00382 // if not, continue onwards to the next. +00383 pollfd polls; +00384 polls.fd = this->connectors[i].GetDescriptor(); +00385 polls.events = POLLIN; +00386 int ret = poll(&polls,1,1); +00387 if (ret <= 0) continue; +00388 +00389 rcvsize = recv(this->connectors[i].GetDescriptor(),data,65000,0); +00390 data[rcvsize] = '\0'; +00391 if (rcvsize == -1) +00392 { +00393 if (errno != EAGAIN) +00394 { +00395 log(DEBUG,"recv() failed for serverrec::RecvPacket(): %s",strerror(errno)); +00396 log(DEBUG,"Disabling connector: %s",this->connectors[i].GetServerName().c_str()); +00397 this->connectors[i].CloseConnection(); +00398 this->connectors[i].SetState(STATE_DISCONNECTED); +00399 } +00400 } +00401 int pushed = 0; +00402 if (rcvsize > 0) +00403 { +00404 if (!this->connectors[i].AddBuffer(data)) +00405 { +00406 WriteOpers("*** Read buffer for %s exceeds maximum, closing connection!",this->connectors[i].GetServerName().c_str()); +00407 this->connectors[i].CloseConnection(); +00408 this->connectors[i].SetState(STATE_DISCONNECTED); +00409 } +00410 if (this->connectors[i].BufferIsComplete()) +00411 { +00412 this->connectors[i].ResetPing(); +00413 while (this->connectors[i].BufferIsComplete()) +00414 { +00415 std::string text = this->connectors[i].GetBuffer(); +00416 if (text != "") +00417 { +00418 if ((text[0] == ':') && (text.find(" ") != std::string::npos)) +00419 { +00420 std::string orig = text; +00421 log(DEBUG,"Original: %s",text.c_str()); +00422 std::string sum = text.substr(1,text.find(" ")-1); +00423 text = text.substr(text.find(" ")+1,text.length()); +00424 std::string possible_token = text.substr(1,text.find(" ")-1); +00425 if (possible_token.length() > 1) +00426 { +00427 sums.push_back("*"); +00428 text = orig; +00429 log(DEBUG,"Non-mesh, non-tokenized string passed up the chain"); +00430 } +00431 else +00432 { +00433 log(DEBUG,"Packet sum: '%s'",sum.c_str()); +00434 if ((already_have_sum(sum)) && (sum != "*")) +00435 { +00436 // we don't accept dupes +00437 continue; +00438 } +00439 sums.push_back(sum.c_str()); +00440 } +00441 } +00442 else sums.push_back("*"); +00443 messages.push_back(text.c_str()); +00444 strlcpy(recvhost,this->connectors[i].GetServerName().c_str(),160); +00445 log(DEBUG,"serverrec::RecvPacket() %d:%s->%s",pushed++,recvhost,text.c_str()); +00446 } +00447 } +00448 return true; +00449 } +00450 } +00451 } +00452 } +00453 // nothing new yet -- message and host will be undefined +00454 return false; +00455 } +00456 +

    Generated on Tue May 24 02:30:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp.html b/docs/module-doc/servers_8cpp.html index 29ea7ce92..c1a2a0c12 100644 --- a/docs/module-doc/servers_8cpp.html +++ b/docs/module-doc/servers_8cpp.html @@ -8,25 +8,122 @@

    servers.cpp File Reference

    #include "inspircd_config.h"
    #include "servers.h"
    #include "inspircd.h"
    -#include <stdio.h>
    +#include <unistd.h>
    +#include <fcntl.h>
    +#include <poll.h>
    +#include <sys/errno.h>
    +#include <sys/ioctl.h>
    +#include <sys/utsname.h>
    +#include <vector>
    +#include <string>
    +#include <deque>
    +#include <sstream>
    #include <map>
    #include "inspstring.h"
    #include "helperfuncs.h"
    +#include "connection.h"

    Include dependency graph for servers.cpp:

    Include dependency graph
    - + +

    Go to the source code of this file. + + + + + + + +

    Functions

    bool already_have_sum (std::string sum)

    Variables

    time_t TIME
    int MaxConn
    std::deque< std::string > xsums
    +


    Function Documentation

    +

    + + + + +
    + + + + + + + + + + +
    bool already_have_sum std::string  sum  ) 
    +
    + + + + +
    +   + + +

    + +

    +Definition at line 350 of file servers.cpp. +

    +References xsums. +

    +Referenced by serverrec::RecvPacket(). +

    +

    00351 {
    +00352         for (int i = 0; i < xsums.size(); i++)
    +00353         {
    +00354                 if (xsums[i] == sum)
    +00355                 {
    +00356                         return true;
    +00357                 }
    +00358         }
    +00359         if (xsums.size() >= 128)
    +00360         {
    +00361                 xsums.pop_front();
    +00362         }
    +00363         xsums.push_back(sum);
    +00364         return false;
    +00365 }
    +


    Variable Documentation

    +

    + + + + +
    + + +
    int MaxConn +
    +
    + + + + + +
    +   + + +

    + +

    +Definition at line 38 of file servers.cpp. +

    +Referenced by serverrec::CreateListener().

    @@ -48,10 +145,36 @@ Include dependency graph for servers.cpp:

    25 of file servers.cpp. +Definition at line 37 of file servers.cpp. +
    +
    +

    + + + + +
    + + +
    std::deque<std::string> xsums +
    +
    + + + +
    +   + + +

    + +

    +Definition at line 40 of file servers.cpp. +

    +Referenced by already_have_sum().

    -


    Generated on Sun May 15 18:37:22 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:15 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp__incl.gif b/docs/module-doc/servers_8cpp__incl.gif index 6158892d6..b2f91580d 100644 Binary files a/docs/module-doc/servers_8cpp__incl.gif and b/docs/module-doc/servers_8cpp__incl.gif differ diff --git a/docs/module-doc/servers_8h-source.html b/docs/module-doc/servers_8h-source.html index 8f80defb2..1055e7577 100644 --- a/docs/module-doc/servers_8h-source.html +++ b/docs/module-doc/servers_8h-source.html @@ -54,14 +54,32 @@ 00071 serverrec(); 00074 serverrec(char* n, long ver, bool jupe); 00077 ~serverrec(); -00078 -00079 }; -00080 -00081 +00078 +00081 std::vector<ircd_connector> connectors; 00082 -00083 #endif -00084 -

    Generated on Sun May 15 18:36:02 2005 for InspIRCd by +00083 +00086 bool CreateListener(char* host, int p); +00087 +00090 bool BeginLink(char* targethost, int port, char* password, char* servername, int myport); +00091 +00094 bool MeshCookie(char* targethost, int port, unsigned long cookie, char* servername); +00095 +00098 void TerminateLink(char* targethost); +00099 +00103 bool SendPacket(char *message, const char* host); +00104 +00109 bool RecvPacket(std::deque<std::string> &messages, char* host, std::deque<std::string> &sums); +00110 +00113 ircd_connector* FindHost(std::string host); +00114 +00118 bool AddIncoming(int fd,char* targethost, int sourceport); +00119 +00122 void FlushWriteBuffers(); +00123 }; +00124 +00125 #endif +00126 +

    Generated on Tue May 24 02:30:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8h.html b/docs/module-doc/servers_8h.html index 9acd0703d..2056aaa3d 100644 --- a/docs/module-doc/servers_8h.html +++ b/docs/module-doc/servers_8h.html @@ -86,7 +86,7 @@ Definition at line 25 of Definition at line 26 of file servers.h. -
    Generated on Sun May 15 18:37:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:17 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structdns__ip4list-members.html b/docs/module-doc/structdns__ip4list-members.html index f27efa746..fc7c2e98f 100644 --- a/docs/module-doc/structdns__ip4list-members.html +++ b/docs/module-doc/structdns__ip4list-members.html @@ -8,7 +8,7 @@

    dns_ip4list Member List

    This is the complete list of members for dns_ip4list, including all inherited members. -
    ipdns_ip4list
    nextdns_ip4list

    Generated on Sun May 15 18:38:03 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:50 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structdns__ip4list.html b/docs/module-doc/structdns__ip4list.html index 15044681d..d3ab6ab3a 100644 --- a/docs/module-doc/structdns__ip4list.html +++ b/docs/module-doc/structdns__ip4list.html @@ -67,7 +67,7 @@ Definition at line 28 of file
    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:38:03 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:50 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1InAddr__HashComp-members.html b/docs/module-doc/structirc_1_1InAddr__HashComp-members.html index 717d6f23a..ea4697b0c 100644 --- a/docs/module-doc/structirc_1_1InAddr__HashComp-members.html +++ b/docs/module-doc/structirc_1_1InAddr__HashComp-members.html @@ -7,7 +7,7 @@

    irc::InAddr_HashComp Member List

    This is the complete list of members for irc::InAddr_HashComp, including all inherited members. -
    operator()(const in_addr &s1, const in_addr &s2) constirc::InAddr_HashComp

    Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1InAddr__HashComp.html b/docs/module-doc/structirc_1_1InAddr__HashComp.html index 059344406..46d637fe3 100644 --- a/docs/module-doc/structirc_1_1InAddr__HashComp.html +++ b/docs/module-doc/structirc_1_1InAddr__HashComp.html @@ -24,7 +24,7 @@ Checking is done by copying both into a size_t then doing a numeric comparison o

    -Definition at line 77 of file hashcomp.h.


    Member Function Documentation

    +Definition at line 92 of file hashcomp.h.

    Member Function Documentation

    @@ -67,7 +67,7 @@ The operator () does the actual comparison in hash_map.


    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:39:25 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:55 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1StrHashComp-members.html b/docs/module-doc/structirc_1_1StrHashComp-members.html index e0fa151ba..baa7a7655 100644 --- a/docs/module-doc/structirc_1_1StrHashComp-members.html +++ b/docs/module-doc/structirc_1_1StrHashComp-members.html @@ -7,7 +7,7 @@

    irc::StrHashComp Member List

    This is the complete list of members for irc::StrHashComp, including all inherited members. -
    operator()(const std::string &s1, const std::string &s2) constirc::StrHashComp

    Generated on Sun May 15 18:39:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1StrHashComp.html b/docs/module-doc/structirc_1_1StrHashComp.html index c9b651972..fd1a3ba63 100644 --- a/docs/module-doc/structirc_1_1StrHashComp.html +++ b/docs/module-doc/structirc_1_1StrHashComp.html @@ -24,7 +24,7 @@ Case sensitivity is ignored, and the RFC 'character set' is adhered to

    -Definition at line 65 of file hashcomp.h.


    Member Function Documentation

    +Definition at line 80 of file hashcomp.h.

    Member Function Documentation

    @@ -67,7 +67,7 @@ The operator () does the actual comparison in hash_map.


    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:39:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1irc__char__traits-members.html b/docs/module-doc/structirc_1_1irc__char__traits-members.html index 5bf350ec9..74e9777ac 100644 --- a/docs/module-doc/structirc_1_1irc__char__traits-members.html +++ b/docs/module-doc/structirc_1_1irc__char__traits-members.html @@ -11,7 +11,7 @@ find(const char *s1, int n, char c)irc::irc_char_traits [static] lt(char c1st, char c2nd)irc::irc_char_traits [static] ne(char c1st, char c2nd)irc::irc_char_traits [static] -
    Generated on Sun May 15 18:39:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1irc__char__traits.html b/docs/module-doc/structirc_1_1irc__char__traits.html index e616b1e86..0170085fb 100644 --- a/docs/module-doc/structirc_1_1irc__char__traits.html +++ b/docs/module-doc/structirc_1_1irc__char__traits.html @@ -44,7 +44,7 @@ This class is used to implement irc::s

    -Definition at line 89 of file hashcomp.h.


    Member Function Documentation

    +Definition at line 104 of file hashcomp.h.

    Member Function Documentation

    @@ -259,7 +259,7 @@ Check if two chars do NOT match.


    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:39:26 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4-members.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4-members.html index 35e6027bc..773c94931 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4-members.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4-members.html @@ -7,7 +7,7 @@

    nspace::hash< in_addr > Member List

    This is the complete list of members for nspace::hash< in_addr >, including all inherited members. -
    operator()(const struct in_addr &a) constnspace::hash< in_addr >

    Generated on Sun May 15 18:39:27 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html index 379d7b71e..b6b2af8d0 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html @@ -48,7 +48,7 @@
    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:39:27 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html index 4cd67926d..d4ae6660c 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html @@ -7,7 +7,7 @@

    nspace::hash< string > Member List

    This is the complete list of members for nspace::hash< string >, including all inherited members. -
    operator()(const string &s) constnspace::hash< string >

    Generated on Sun May 15 18:39:27 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html index c8ed55ca1..56e014d29 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html @@ -48,7 +48,7 @@
    The documentation for this struct was generated from the following file: -
    Generated on Sun May 15 18:39:27 2005 for InspIRCd by +
    Generated on Tue May 24 02:32:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8cpp-source.html b/docs/module-doc/users_8cpp-source.html index e4e36db0d..2d74edf36 100644 --- a/docs/module-doc/users_8cpp-source.html +++ b/docs/module-doc/users_8cpp-source.html @@ -21,271 +21,286 @@ 00014 * --------------------------------------------------- 00015 */ 00016 -00017 #include "inspircd_config.h" -00018 #include "channels.h" -00019 #include "users.h" -00020 #include "inspircd.h" -00021 #include <stdio.h> -00022 #include "inspstring.h" -00023 #include "helperfuncs.h" -00024 -00025 extern std::stringstream config_f; +00017 using namespace std; +00018 +00019 #include "inspircd_config.h" +00020 #include "channels.h" +00021 #include "users.h" +00022 #include "inspircd.h" +00023 #include <stdio.h> +00024 #include "inspstring.h" +00025 #include "helperfuncs.h" 00026 -00027 extern time_t TIME; +00027 extern std::stringstream config_f; 00028 -00029 userrec::userrec() -00030 { -00031 // the PROPER way to do it, AVOID bzero at *ALL* costs -00032 strcpy(nick,""); -00033 strcpy(ip,"127.0.0.1"); -00034 timeout = 0; -00035 strcpy(ident,""); -00036 strcpy(host,""); -00037 strcpy(dhost,""); -00038 strcpy(fullname,""); -00039 strcpy(modes,""); -00040 strcpy(server,""); -00041 strcpy(awaymsg,""); -00042 strcpy(oper,""); -00043 reset_due = TIME; -00044 lines_in = 0; -00045 fd = lastping = signon = idle_lastmsg = nping = registered = 0; -00046 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; -00047 haspassed = false; -00048 dns_done = false; -00049 recvq = ""; -00050 sendq = ""; -00051 strcpy(result,""); -00052 for (int i = 0; i < MAXCHANS; i++) -00053 { -00054 this->chans[i].channel = NULL; -00055 this->chans[i].uc_modes = 0; -00056 } -00057 invites.clear(); -00058 } -00059 -00060 -00061 -00062 char* userrec::GetFullHost() +00029 extern time_t TIME; +00030 +00031 userrec::userrec() +00032 { +00033 // the PROPER way to do it, AVOID bzero at *ALL* costs +00034 strcpy(nick,""); +00035 strcpy(ip,"127.0.0.1"); +00036 timeout = 0; +00037 strcpy(ident,""); +00038 strcpy(host,""); +00039 strcpy(dhost,""); +00040 strcpy(fullname,""); +00041 strcpy(modes,""); +00042 strcpy(server,""); +00043 strcpy(awaymsg,""); +00044 strcpy(oper,""); +00045 reset_due = TIME; +00046 lines_in = 0; +00047 fd = lastping = signon = idle_lastmsg = nping = registered = 0; +00048 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; +00049 haspassed = false; +00050 dns_done = false; +00051 recvq = ""; +00052 sendq = ""; +00053 strcpy(result,""); +00054 for (int i = 0; i < MAXCHANS; i++) +00055 { +00056 this->chans[i].channel = NULL; +00057 this->chans[i].uc_modes = 0; +00058 } +00059 invites.clear(); +00060 } +00061 +00062 void userrec::CloseSocket() 00063 { -00064 snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost); -00065 return result; +00064 shutdown(this->fd,2); +00065 close(this->fd); 00066 } -00067 -00068 -00069 char* userrec::GetFullRealHost() -00070 { -00071 snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host); -00072 return result; -00073 } -00074 -00075 bool userrec::IsInvited(char* channel) -00076 { -00077 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -00078 { -00079 if (i->channel) { -00080 if (!strcasecmp(i->channel,channel)) -00081 { -00082 return true; -00083 } -00084 } -00085 } -00086 return false; -00087 } -00088 -00089 InvitedList* userrec::GetInviteList() -00090 { -00091 return &invites; -00092 } -00093 -00094 void userrec::InviteTo(char* channel) -00095 { -00096 Invited i; -00097 strlcpy(i.channel,channel,CHANMAX); -00098 invites.push_back(i); -00099 } -00100 -00101 void userrec::RemoveInvite(char* channel) -00102 { -00103 log(DEBUG,"Removing invites"); -00104 if (channel) -00105 { -00106 if (invites.size()) -00107 { -00108 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -00109 { -00110 if (i->channel) -00111 { -00112 if (!strcasecmp(i->channel,channel)) -00113 { -00114 invites.erase(i); -00115 return; -00116 } -00117 } -00118 } -00119 } -00120 } -00121 } -00122 -00123 bool userrec::HasPermission(char* command) -00124 { -00125 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; -00126 char* mycmd; -00127 char* savept; -00128 char* savept2; -00129 -00130 // are they even an oper at all? -00131 if (strchr(this->modes,'o')) -00132 { -00133 log(DEBUG,"*** HasPermission: %s is an oper",this->nick); -00134 for (int j =0; j < ConfValueEnum("type",&config_f); j++) -00135 { -00136 ConfValue("type","name",j,TypeName,&config_f); -00137 if (!strcmp(TypeName,this->oper)) -00138 { -00139 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper); -00140 ConfValue("type","classes",j,Classes,&config_f); -00141 char* myclass = strtok_r(Classes," ",&savept); -00142 while (myclass) -00143 { -00144 log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass); -00145 for (int k =0; k < ConfValueEnum("class",&config_f); k++) -00146 { -00147 ConfValue("class","name",k,ClassName,&config_f); -00148 if (!strcmp(ClassName,myclass)) -00149 { -00150 ConfValue("class","commands",k,CommandList,&config_f); -00151 log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList); -00152 -00153 -00154 mycmd = strtok_r(CommandList," ",&savept2); -00155 while (mycmd) -00156 { -00157 if (!strcasecmp(mycmd,command)) -00158 { -00159 log(DEBUG,"*** Command %s found, returning true",command); -00160 return true; -00161 } -00162 mycmd = strtok_r(NULL," ",&savept2); -00163 } -00164 } -00165 } -00166 myclass = strtok_r(NULL," ",&savept); -00167 } -00168 } -00169 } -00170 } -00171 return false; -00172 } -00173 -00174 -00175 bool userrec::AddBuffer(std::string a) -00176 { -00177 std::string b = ""; -00178 for (int i = 0; i < a.length(); i++) -00179 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) -00180 b = b + a[i]; -00181 std::stringstream stream(recvq); -00182 stream << b; -00183 recvq = stream.str(); -00184 int i = 0; -00185 // count the size of the first line in the buffer. -00186 while (i < recvq.length()) -00187 { -00188 if (recvq[i++] == '\n') -00189 break; -00190 } -00191 if (recvq.length() > this->recvqmax) -00192 { -00193 this->SetWriteError("RecvQ exceeded"); -00194 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax); -00195 } -00196 // return false if we've had more than 600 characters WITHOUT -00197 // a carriage return (this is BAD, drop the socket) -00198 return (i < 600); -00199 } -00200 -00201 bool userrec::BufferIsReady() -00202 { -00203 for (int i = 0; i < recvq.length(); i++) -00204 if (recvq[i] == '\n') -00205 return true; -00206 return false; -00207 } -00208 -00209 void userrec::ClearBuffer() -00210 { -00211 recvq = ""; -00212 } -00213 -00214 std::string userrec::GetBuffer() -00215 { -00216 if (recvq == "") -00217 return ""; -00218 char* line = (char*)recvq.c_str(); -00219 std::string ret = ""; -00220 while ((*line != '\n') && (strlen(line))) -00221 { -00222 ret = ret + *line; -00223 line++; -00224 } -00225 if ((*line == '\n') || (*line == '\r')) -00226 line++; -00227 recvq = line; -00228 return ret; -00229 } -00230 -00231 void userrec::AddWriteBuf(std::string data) -00232 { -00233 if (this->GetWriteError() != "") -00234 return; -00235 if (sendq.length() + data.length() > this->sendqmax) +00067 +00068 char* userrec::GetFullHost() +00069 { +00070 snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost); +00071 return result; +00072 } +00073 +00074 int userrec::ReadData(void* buffer, size_t size) +00075 { +00076 if (this->fd > -1) +00077 { +00078 return read(this->fd, buffer, size); +00079 } +00080 else return 0; +00081 } +00082 +00083 +00084 char* userrec::GetFullRealHost() +00085 { +00086 snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host); +00087 return result; +00088 } +00089 +00090 bool userrec::IsInvited(char* channel) +00091 { +00092 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +00093 { +00094 if (i->channel) { +00095 if (!strcasecmp(i->channel,channel)) +00096 { +00097 return true; +00098 } +00099 } +00100 } +00101 return false; +00102 } +00103 +00104 InvitedList* userrec::GetInviteList() +00105 { +00106 return &invites; +00107 } +00108 +00109 void userrec::InviteTo(char* channel) +00110 { +00111 Invited i; +00112 strlcpy(i.channel,channel,CHANMAX); +00113 invites.push_back(i); +00114 } +00115 +00116 void userrec::RemoveInvite(char* channel) +00117 { +00118 log(DEBUG,"Removing invites"); +00119 if (channel) +00120 { +00121 if (invites.size()) +00122 { +00123 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +00124 { +00125 if (i->channel) +00126 { +00127 if (!strcasecmp(i->channel,channel)) +00128 { +00129 invites.erase(i); +00130 return; +00131 } +00132 } +00133 } +00134 } +00135 } +00136 } +00137 +00138 bool userrec::HasPermission(char* command) +00139 { +00140 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; +00141 char* mycmd; +00142 char* savept; +00143 char* savept2; +00144 +00145 // are they even an oper at all? +00146 if (strchr(this->modes,'o')) +00147 { +00148 log(DEBUG,"*** HasPermission: %s is an oper",this->nick); +00149 for (int j =0; j < ConfValueEnum("type",&config_f); j++) +00150 { +00151 ConfValue("type","name",j,TypeName,&config_f); +00152 if (!strcmp(TypeName,this->oper)) +00153 { +00154 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper); +00155 ConfValue("type","classes",j,Classes,&config_f); +00156 char* myclass = strtok_r(Classes," ",&savept); +00157 while (myclass) +00158 { +00159 log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass); +00160 for (int k =0; k < ConfValueEnum("class",&config_f); k++) +00161 { +00162 ConfValue("class","name",k,ClassName,&config_f); +00163 if (!strcmp(ClassName,myclass)) +00164 { +00165 ConfValue("class","commands",k,CommandList,&config_f); +00166 log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList); +00167 +00168 +00169 mycmd = strtok_r(CommandList," ",&savept2); +00170 while (mycmd) +00171 { +00172 if (!strcasecmp(mycmd,command)) +00173 { +00174 log(DEBUG,"*** Command %s found, returning true",command); +00175 return true; +00176 } +00177 mycmd = strtok_r(NULL," ",&savept2); +00178 } +00179 } +00180 } +00181 myclass = strtok_r(NULL," ",&savept); +00182 } +00183 } +00184 } +00185 } +00186 return false; +00187 } +00188 +00189 +00190 bool userrec::AddBuffer(std::string a) +00191 { +00192 std::string b = ""; +00193 for (int i = 0; i < a.length(); i++) +00194 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) +00195 b = b + a[i]; +00196 std::stringstream stream(recvq); +00197 stream << b; +00198 recvq = stream.str(); +00199 int i = 0; +00200 // count the size of the first line in the buffer. +00201 while (i < recvq.length()) +00202 { +00203 if (recvq[i++] == '\n') +00204 break; +00205 } +00206 if (recvq.length() > this->recvqmax) +00207 { +00208 this->SetWriteError("RecvQ exceeded"); +00209 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax); +00210 } +00211 // return false if we've had more than 600 characters WITHOUT +00212 // a carriage return (this is BAD, drop the socket) +00213 return (i < 600); +00214 } +00215 +00216 bool userrec::BufferIsReady() +00217 { +00218 for (int i = 0; i < recvq.length(); i++) +00219 if (recvq[i] == '\n') +00220 return true; +00221 return false; +00222 } +00223 +00224 void userrec::ClearBuffer() +00225 { +00226 recvq = ""; +00227 } +00228 +00229 std::string userrec::GetBuffer() +00230 { +00231 if (recvq == "") +00232 return ""; +00233 char* line = (char*)recvq.c_str(); +00234 std::string ret = ""; +00235 while ((*line != '\n') && (strlen(line))) 00236 { -00237 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax); -00238 this->SetWriteError("SendQ exceeded"); -00239 return; -00240 } -00241 std::stringstream stream; -00242 stream << sendq << data; -00243 sendq = stream.str(); +00237 ret = ret + *line; +00238 line++; +00239 } +00240 if ((*line == '\n') || (*line == '\r')) +00241 line++; +00242 recvq = line; +00243 return ret; 00244 } 00245 -00246 // send AS MUCH OF THE USERS SENDQ as we are able to (might not be all of it) -00247 void userrec::FlushWriteBuf() -00248 { -00249 if (sendq.length()) -00250 { -00251 char* tb = (char*)this->sendq.c_str(); -00252 int n_sent = write(this->fd,tb,this->sendq.length()); -00253 if (n_sent == -1) -00254 { -00255 this->SetWriteError(strerror(errno)); -00256 } -00257 else -00258 { -00259 // advance the queue -00260 tb += n_sent; -00261 this->sendq = tb; -00262 // update the user's stats counters -00263 this->bytes_out += n_sent; -00264 this->cmds_out++; -00265 } -00266 } -00267 } -00268 -00269 void userrec::SetWriteError(std::string error) -00270 { -00271 log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str()); -00272 // don't try to set the error twice, its already set take the first string. -00273 if (this->WriteError == "") -00274 this->WriteError = error; -00275 } -00276 -00277 std::string userrec::GetWriteError() -00278 { -00279 return this->WriteError; -00280 } -

    Generated on Sun May 15 18:36:02 2005 for InspIRCd by +00246 void userrec::AddWriteBuf(std::string data) +00247 { +00248 if (this->GetWriteError() != "") +00249 return; +00250 if (sendq.length() + data.length() > this->sendqmax) +00251 { +00252 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax); +00253 this->SetWriteError("SendQ exceeded"); +00254 return; +00255 } +00256 std::stringstream stream; +00257 stream << sendq << data; +00258 sendq = stream.str(); +00259 } +00260 +00261 // send AS MUCH OF THE USERS SENDQ as we are able to (might not be all of it) +00262 void userrec::FlushWriteBuf() +00263 { +00264 if (sendq.length()) +00265 { +00266 char* tb = (char*)this->sendq.c_str(); +00267 int n_sent = write(this->fd,tb,this->sendq.length()); +00268 if (n_sent == -1) +00269 { +00270 this->SetWriteError(strerror(errno)); +00271 } +00272 else +00273 { +00274 // advance the queue +00275 tb += n_sent; +00276 this->sendq = tb; +00277 // update the user's stats counters +00278 this->bytes_out += n_sent; +00279 this->cmds_out++; +00280 } +00281 } +00282 } +00283 +00284 void userrec::SetWriteError(std::string error) +00285 { +00286 log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str()); +00287 // don't try to set the error twice, its already set take the first string. +00288 if (this->WriteError == "") +00289 this->WriteError = error; +00290 } +00291 +00292 std::string userrec::GetWriteError() +00293 { +00294 return this->WriteError; +00295 } +

    Generated on Tue May 24 02:30:07 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8cpp.html b/docs/module-doc/users_8cpp.html index 4288a8783..bdb475f34 100644 --- a/docs/module-doc/users_8cpp.html +++ b/docs/module-doc/users_8cpp.html @@ -51,7 +51,7 @@ Include dependency graph for users.cpp:

    25 of file users.cpp. +Definition at line 27 of file users.cpp.

    @@ -75,10 +75,10 @@ Definition at line 25 of

    -Definition at line 27 of file users.cpp. +Definition at line 29 of file users.cpp. -


    Generated on Sun May 15 18:37:29 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:20 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8h-source.html b/docs/module-doc/users_8h-source.html index 161fd21ec..16bbb2ee4 100644 --- a/docs/module-doc/users_8h-source.html +++ b/docs/module-doc/users_8h-source.html @@ -149,39 +149,43 @@ 00250 00255 bool HasPermission(char* command); 00256 -00264 bool AddBuffer(std::string a); -00265 -00269 bool BufferIsReady(); -00270 -00273 void ClearBuffer(); +00259 int ReadData(void* buffer, size_t size); +00260 +00268 bool AddBuffer(std::string a); +00269 +00273 bool BufferIsReady(); 00274 -00282 std::string GetBuffer(); -00283 -00289 void SetWriteError(std::string error); -00290 -00294 std::string GetWriteError(); -00295 -00301 void AddWriteBuf(std::string data); -00302 -00309 void FlushWriteBuf(); -00310 -00313 InvitedList* GetInviteList(); -00314 }; -00315 -00318 class WhoWasUser -00319 { -00320 public: -00321 char nick[NICKMAX]; -00322 char ident[16]; -00323 char dhost[160]; -00324 char host[160]; -00325 char fullname[128]; -00326 char server[256]; -00327 time_t signon; -00328 }; -00329 -00330 #endif -

    Generated on Sun May 15 18:36:03 2005 for InspIRCd by +00277 void ClearBuffer(); +00278 +00286 std::string GetBuffer(); +00287 +00293 void SetWriteError(std::string error); +00294 +00298 std::string GetWriteError(); +00299 +00305 void AddWriteBuf(std::string data); +00306 +00313 void FlushWriteBuf(); +00314 +00317 InvitedList* GetInviteList(); +00318 +00321 void CloseSocket(); +00322 }; +00323 +00326 class WhoWasUser +00327 { +00328 public: +00329 char nick[NICKMAX]; +00330 char ident[16]; +00331 char dhost[160]; +00332 char host[160]; +00333 char fullname[128]; +00334 char server[256]; +00335 time_t signon; +00336 }; +00337 +00338 #endif +

    Generated on Tue May 24 02:30:07 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8h.html b/docs/module-doc/users_8h.html index 14a9ca72c..739cbb08d 100644 --- a/docs/module-doc/users_8h.html +++ b/docs/module-doc/users_8h.html @@ -264,10 +264,10 @@ Holds a complete list of all channels to which a user has been invited and has n

    Definition at line 94 of file users.h.

    -Referenced by userrec::GetInviteList(). +Referenced by userrec::GetInviteList(). -


    Generated on Sun May 15 18:37:33 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:24 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/xline_8h-source.html b/docs/module-doc/xline_8h-source.html index 96c3f3d53..fb8765c98 100644 --- a/docs/module-doc/xline_8h-source.html +++ b/docs/module-doc/xline_8h-source.html @@ -123,7 +123,7 @@ 00157 void sync_xlines(serverrec* serv, char* tcp_host); 00158 00159 #endif -

    Generated on Sun May 15 18:36:03 2005 for InspIRCd by +

    Generated on Tue May 24 02:30:07 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/xline_8h.html b/docs/module-doc/xline_8h.html index b985ff3a6..5428c7969 100644 --- a/docs/module-doc/xline_8h.html +++ b/docs/module-doc/xline_8h.html @@ -159,7 +159,7 @@ This graph shows which files directly or indirectly include this file:

    -Referenced by Server::AddELine(). +Referenced by Server::AddELine().

    @@ -211,7 +211,7 @@ Referenced by Server::AddEL

    -Referenced by Server::AddGLine(). +Referenced by Server::AddGLine().

    @@ -263,7 +263,7 @@ Referenced by Server::AddGL

    -Referenced by Server::AddKLine(). +Referenced by Server::AddKLine().

    @@ -315,7 +315,7 @@ Referenced by Server::AddKL

    -Referenced by Server::AddQLine(). +Referenced by Server::AddQLine().

    @@ -367,7 +367,7 @@ Referenced by Server::AddQL

    -Referenced by Server::AddZLine(). +Referenced by Server::AddZLine().

    @@ -426,7 +426,7 @@ Referenced by Server::AddZL

    -Referenced by Server::DelELine(). +Referenced by Server::DelELine().

    @@ -457,7 +457,7 @@ Referenced by Server::DelEL

    -Referenced by Server::DelGLine(). +Referenced by Server::DelGLine().

    @@ -488,7 +488,7 @@ Referenced by Server::DelGL

    -Referenced by Server::DelKLine(). +Referenced by Server::DelKLine().

    @@ -519,7 +519,7 @@ Referenced by Server::DelKL

    -Referenced by Server::DelQLine(). +Referenced by Server::DelQLine().

    @@ -550,7 +550,7 @@ Referenced by Server::DelQL

    -Referenced by Server::DelZLine(). +Referenced by Server::DelZLine().

    @@ -1109,7 +1109,7 @@ Referenced by Server::DelZL -


    Generated on Sun May 15 18:37:36 2005 for InspIRCd by +
    Generated on Tue May 24 02:31:26 2005 for InspIRCd by doxygen 1.3.3
    -- cgit v1.2.3