]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - include/inspircd.h
42072919e400cdbbf7a02793a687d5818553ccdd
[user/henk/code/inspircd.git] / include / inspircd.h
1 /*       +------------------------------------+
2  *       | Inspire Internet Relay Chat Daemon |
3  *       +------------------------------------+
4  *
5  *  InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
6  *                     E-mail:
7  *              <brain@chatspike.net>
8  *                <Craig@chatspike.net>
9  *     
10  * Written by Craig Edwards, Craig McLure, and others.
11  * This program is free but copyrighted software; see
12  *          the file COPYING for details.
13  *
14  * ---------------------------------------------------
15  */
16
17 #ifndef __INSPIRCD_H__
18 #define __INSPIRCD_H__
19
20 #include <time.h>
21 #include <string>
22 #include <sstream>
23 #include "inspircd_config.h"
24 #include "users.h"
25 #include "channels.h"
26 #include "socket.h"
27 #include "mode.h"
28 #include "helperfuncs.h"
29 #include "socketengine.h"
30 #include "command_parse.h"
31
32 /* Some misc defines */
33 #define ERROR -1
34 #define MAXCOMMAND 32
35
36 /* Crucial defines */
37 #define ETIREDGERBILS EAGAIN
38
39 /* This define is used in place of strcmp when we 
40  * want to check if a char* string contains only one
41  * letter. Pretty fast, its just two compares and an
42  * addition.
43  */
44 #define IS_SINGLE(x,y) ( (*x == y) && (*(x+1) == 0) )
45
46 #define DELETE(x) { InspIRCd::Log(DEBUG,"%s:%d: delete()",__FILE__,__LINE__); if (x) { delete x; x = NULL; } else InspIRCd::Log(DEBUG,"Attempt to delete NULL pointer!"); }
47
48 template<typename T> inline std::string ConvToStr(const T &in)
49 {
50         std::stringstream tmp;
51         if (!(tmp << in)) return std::string();
52         return tmp.str();
53 }
54
55 class serverstats : public classbase
56 {
57   public:
58         unsigned long statsAccept;
59         unsigned long statsRefused;
60         unsigned long statsUnknown;
61         unsigned long statsCollisions;
62         unsigned long statsDns;
63         unsigned long statsDnsGood;
64         unsigned long statsDnsBad;
65         unsigned long statsConnects;
66         double statsSent;
67         double statsRecv;
68         unsigned long BoundPortCount;
69
70         serverstats()
71         {
72                 statsAccept = statsRefused = statsUnknown = 0;
73                 statsCollisions = statsDns = statsDnsGood = 0;
74                 statsDnsBad = statsConnects = 0;
75                 statsSent = statsRecv = 0.0;
76                 BoundPortCount = 0;
77         }
78 };
79
80
81 class InspIRCd : public classbase
82 {
83  private:
84         char MODERR[MAXBUF];
85         bool expire_run;
86         servernamelist servernames;
87  
88         void EraseFactory(int j);
89         void EraseModule(int j);
90         void BuildISupport();
91         void MoveTo(std::string modulename,int slot);
92         void Start();
93         void SetSignals(bool SEGVHandler);
94         bool DaemonSeed();
95         void MakeLowerMap();
96         void MoveToLast(std::string modulename);
97         void MoveToFirst(std::string modulename);
98         void MoveAfter(std::string modulename, std::string after);
99         void MoveBefore(std::string modulename, std::string before);
100
101         void ProcessUser(userrec* cu);
102         void DoSocketTimeouts(time_t TIME);
103         void DoBackgroundUserStuff(time_t TIME);
104
105         bool AllModulesReportReady(userrec* user);
106
107         int ModCount;
108         char LogFileName[MAXBUF];
109
110         featurelist Features;
111
112  public:
113         time_t startup_time;
114         ModeParser* ModeGrok;
115         CommandParser* Parser;
116         SocketEngine* SE;
117         serverstats* stats;
118         ServerConfig* Config;
119         std::vector<InspSocket*> module_sockets;
120         InspSocket* socket_ref[MAX_DESCRIPTORS];        /* XXX: This should probably be made private, with inline accessors */
121         userrec* fd_ref_table[MAX_DESCRIPTORS];         /* XXX: Ditto */
122         user_hash clientlist;
123         chan_hash chanlist;
124         std::vector<userrec*> local_users;
125         std::vector<userrec*> all_opers;
126         DNS* Res;
127         TimerManager* Timers;
128
129         ModuleList modules;
130         FactoryList factory;
131
132         int GetModuleCount();
133
134         Module* FindModule(const std::string &name);
135
136         void AddServerName(const std::string &servername);
137         const char* FindServerNamePtr(const std::string &servername);
138         bool FindServerName(const std::string &servername);
139
140         std::string GetServerDescription(const char* servername);
141
142         void WriteOpers(const char* text, ...);
143         void WriteOpers(const std::string &text);
144         
145         userrec* FindNick(const std::string &nick);
146         userrec* FindNick(const char* nick);
147
148         chanrec* FindChan(const std::string &chan);
149         chanrec* FindChan(const char* chan);
150
151         void LoadAllModules();
152         void CheckDie();
153         void CheckRoot();
154         void OpenLog(char** argv, int argc);
155
156         bool UserToPseudo(userrec* user, const std::string &message);
157         bool PseudoToUser(userrec* alive, userrec* zombie, const std::string &message);
158
159         void ServerNoticeAll(char* text, ...);
160         void ServerPrivmsgAll(char* text, ...);
161         void WriteMode(const char* modes, int flags, const char* text, ...);
162
163         bool IsChannel(const char *chname);
164
165         static void Error(int status);
166         static void Rehash(int status);
167         static void Exit(int status);
168
169         int usercnt();
170         int registered_usercount();
171         int usercount_invisible();
172         int usercount_opers();
173         int usercount_unknown();
174         long chancount();
175         long local_count();
176
177         void SendError(const char *s);
178
179         /** For use with Module::Prioritize().
180          * When the return value of this function is returned from
181          * Module::Prioritize(), this specifies that the module wishes
182          * to be ordered exactly BEFORE 'modulename'. For more information
183          * please see Module::Prioritize().
184          * @param modulename The module your module wants to be before in the call list
185          * @returns a priority ID which the core uses to relocate the module in the list
186          */
187         long PriorityBefore(const std::string &modulename);
188
189         /** For use with Module::Prioritize().
190          * When the return value of this function is returned from
191          * Module::Prioritize(), this specifies that the module wishes
192          * to be ordered exactly AFTER 'modulename'. For more information please
193          * see Module::Prioritize().
194          * @param modulename The module your module wants to be after in the call list
195          * @returns a priority ID which the core uses to relocate the module in the list
196          */
197         long PriorityAfter(const std::string &modulename);
198
199         /** Publish a 'feature'.
200          * There are two ways for a module to find another module it depends on.
201          * Either by name, using InspIRCd::FindModule, or by feature, using this
202          * function. A feature is an arbitary string which identifies something this
203          * module can do. For example, if your module provides SSL support, but other
204          * modules provide SSL support too, all the modules supporting SSL should
205          * publish an identical 'SSL' feature. This way, any module requiring use
206          * of SSL functions can just look up the 'SSL' feature using FindFeature,
207          * then use the module pointer they are given.
208          * @param FeatureName The case sensitive feature name to make available
209          * @param Mod a pointer to your module class
210          * @returns True on success, false if the feature is already published by
211          * another module.
212          */
213         bool PublishFeature(const std::string &FeatureName, Module* Mod);
214
215         /** Unpublish a 'feature'.
216          * When your module exits, it must call this method for every feature it
217          * is providing so that the feature table is cleaned up.
218          * @param FeatureName the feature to remove
219          */
220         bool UnpublishFeature(const std::string &FeatureName);
221
222         /** Find a 'feature'.
223          * There are two ways for a module to find another module it depends on.
224          * Either by name, using InspIRCd::FindModule, or by feature, using the
225          * InspIRCd::PublishFeature method. A feature is an arbitary string which
226          * identifies something this module can do. For example, if your module
227          * provides SSL support, but other modules provide SSL support too, all
228          * the modules supporting SSL should publish an identical 'SSL' feature.
229          * To find a module capable of providing the feature you want, simply
230          * call this method with the feature name you are looking for.
231          * @param FeatureName The feature name you wish to obtain the module for
232          * @returns A pointer to a valid module class on success, NULL on failure.
233          */
234         Module* FindFeature(const std::string &FeatureName);
235
236         const std::string& GetModuleName(Module* m);
237
238         bool IsNick(const char* n);
239         bool IsIdent(const char* n);
240
241         std::string GetRevision();
242         std::string GetVersionString();
243         void WritePID(const std::string &filename);
244         char* ModuleError();
245         bool LoadModule(const char* filename);
246         bool UnloadModule(const char* filename);
247         InspIRCd(int argc, char** argv);
248         void DoOneIteration(bool process_module_sockets);
249         static void Log(int level, const char* text, ...);
250         static void Log(int level, const std::string &text);
251         int Run();
252 };
253
254 #endif