]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - include/inspircd.h
Remove an utterly insane comment .. based on changed by based on originally by change...
[user/henk/code/inspircd.git] / include / inspircd.h
index cb40e2734082761c1c8bbde4c15a172a8e528af4..dbbc0375e732bc8a6be105eb96b446ff28405f93 100644 (file)
@@ -29,6 +29,7 @@
 #include <string>
 #include <sstream>
 #include "inspircd_config.h"
+#include "uid.h"
 #include "users.h"
 #include "channels.h"
 #include "socket.h"
@@ -254,6 +255,10 @@ class XLineManager;
 class CoreExport InspIRCd : public classbase
 {
  private:
+       /** Holds the current UID. Used to generate the next one.
+        */
+       char current_uid[UUID_LENGTH];
+
        /** Holds a string describing the last module error to occur
         */
        char MODERR[MAXBUF];
@@ -390,6 +395,26 @@ class CoreExport InspIRCd : public classbase
         */
        std::map<InspSocket*,InspSocket*> SocketCull;
 
+       /** Globally accessible fake user record. This is used to force mode changes etc across s2s, etc.. bit ugly, but.. better than how this was done in 1.1
+        */
+       userrec *FakeClient;
+
+       /** Returns the next available UID for this server.
+        */
+       std::string GetUID();
+
+       /** Find a user in the UUID hash
+        * @param nick The nickname to find
+        * @return A pointer to the user, or NULL if the user does not exist
+        */
+       userrec *FindUUID(const std::string &);
+
+       /** Find a user in the UUID hash
+        * @param nick The nickname to find
+        * @return A pointer to the user, or NULL if the user does not exist
+        */
+       userrec *FindUUID(const char *);
+
        /** Build the ISUPPORT string by triggering all modules On005Numeric events
         */
        void BuildISupport();
@@ -440,6 +465,11 @@ class CoreExport InspIRCd : public classbase
         */
        user_hash* clientlist;
 
+       /** Client list stored by UUID. Contains all clients, and is updated
+        * automatically by the constructor and destructor of userrec.
+        */
+       user_hash* uuidlist;
+
        /** Channel list, a hash_map containing all channels
         */
        chan_hash* chanlist;
@@ -599,18 +629,28 @@ class CoreExport InspIRCd : public classbase
         */
        void WriteOpers(const std::string &text);
 
-       /** Find a nickname in the nick hash
+       /** Find a user in the nick hash.
+        * If the user cant be found in the nick hash check the uuid hash
         * @param nick The nickname to find
         * @return A pointer to the user, or NULL if the user does not exist
         */
        userrec* FindNick(const std::string &nick);
 
-       /** Find a nickname in the nick hash
+       /** Find a user in the nick hash.
+        * If the user cant be found in the nick hash check the uuid hash
         * @param nick The nickname to find
         * @return A pointer to the user, or NULL if the user does not exist
         */
        userrec* FindNick(const char* nick);
 
+       /** Find a user in the nick hash ONLY
+        */
+       userrec* FindNickOnly(const char* nick);
+
+       /** Find a user in the nick hash ONLY
+        */
+       userrec* FindNickOnly(const std::string &nick);
+
        /** Find a channel in the channels hash
         * @param chan The channel to find
         * @return A pointer to the channel, or NULL if the channel does not exist
@@ -640,8 +680,9 @@ class CoreExport InspIRCd : public classbase
        /** Determine the right path for, and open, the logfile
         * @param argv The argv passed to main() initially, used to calculate program path
         * @param argc The argc passed to main() initially, used to calculate program path
+        * @return True if the log could be opened, false if otherwise
         */
-       void OpenLog(char** argv, int argc);
+       bool OpenLog(char** argv, int argc);
 
        /** Close the currently open log file
         */