* +------------------------------------+
*
* 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.
*
* ---------------------------------------------------
*/
*/
#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)
{
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;
}
};
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);
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();
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