summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorw00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7>2007-08-27 14:20:55 +0000
committerw00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7>2007-08-27 14:20:55 +0000
commit9d1b979fbca14013718f29e4e0380bb84b5e5470 (patch)
tree15fad0a2bdc8a557d01db6e0e25db7d45f4a2848
parent90ee2ee38c733520a8d149f90498bdbdb6091d67 (diff)
Changes to UID generation:
- Endless loop until we find a UID that is in use (this will be problematic if we get 2 billion users to a server..) - Once we reach the end of the UID namespace, start back at AAAA - Remove an unneeded allocation git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@7884 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--src/server.cpp37
1 files changed, 25 insertions, 12 deletions
diff --git a/src/server.cpp b/src/server.cpp
index a18610fab..041b9f5dd 100644
--- a/src/server.cpp
+++ b/src/server.cpp
@@ -136,10 +136,12 @@ bool InspIRCd::FindServerName(const std::string &servername)
*/
std::string InspIRCd::GetUID()
{
- bool HasUID = false;
int i;
- while (!HasUID)
+ /*
+ * This will only finish once we return a UUID that is not in use.
+ */
+ while (1)
{
/*
* Okay. The rules for generating a UID go like this...
@@ -171,22 +173,33 @@ std::string InspIRCd::GetUID()
current_uid[i]++;
}
- /*
- * XXX!
- * Check if it's in use here, continue; if it is!
- * This will only be an issue once we have a server that gets
- * an assload of connections, but.. -- w00t
- *
- * Until we have a map to check, just bail. -- w00t
- */
if (current_uid[3] == 'Z')
{
- InspIRCd::Exit(0);
+ /* If we get to here, we need to wrap around to AAAA. */
+ for(int j = 3; j < UUID_LENGTH - 1; j++)
+ current_uid[j] = 'A';
+
+ /*
+ * and now we need to break the inner for () to continue the while (),
+ * which will start the checking process over again. -- w00t
+ */
+ break;
+
}
- return std::string(current_uid);
+ if (this->FindUUID(current_uid))
+ {
+ /*
+ * It's in use. We need to try the loop again.
+ */
+ continue;
+ }
+
+ return current_uid;
}
}
+
+ /* not reached. */
return "";
}