From d2a412e94bf3ef1e332d44b7106c606f26b1636b Mon Sep 17 00:00:00 2001
From: lbsa71
Date: Thu, 9 Apr 2009 16:45:22 +0000
Subject: * Added some more experimental code; nothing wired in so far.
---
OpenSim/Grid/UserServer.Modules/UserManager.cs | 108 ++++++++++++++++---------
1 file changed, 68 insertions(+), 40 deletions(-)
(limited to 'OpenSim/Grid')
diff --git a/OpenSim/Grid/UserServer.Modules/UserManager.cs b/OpenSim/Grid/UserServer.Modules/UserManager.cs
index c40201e..515c2bf 100644
--- a/OpenSim/Grid/UserServer.Modules/UserManager.cs
+++ b/OpenSim/Grid/UserServer.Modules/UserManager.cs
@@ -41,7 +41,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
public delegate void logOffUser(UUID AgentID);
- public class UserManager
+ public class UserManager
{
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
@@ -50,12 +50,12 @@ namespace OpenSim.Grid.UserServer.Modules
private UserDataBaseService m_userDataBaseService;
private BaseHttpServer m_httpServer;
-
+
///
///
///
///
- public UserManager( UserDataBaseService userDataBaseService)
+ public UserManager(UserDataBaseService userDataBaseService)
{
m_userDataBaseService = userDataBaseService;
}
@@ -70,10 +70,38 @@ namespace OpenSim.Grid.UserServer.Modules
}
+ private string RESTGetUserProfile(string request, string path, string param, OSHttpRequest httpRequest, OSHttpResponse httpResponse)
+ {
+ UUID id;
+ UserProfileData userProfile;
+
+ try
+ {
+ id = new UUID(param);
+ }
+ catch (Exception)
+ {
+ httpResponse.StatusCode = 500;
+ return "Malformed Param [" + param + "]";
+ }
+
+ userProfile = m_userDataBaseService.GetUserProfile(id);
+
+ if (userProfile == null)
+ {
+ httpResponse.StatusCode = 404;
+ return "Not Found.";
+ }
+
+ return ProfileToXmlRPCResponse(userProfile).ToString();
+ }
+
public void RegisterHandlers(BaseHttpServer httpServer)
{
m_httpServer = httpServer;
+ m_httpServer.AddStreamHandler(new RestStreamHandler("GET", "/users/", RESTGetUserProfile));
+
m_httpServer.AddXmlRPCHandler("get_user_by_name", XmlRPCGetUserMethodName);
m_httpServer.AddXmlRPCHandler("get_user_by_uuid", XmlRPCGetUserMethodUUID);
m_httpServer.AddXmlRPCHandler("get_avatar_picker_avatar", XmlRPCGetAvatarPickerAvatar);
@@ -191,24 +219,24 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCGetAvatarPickerAvatar(XmlRpcRequest request)
{
// XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
List returnAvatar = new List();
UUID queryID = new UUID(UUID.Zero.ToString());
if (requestData.Contains("avquery") && requestData.Contains("queryid"))
{
- queryID = new UUID((string) requestData["queryid"]);
- returnAvatar = m_userDataBaseService.GenerateAgentPickerRequestResponse(queryID, (string) requestData["avquery"]);
+ queryID = new UUID((string)requestData["queryid"]);
+ returnAvatar = m_userDataBaseService.GenerateAgentPickerRequestResponse(queryID, (string)requestData["avquery"]);
}
- m_log.InfoFormat("[AVATARINFO]: Servicing Avatar Query: " + (string) requestData["avquery"]);
+ m_log.InfoFormat("[AVATARINFO]: Servicing Avatar Query: " + (string)requestData["avquery"]);
return AvatarPickerListtoXmlRPCResponse(queryID, returnAvatar);
}
public XmlRpcResponse XmlRPCAtRegion(XmlRpcRequest request)
{
XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
Hashtable responseData = new Hashtable();
string returnstring = "FALSE";
@@ -219,14 +247,14 @@ namespace OpenSim.Grid.UserServer.Modules
UUID regionUUID;
UUID avatarUUID;
- UUID.TryParse((string) requestData["avatar_id"], out avatarUUID);
- UUID.TryParse((string) requestData["region_uuid"], out regionUUID);
+ UUID.TryParse((string)requestData["avatar_id"], out avatarUUID);
+ UUID.TryParse((string)requestData["region_uuid"], out regionUUID);
if (avatarUUID != UUID.Zero)
{
UserProfileData userProfile = m_userDataBaseService.GetUserProfile(avatarUUID);
userProfile.CurrentAgent.Region = regionUUID;
- userProfile.CurrentAgent.Handle = (ulong) Convert.ToInt64((string) requestData["region_handle"]);
+ userProfile.CurrentAgent.Handle = (ulong)Convert.ToInt64((string)requestData["region_handle"]);
//userProfile.CurrentAgent.
m_userDataBaseService.CommitAgent(ref userProfile);
//setUserProfile(userProfile);
@@ -243,11 +271,11 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCGetUserMethodName(XmlRpcRequest request)
{
// XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
UserProfileData userProfile;
if (requestData.Contains("avatar_name"))
{
- string query = (string) requestData["avatar_name"];
+ string query = (string)requestData["avatar_name"];
if (null == query)
return CreateUnknownUserErrorResponse();
@@ -280,7 +308,7 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCGetUserMethodUUID(XmlRpcRequest request)
{
// XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
UserProfileData userProfile;
//CFK: this clogs the UserServer log and is not necessary at this time.
//CFK: m_log.Debug("METHOD BY UUID CALLED");
@@ -288,7 +316,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- UUID guess = new UUID((string) requestData["avatar_uuid"]);
+ UUID guess = new UUID((string)requestData["avatar_uuid"]);
userProfile = m_userDataBaseService.GetUserProfile(guess);
}
@@ -313,7 +341,7 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCGetAgentMethodUUID(XmlRpcRequest request)
{
XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
UserProfileData userProfile;
//CFK: this clogs the UserServer log and is not necessary at this time.
//CFK: m_log.Debug("METHOD BY UUID CALLED");
@@ -321,7 +349,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
UUID guess;
- UUID.TryParse((string) requestData["avatar_uuid"], out guess);
+ UUID.TryParse((string)requestData["avatar_uuid"], out guess);
if (guess == UUID.Zero)
{
@@ -362,7 +390,7 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCCheckAuthSession(XmlRpcRequest request)
{
XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
UserProfileData userProfile;
string authed = "FALSE";
@@ -371,12 +399,12 @@ namespace OpenSim.Grid.UserServer.Modules
UUID guess_aid;
UUID guess_sid;
- UUID.TryParse((string) requestData["avatar_uuid"], out guess_aid);
+ UUID.TryParse((string)requestData["avatar_uuid"], out guess_aid);
if (guess_aid == UUID.Zero)
{
return CreateUnknownUserErrorResponse();
}
- UUID.TryParse((string) requestData["session_id"], out guess_sid);
+ UUID.TryParse((string)requestData["session_id"], out guess_sid);
if (guess_sid == UUID.Zero)
{
return CreateUnknownUserErrorResponse();
@@ -404,7 +432,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
m_log.Debug("[UserManager]: Got request to update user profile");
XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
Hashtable responseData = new Hashtable();
if (!requestData.Contains("avatar_uuid"))
@@ -412,7 +440,7 @@ namespace OpenSim.Grid.UserServer.Modules
return CreateUnknownUserErrorResponse();
}
- UUID UserUUID = new UUID((string) requestData["avatar_uuid"]);
+ UUID UserUUID = new UUID((string)requestData["avatar_uuid"]);
UserProfileData userProfile = m_userDataBaseService.GetUserProfile(UserUUID);
if (null == userProfile)
{
@@ -424,11 +452,11 @@ namespace OpenSim.Grid.UserServer.Modules
}
if (requestData.Contains("FLImageID"))
{
- userProfile.FirstLifeImage = new UUID((string) requestData["FLImageID"]);
+ userProfile.FirstLifeImage = new UUID((string)requestData["FLImageID"]);
}
if (requestData.Contains("ImageID"))
{
- userProfile.Image = new UUID((string) requestData["ImageID"]);
+ userProfile.Image = new UUID((string)requestData["ImageID"]);
}
// dont' know how yet
if (requestData.Contains("MaturePublish"))
@@ -436,11 +464,11 @@ namespace OpenSim.Grid.UserServer.Modules
}
if (requestData.Contains("AboutText"))
{
- userProfile.AboutText = (string) requestData["AboutText"];
+ userProfile.AboutText = (string)requestData["AboutText"];
}
if (requestData.Contains("FLAboutText"))
{
- userProfile.FirstLifeAboutText = (string) requestData["FLAboutText"];
+ userProfile.FirstLifeAboutText = (string)requestData["FLAboutText"];
}
// not in DB yet.
if (requestData.Contains("ProfileURL"))
@@ -450,7 +478,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeRegion = Convert.ToUInt64((string) requestData["home_region"]);
+ userProfile.HomeRegion = Convert.ToUInt64((string)requestData["home_region"]);
}
catch (ArgumentException)
{
@@ -468,14 +496,14 @@ namespace OpenSim.Grid.UserServer.Modules
if (requestData.Contains("home_region_id"))
{
UUID regionID;
- UUID.TryParse((string) requestData["home_region_id"], out regionID);
+ UUID.TryParse((string)requestData["home_region_id"], out regionID);
userProfile.HomeRegionID = regionID;
}
if (requestData.Contains("home_pos_x"))
{
try
{
- userProfile.HomeLocationX = (float) Convert.ToDecimal((string) requestData["home_pos_x"]);
+ userProfile.HomeLocationX = (float)Convert.ToDecimal((string)requestData["home_pos_x"]);
}
catch (InvalidCastException)
{
@@ -486,7 +514,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeLocationY = (float) Convert.ToDecimal((string) requestData["home_pos_y"]);
+ userProfile.HomeLocationY = (float)Convert.ToDecimal((string)requestData["home_pos_y"]);
}
catch (InvalidCastException)
{
@@ -497,7 +525,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeLocationZ = (float) Convert.ToDecimal((string) requestData["home_pos_z"]);
+ userProfile.HomeLocationZ = (float)Convert.ToDecimal((string)requestData["home_pos_z"]);
}
catch (InvalidCastException)
{
@@ -508,7 +536,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeLookAtX = (float) Convert.ToDecimal((string) requestData["home_look_x"]);
+ userProfile.HomeLookAtX = (float)Convert.ToDecimal((string)requestData["home_look_x"]);
}
catch (InvalidCastException)
{
@@ -519,7 +547,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeLookAtY = (float) Convert.ToDecimal((string) requestData["home_look_y"]);
+ userProfile.HomeLookAtY = (float)Convert.ToDecimal((string)requestData["home_look_y"]);
}
catch (InvalidCastException)
{
@@ -530,7 +558,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.HomeLookAtZ = (float) Convert.ToDecimal((string) requestData["home_look_z"]);
+ userProfile.HomeLookAtZ = (float)Convert.ToDecimal((string)requestData["home_look_z"]);
}
catch (InvalidCastException)
{
@@ -541,7 +569,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.UserFlags = Convert.ToInt32((string) requestData["user_flags"]);
+ userProfile.UserFlags = Convert.ToInt32((string)requestData["user_flags"]);
}
catch (InvalidCastException)
{
@@ -552,7 +580,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.GodLevel = Convert.ToInt32((string) requestData["god_level"]);
+ userProfile.GodLevel = Convert.ToInt32((string)requestData["god_level"]);
}
catch (InvalidCastException)
{
@@ -563,7 +591,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.CustomType = (string) requestData["custom_type"];
+ userProfile.CustomType = (string)requestData["custom_type"];
}
catch (InvalidCastException)
{
@@ -574,7 +602,7 @@ namespace OpenSim.Grid.UserServer.Modules
{
try
{
- userProfile.Partner = new UUID((string) requestData["partner"]);
+ userProfile.Partner = new UUID((string)requestData["partner"]);
}
catch (InvalidCastException)
{
@@ -596,7 +624,7 @@ namespace OpenSim.Grid.UserServer.Modules
public XmlRpcResponse XmlRPCLogOffUserMethodUUID(XmlRpcRequest request)
{
XmlRpcResponse response = new XmlRpcResponse();
- Hashtable requestData = (Hashtable) request.Params[0];
+ Hashtable requestData = (Hashtable)request.Params[0];
if (requestData.Contains("avatar_uuid"))
{
@@ -685,6 +713,6 @@ namespace OpenSim.Grid.UserServer.Modules
public void HandleRegionShutdown(UUID regionID)
{
m_userDataBaseService.LogoutUsers(regionID);
- }
+ }
}
}
--
cgit v1.1