summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/inspircd.cpp15
-rw-r--r--src/server.cpp53
2 files changed, 68 insertions, 0 deletions
diff --git a/src/inspircd.cpp b/src/inspircd.cpp
index 5c1835b03..e7d43edff 100644
--- a/src/inspircd.cpp
+++ b/src/inspircd.cpp
@@ -529,6 +529,21 @@ InspIRCd::InspIRCd(int argc, char** argv)
FreeConsole();
}
#endif
+
+
+ /*
+ * Initialise UID. XXX, we need to read SID from config, and use it instead of 000.
+ * For an explanation as to exactly how this works, and why it works this way, see GetUID().
+ * -- w00t
+ */
+ int i;
+
+ for(i = 0; i < 3; i++)
+ current_uid[i] = '0';
+
+ for(i = 3; i < UUID_LENGTH - 1; i++)
+ current_uid[i] = 'A';
+
printf("\nInspIRCd is now running!\n");
Log(DEFAULT,"Startup complete.");
diff --git a/src/server.cpp b/src/server.cpp
index 1ab5b5efd..ac693adb1 100644
--- a/src/server.cpp
+++ b/src/server.cpp
@@ -131,9 +131,62 @@ bool InspIRCd::FindServerName(const std::string &servername)
return false;
}
+/*
+ * Retrieve the next valid UUID that is free for this server.
+ */
std::string InspIRCd::GetUID()
{
+ bool HasUID = false;
+ int i;
+ while (!HasUID)
+ {
+ /*
+ * Okay. The rules for generating a UID go like this...
+ * -- > ABCDEFGHIJKLMNOPQRSTUVWXYZ --> 012345679 --> WRAP
+ * That is, we start at A. When we reach Z, we go to 0. At 9, we go to
+ * A again, in an iterative fashion.. so..
+ * AAA9 -> AABA, and so on. -- w00t
+ */
+
+ /* start at the end of the current UID string, work backwards. don't trample on SID! */
+ for (i = UUID_LENGTH - 2; i > 3; i--)
+ {
+ if (current_uid[i] == 'Z')
+ {
+ /* reached the end of alphabetical, go to numeric range */
+ current_uid[i] = '0';
+ }
+ else if (current_uid[i] == '9')
+ {
+ /* we reached the end of the sequence, set back to A */
+ current_uid[i] = 'A';
+
+ /* we also need to increment the next digit. */
+ continue;
+ }
+ else
+ {
+ /* most common case .. increment current UID */
+ 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);
+ }
+
+ return std::string(current_uid);
+ }
+ }
}