From 500d259c252f8c4f75c6f37e1067d57811426ddd Mon Sep 17 00:00:00 2001
From: Justin Clarke Casey
Date: Mon, 18 Feb 2008 15:50:18 +0000
Subject: * Do not allow a user to be created if one with the same name already
exists
---
.../Communications/CommunicationsManager.cs | 20 +++++++++-
.../Framework/Communications/UserManagerBase.cs | 45 +++++++++-------------
OpenSim/Framework/Console/ConsoleBase.cs | 8 ++--
OpenSim/Framework/IUserService.cs | 16 +++++++-
OpenSim/Grid/UserServer/Main.cs | 23 ++++++-----
5 files changed, 69 insertions(+), 43 deletions(-)
diff --git a/OpenSim/Framework/Communications/CommunicationsManager.cs b/OpenSim/Framework/Communications/CommunicationsManager.cs
index eb820c1..4ad808a 100644
--- a/OpenSim/Framework/Communications/CommunicationsManager.cs
+++ b/OpenSim/Framework/Communications/CommunicationsManager.cs
@@ -131,11 +131,27 @@ namespace OpenSim.Framework.Communications
regY = Convert.ToUInt32(cmmdParams[5]);
}
- AddUser(firstName, lastName, password, regX, regY);
+ if (null == m_userService.GetUserProfile(firstName, lastName))
+ {
+ AddUser(firstName, lastName, password, regX, regY);
+ }
+ else
+ {
+ m_log.ErrorFormat("[USERS]: A user with the name {0} {1} already exists!", firstName, lastName);
+ }
break;
}
}
+ ///
+ /// Persistently adds a user to OpenSim.
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ /// The UUID of the added user. Returns null if the add was unsuccessful
public LLUUID AddUser(string firstName, string lastName, string password, uint regX, uint regY)
{
string md5PasswdHash = Util.Md5Hash(Util.Md5Hash(password) + ":" + String.Empty);
@@ -149,7 +165,7 @@ namespace OpenSim.Framework.Communications
else
{
m_inventoryService.CreateNewUserInventory(userProf.UUID);
- System.Console.WriteLine("Created new inventory set for " + firstName + " " + lastName);
+ System.Console.WriteLine("[USERS]: Created new inventory set for " + firstName + " " + lastName);
return userProf.UUID;
}
}
diff --git a/OpenSim/Framework/Communications/UserManagerBase.cs b/OpenSim/Framework/Communications/UserManagerBase.cs
index dbf9276..733d62b 100644
--- a/OpenSim/Framework/Communications/UserManagerBase.cs
+++ b/OpenSim/Framework/Communications/UserManagerBase.cs
@@ -86,11 +86,24 @@ namespace OpenSim.Framework.UserManagement
#region Get UserProfile
- ///
- /// Loads a user profile from a database by UUID
- ///
- /// The target UUID
- /// A user profile. Returns null if no user profile is found.
+ // see IUserService
+ public UserProfileData GetUserProfile(string fname, string lname)
+ {
+ foreach (KeyValuePair plugin in _plugins)
+ {
+ UserProfileData profile = plugin.Value.GetUserByName(fname, lname);
+
+ if (profile != null)
+ {
+ profile.currentAgent = getUserAgent(profile.UUID);
+ return profile;
+ }
+ }
+
+ return null;
+ }
+
+ // see IUserService
public UserProfileData GetUserProfile(LLUUID uuid)
{
foreach (KeyValuePair plugin in _plugins)
@@ -126,28 +139,6 @@ namespace OpenSim.Framework.UserManagement
}
///
- /// Loads a user profile by name
- ///
- /// First name
- /// Last name
- /// A user profile. Returns null if no profile is found
- public UserProfileData GetUserProfile(string fname, string lname)
- {
- foreach (KeyValuePair plugin in _plugins)
- {
- UserProfileData profile = plugin.Value.GetUserByName(fname, lname);
-
- if (profile != null)
- {
- profile.currentAgent = getUserAgent(profile.UUID);
- return profile;
- }
- }
-
- return null;
- }
-
- ///
/// Set's user profile from object
///
/// First name
diff --git a/OpenSim/Framework/Console/ConsoleBase.cs b/OpenSim/Framework/Console/ConsoleBase.cs
index 829d6c7..63711f3 100644
--- a/OpenSim/Framework/Console/ConsoleBase.cs
+++ b/OpenSim/Framework/Console/ConsoleBase.cs
@@ -295,15 +295,15 @@ namespace OpenSim.Framework.Console
}
// Displays a prompt and waits for the user to enter a string, then returns that string
- // Done with no echo and suitable for passwords
+ // (Done with no echo and suitable for passwords - currently disabled)
public string PasswdPrompt(string prompt)
{
// FIXME: Needs to be better abstracted
System.Console.WriteLine(String.Format("{0}: ", prompt));
- ConsoleColor oldfg = System.Console.ForegroundColor;
- System.Console.ForegroundColor = System.Console.BackgroundColor;
+ //ConsoleColor oldfg = System.Console.ForegroundColor;
+ //System.Console.ForegroundColor = System.Console.BackgroundColor;
string temp = System.Console.ReadLine();
- System.Console.ForegroundColor = oldfg;
+ //System.Console.ForegroundColor = oldfg;
return temp;
}
diff --git a/OpenSim/Framework/IUserService.cs b/OpenSim/Framework/IUserService.cs
index f1f3c81..3b84486 100644
--- a/OpenSim/Framework/IUserService.cs
+++ b/OpenSim/Framework/IUserService.cs
@@ -32,9 +32,23 @@ namespace OpenSim.Framework
{
public interface IUserService
{
+ ///
+ /// Loads a user profile by name
+ ///
+ /// First name
+ /// Last name
+ /// A user profile. Returns null if no profile is found
UserProfileData GetUserProfile(string firstName, string lastName);
+
//UserProfileData GetUserProfile(string name);
+
+ ///
+ /// Loads a user profile from a database by UUID
+ ///
+ /// The target UUID
+ /// A user profile. Returns null if no user profile is found.
UserProfileData GetUserProfile(LLUUID userId);
+
void clearUserAgent(LLUUID avatarID);
List GenerateAgentPickerRequestResponse(LLUUID QueryID, string Query);
@@ -88,4 +102,4 @@ namespace OpenSim.Framework
/// The agent that we're retreiving the friends Data.
List GetUserFriendList(LLUUID friendlistowner);
}
-}
\ No newline at end of file
+}
diff --git a/OpenSim/Grid/UserServer/Main.cs b/OpenSim/Grid/UserServer/Main.cs
index 8c05d86..3500665 100644
--- a/OpenSim/Grid/UserServer/Main.cs
+++ b/OpenSim/Grid/UserServer/Main.cs
@@ -148,6 +148,12 @@ namespace OpenSim.Grid.UserServer
regX = Convert.ToUInt32(m_console.CmdPrompt("Start Region X"));
regY = Convert.ToUInt32(m_console.CmdPrompt("Start Region Y"));
+ if (null != m_userManager.GetUserProfile(tempfirstname, templastname))
+ {
+ m_log.ErrorFormat("[USERS]: A user with the name {0} {1} already exists!", tempfirstname, templastname);
+ break;
+ }
+
tempMD5Passwd = Util.Md5Hash(Util.Md5Hash(tempMD5Passwd) + ":" + String.Empty);
LLUUID userID = new LLUUID();
@@ -157,7 +163,7 @@ namespace OpenSim.Grid.UserServer
m_userManager.AddUserProfile(tempfirstname, templastname, tempMD5Passwd, regX, regY);
} catch (Exception ex)
{
- m_log.ErrorFormat("[SERVER]: Error creating user: {0}", ex.ToString());
+ m_log.ErrorFormat("[USERS]: Error creating user: {0}", ex.ToString());
}
try
@@ -167,7 +173,7 @@ namespace OpenSim.Grid.UserServer
}
catch (Exception ex)
{
- m_log.ErrorFormat("[SERVER]: Error creating inventory for user: {0}", ex.ToString());
+ m_log.ErrorFormat("[USERS]: Error creating inventory for user: {0}", ex.ToString());
}
m_lastCreatedUser = userID;
break;
@@ -204,13 +210,12 @@ namespace OpenSim.Grid.UserServer
// RestObjectPosterResponse> requester = new RestObjectPosterResponse>();
// requester.ReturnResponseVal = TestResponse;
// requester.BeginPostObject(m_userManager._config.InventoryUrl + "RootFolders/", m_lastCreatedUser);
- List folders =
- SynchronousRestObjectPoster.BeginPostObject>("POST",
- m_userManager.
- _config.
- InventoryUrl +
- "RootFolders/",
- m_lastCreatedUser);
+ SynchronousRestObjectPoster.BeginPostObject>("POST",
+ m_userManager.
+ _config.
+ InventoryUrl +
+ "RootFolders/",
+ m_lastCreatedUser);
break;
}
}
--
cgit v1.1