]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - include/inspircd.h
Move AllModulesReportReady into a private method of class InspIRCd
[user/henk/code/inspircd.git] / include / inspircd.h
index 109e1f2be51f226297aae38e495098d95163a41d..59dc7eab0972e332cac2ef641cf9fb4403968130 100644 (file)
@@ -3,13 +3,13 @@
  *       +------------------------------------+
  *
  *  InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
- *                       E-mail:
- *                <brain@chatspike.net>
- *               <Craig@chatspike.net>
+ *                    E-mail:
+ *             <brain@chatspike.net>
+ *               <Craig@chatspike.net>
  *     
  * Written by Craig Edwards, Craig McLure, and others.
  * This program is free but copyrighted software; see
- *            the file COPYING for details.
+ *         the file COPYING for details.
  *
  * ---------------------------------------------------
  */
@@ -43,7 +43,7 @@
  */
 #define IS_SINGLE(x,y) ( (*x == y) && (*(x+1) == 0) )
 
-#define DELETE(x) { do_log(DEBUG,"%s:%d: delete()",__FILE__,__LINE__); if (x) { delete x; x = NULL; } else log(DEBUG,"Attempt to delete NULL pointer!"); }
+#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!"); }
 
 template<typename T> inline std::string ConvToStr(const T &in)
 {
@@ -55,23 +55,24 @@ template<typename T> inline std::string ConvToStr(const T &in)
 class serverstats : public classbase
 {
   public:
-       int statsAccept;
-       int statsRefused;
-       int statsUnknown;
-       int statsCollisions;
-       int statsDns;
-       int statsDnsGood;
-       int statsDnsBad;
-       int statsConnects;
-       int statsSent;
-       int statsRecv;
-       int BoundPortCount;
+       unsigned long statsAccept;
+       unsigned long statsRefused;
+       unsigned long statsUnknown;
+       unsigned long statsCollisions;
+       unsigned long statsDns;
+       unsigned long statsDnsGood;
+       unsigned long statsDnsBad;
+       unsigned long statsConnects;
+       double statsSent;
+       double statsRecv;
+       unsigned long BoundPortCount;
 
        serverstats()
        {
                statsAccept = statsRefused = statsUnknown = 0;
                statsCollisions = statsDns = statsDnsGood = 0;
-               statsDnsBad = statsConnects = statsSent = statsRecv = 0;
+               statsDnsBad = statsConnects = 0;
+               statsSent = statsRecv = 0.0;
                BoundPortCount = 0;
        }
 };
@@ -82,13 +83,14 @@ class InspIRCd : public classbase
  private:
        char MODERR[MAXBUF];
        bool expire_run;
+       servernamelist servernames;
  
        void EraseFactory(int j);
        void EraseModule(int j);
        void BuildISupport();
        void MoveTo(std::string modulename,int slot);
        void Start();
-       void SetSignals();
+       void SetSignals(bool SEGVHandler);
        bool DaemonSeed();
        void MakeLowerMap();
        void MoveToLast(std::string modulename);
@@ -96,12 +98,121 @@ class InspIRCd : public classbase
        void MoveAfter(std::string modulename, std::string after);
        void MoveBefore(std::string modulename, std::string before);
 
+       void ProcessUser(userrec* cu);
+       void DoSocketTimeouts(time_t TIME);
+       void DoBackgroundUserStuff(time_t TIME);
+
+       bool AllModulesReportReady(userrec* user);
+
  public:
        time_t startup_time;
        ModeParser* ModeGrok;
        CommandParser* Parser;
        SocketEngine* SE;
        serverstats* stats;
+       ServerConfig* Config;
+       std::vector<InspSocket*> module_sockets;
+       InspSocket* socket_ref[MAX_DESCRIPTORS];        /* XXX: This should probably be made private, with inline accessors */
+       userrec* fd_ref_table[MAX_DESCRIPTORS];         /* XXX: Ditto */
+       user_hash clientlist;
+       chan_hash chanlist;
+       std::vector<userrec*> local_users;
+       DNS* Res;
+       TimerManager* Timers;
+
+       void AddServerName(const std::string &servername);
+       const char* FindServerNamePtr(const std::string &servername);
+       bool FindServerName(const std::string &servername);
+
+       std::string GetServerDescription(const char* servername);
+
+       void WriteOpers(const char* text, ...);
+       void WriteOpers(const std::string &text);
+       
+       userrec* FindNick(const std::string &nick);
+       userrec* FindNick(const char* nick);
+
+       chanrec* FindChan(const std::string &chan);
+       chanrec* FindChan(const char* chan);
+
+       bool UserToPseudo(userrec* user, const std::string &message);
+       bool PseudoToUser(userrec* alive, userrec* zombie, const std::string &message);
+
+       void ServerNoticeAll(char* text, ...);
+       void ServerPrivmsgAll(char* text, ...);
+       void WriteMode(const char* modes, int flags, const char* text, ...);
+
+       int usercnt();
+       int registered_usercount();
+       int usercount_invisible();
+       int usercount_opers();
+       int usercount_unknown();
+       long chancount();
+       long local_count();
+
+       void SendError(const char *s);
+
+       /** For use with Module::Prioritize().
+        * When the return value of this function is returned from
+        * Module::Prioritize(), this specifies that the module wishes
+        * to be ordered exactly BEFORE 'modulename'. For more information
+        * please see Module::Prioritize().
+        * @param modulename The module your module wants to be before in the call list
+        * @returns a priority ID which the core uses to relocate the module in the list
+        */
+       long PriorityBefore(const std::string &modulename);
+
+       /** For use with Module::Prioritize().
+        * When the return value of this function is returned from
+        * Module::Prioritize(), this specifies that the module wishes
+        * to be ordered exactly AFTER 'modulename'. For more information please
+        * see Module::Prioritize().
+        * @param modulename The module your module wants to be after in the call list
+        * @returns a priority ID which the core uses to relocate the module in the list
+        */
+       long PriorityAfter(const std::string &modulename);
+
+       /** Publish a 'feature'.
+        * There are two ways for a module to find another module it depends on.
+        * Either by name, using InspIRCd::FindModule, or by feature, using this
+        * function. A feature is an arbitary string which identifies something this
+        * module can do. For example, if your module provides SSL support, but other
+        * modules provide SSL support too, all the modules supporting SSL should
+        * publish an identical 'SSL' feature. This way, any module requiring use
+        * of SSL functions can just look up the 'SSL' feature using FindFeature,
+        * then use the module pointer they are given.
+        * @param FeatureName The case sensitive feature name to make available
+        * @param Mod a pointer to your module class
+        * @returns True on success, false if the feature is already published by
+        * another module.
+        */
+       bool PublishFeature(const std::string &FeatureName, Module* Mod);
+
+       /** Unpublish a 'feature'.
+        * When your module exits, it must call this method for every feature it
+        * is providing so that the feature table is cleaned up.
+        * @param FeatureName the feature to remove
+        */
+       bool UnpublishFeature(const std::string &FeatureName);
+
+       /** Find a 'feature'.
+        * There are two ways for a module to find another module it depends on.
+        * Either by name, using InspIRCd::FindModule, or by feature, using the
+        * InspIRCd::PublishFeature method. A feature is an arbitary string which
+        * identifies something this module can do. For example, if your module
+        * provides SSL support, but other modules provide SSL support too, all
+        * the modules supporting SSL should publish an identical 'SSL' feature.
+        * To find a module capable of providing the feature you want, simply
+        * call this method with the feature name you are looking for.
+        * @param FeatureName The feature name you wish to obtain the module for
+        * @returns A pointer to a valid module class on success, NULL on failure.
+        */
+       Module* FindFeature(const std::string &FeatureName);
+
+       const std::string& GetModuleName(Module* m);
+
+       bool IsNick(const char* n);
+       bool IsIdent(const char* n);
 
        std::string GetRevision();
        std::string GetVersionString();
@@ -111,16 +222,12 @@ class InspIRCd : public classbase
        bool UnloadModule(const char* filename);
        InspIRCd(int argc, char** argv);
        void DoOneIteration(bool process_module_sockets);
+       static void Log(int level, const char* text, ...);
+       static void Log(int level, const std::string &text);
        int Run();
-
 };
 
 /* Miscellaneous stuff here, moved from inspircd_io.h */
 void Exit(int status);
 
-/* userrec optimization stuff */
-void AddServerName(const std::string &servername);
-const char* FindServerNamePtr(const std::string &servername);
-bool FindServerName(const std::string &servername);
-
 #endif