aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework/Communications/LoginService.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Framework/Communications/LoginService.cs')
-rw-r--r--OpenSim/Framework/Communications/LoginService.cs110
1 files changed, 79 insertions, 31 deletions
diff --git a/OpenSim/Framework/Communications/LoginService.cs b/OpenSim/Framework/Communications/LoginService.cs
index b84f5b6..99b5df7 100644
--- a/OpenSim/Framework/Communications/LoginService.cs
+++ b/OpenSim/Framework/Communications/LoginService.cs
@@ -90,13 +90,6 @@ namespace OpenSim.Framework.Communications
90 { 90 {
91 } 91 }
92 92
93 /// <summary>
94 /// Get the initial login inventory skeleton (in other words, the folder structure) for the given user.
95 /// </summary>
96 /// <param name="userID"></param>
97 /// <returns></returns>
98 /// <exception cref='System.Exception'>This will be thrown if there is a problem with the inventory service</exception>
99 protected abstract InventoryData GetInventorySkeleton(UUID userID);
100 93
101 /// <summary> 94 /// <summary>
102 /// Called when we receive the client's initial XMLRPC login_to_simulator request message 95 /// Called when we receive the client's initial XMLRPC login_to_simulator request message
@@ -107,13 +100,13 @@ namespace OpenSim.Framework.Communications
107 { 100 {
108 // Temporary fix 101 // Temporary fix
109 m_loginMutex.WaitOne(); 102 m_loginMutex.WaitOne();
110 103
111 try 104 try
112 { 105 {
113 //CFK: CustomizeResponse contains sufficient strings to alleviate the need for this. 106 //CFK: CustomizeResponse contains sufficient strings to alleviate the need for this.
114 //CKF: m_log.Info("[LOGIN]: Attempting login now..."); 107 //CKF: m_log.Info("[LOGIN]: Attempting login now...");
115 XmlRpcResponse response = new XmlRpcResponse(); 108 XmlRpcResponse response = new XmlRpcResponse();
116 Hashtable requestData = (Hashtable) request.Params[0]; 109 Hashtable requestData = (Hashtable)request.Params[0];
117 110
118 SniffLoginKey((Uri)request.Params[2], requestData); 111 SniffLoginKey((Uri)request.Params[2], requestData);
119 112
@@ -301,14 +294,14 @@ namespace OpenSim.Framework.Communications
301 { 294 {
302 if (requestData.Contains("passwd")) 295 if (requestData.Contains("passwd"))
303 { 296 {
304 string passwd = (string) requestData["passwd"]; 297 string passwd = (string)requestData["passwd"];
305 GoodLogin = AuthenticateUser(userProfile, passwd); 298 GoodLogin = AuthenticateUser(userProfile, passwd);
306 } 299 }
307 if (!GoodLogin && (requestData.Contains("web_login_key"))) 300 if (!GoodLogin && (requestData.Contains("web_login_key")))
308 { 301 {
309 try 302 try
310 { 303 {
311 UUID webloginkey = new UUID((string) requestData["web_login_key"]); 304 UUID webloginkey = new UUID((string)requestData["web_login_key"]);
312 GoodLogin = AuthenticateUser(userProfile, webloginkey); 305 GoodLogin = AuthenticateUser(userProfile, webloginkey);
313 } 306 }
314 catch (Exception e) 307 catch (Exception e)
@@ -372,7 +365,7 @@ namespace OpenSim.Framework.Communications
372 m_log.Info("[LOGIN]: LLSD StartLocation Requested: " + map["start"].AsString()); 365 m_log.Info("[LOGIN]: LLSD StartLocation Requested: " + map["start"].AsString());
373 startLocationRequest = map["start"].AsString(); 366 startLocationRequest = map["start"].AsString();
374 } 367 }
375 m_log.Info("[LOGIN]: LLSD Login Requested for: '" + firstname+"' '"+lastname+"' / "+passwd); 368 m_log.Info("[LOGIN]: LLSD Login Requested for: '" + firstname + "' '" + lastname + "' / " + passwd);
376 369
377 if (!TryAuthenticateLLSDLogin(firstname, lastname, passwd, out userProfile)) 370 if (!TryAuthenticateLLSDLogin(firstname, lastname, passwd, out userProfile))
378 { 371 {
@@ -385,7 +378,7 @@ namespace OpenSim.Framework.Communications
385 else 378 else
386 return logResponse.CreateLoginFailedResponseLLSD(); 379 return logResponse.CreateLoginFailedResponseLLSD();
387 380
388 381
389 if (userProfile.GodLevel < m_minLoginLevel) 382 if (userProfile.GodLevel < m_minLoginLevel)
390 { 383 {
391 return logResponse.CreateLoginBlockedResponseLLSD(); 384 return logResponse.CreateLoginBlockedResponseLLSD();
@@ -520,7 +513,7 @@ namespace OpenSim.Framework.Communications
520 string firstname = String.Empty; 513 string firstname = String.Empty;
521 string lastname = String.Empty; 514 string lastname = String.Empty;
522 string location = String.Empty; 515 string location = String.Empty;
523 string region =String.Empty; 516 string region = String.Empty;
524 string grid = String.Empty; 517 string grid = String.Empty;
525 string channel = String.Empty; 518 string channel = String.Empty;
526 string version = String.Empty; 519 string version = String.Empty;
@@ -560,7 +553,7 @@ namespace OpenSim.Framework.Communications
560 lang = wfcut.Replace((string)keysvals["lang"], String.Empty, 99999); 553 lang = wfcut.Replace((string)keysvals["lang"], String.Empty, 99999);
561 554
562 if (keysvals.Contains("password")) 555 if (keysvals.Contains("password"))
563 password = wfcut.Replace((string)keysvals["password"], String.Empty, 99999); 556 password = wfcut.Replace((string)keysvals["password"], String.Empty, 99999);
564 557
565 // load our login form. 558 // load our login form.
566 string loginform = GetLoginForm(firstname, lastname, location, region, grid, channel, version, lang, password, errormessages); 559 string loginform = GetLoginForm(firstname, lastname, location, region, grid, channel, version, lang, password, errormessages);
@@ -578,11 +571,11 @@ namespace OpenSim.Framework.Communications
578 UUID webloginkey = UUID.Random(); 571 UUID webloginkey = UUID.Random();
579 m_userManager.StoreWebLoginKey(user.ID, webloginkey); 572 m_userManager.StoreWebLoginKey(user.ID, webloginkey);
580 //statuscode = 301; 573 //statuscode = 301;
581 574
582// string redirectURL = "about:blank?redirect-http-hack=" + 575 // string redirectURL = "about:blank?redirect-http-hack=" +
583// HttpUtility.UrlEncode("secondlife:///app/login?first_name=" + firstname + "&last_name=" + 576 // HttpUtility.UrlEncode("secondlife:///app/login?first_name=" + firstname + "&last_name=" +
584// lastname + 577 // lastname +
585// "&location=" + location + "&grid=Other&web_login_key=" + webloginkey.ToString()); 578 // "&location=" + location + "&grid=Other&web_login_key=" + webloginkey.ToString());
586 //m_log.Info("[WEB]: R:" + redirectURL); 579 //m_log.Info("[WEB]: R:" + redirectURL);
587 returnactions["int_response_code"] = statuscode; 580 returnactions["int_response_code"] = statuscode;
588 //returnactions["str_redirect_location"] = redirectURL; 581 //returnactions["str_redirect_location"] = redirectURL;
@@ -612,7 +605,7 @@ namespace OpenSim.Framework.Communications
612 { 605 {
613 // inject our values in the form at the markers 606 // inject our values in the form at the markers
614 607
615 string loginform=String.Empty; 608 string loginform = String.Empty;
616 string file = Path.Combine(Util.configDir(), "http_loginform.html"); 609 string file = Path.Combine(Util.configDir(), "http_loginform.html");
617 if (!File.Exists(file)) 610 if (!File.Exists(file))
618 { 611 {
@@ -753,7 +746,7 @@ namespace OpenSim.Framework.Communications
753 m_log.InfoFormat("[LOGIN]: Authenticating {0} {1} ({2})", profile.FirstName, profile.SurName, profile.ID); 746 m_log.InfoFormat("[LOGIN]: Authenticating {0} {1} ({2})", profile.FirstName, profile.SurName, profile.ID);
754 747
755 // Match web login key unless it's the default weblogin key UUID.Zero 748 // Match web login key unless it's the default weblogin key UUID.Zero
756 passwordSuccess = ((profile.WebLoginKey==webloginkey) && profile.WebLoginKey != UUID.Zero); 749 passwordSuccess = ((profile.WebLoginKey == webloginkey) && profile.WebLoginKey != UUID.Zero);
757 750
758 return passwordSuccess; 751 return passwordSuccess;
759 } 752 }
@@ -801,7 +794,7 @@ namespace OpenSim.Framework.Communications
801 LoginResponse.BuddyList.BuddyInfo buddyitem = new LoginResponse.BuddyList.BuddyInfo(fl.Friend); 794 LoginResponse.BuddyList.BuddyInfo buddyitem = new LoginResponse.BuddyList.BuddyInfo(fl.Friend);
802 buddyitem.BuddyID = fl.Friend; 795 buddyitem.BuddyID = fl.Friend;
803 buddyitem.BuddyRightsHave = (int)fl.FriendListOwnerPerms; 796 buddyitem.BuddyRightsHave = (int)fl.FriendListOwnerPerms;
804 buddyitem.BuddyRightsGiven = (int) fl.FriendPerms; 797 buddyitem.BuddyRightsGiven = (int)fl.FriendPerms;
805 buddylistreturn.AddNewBuddy(buddyitem); 798 buddylistreturn.AddNewBuddy(buddyitem);
806 } 799 }
807 return buddylistreturn; 800 return buddylistreturn;
@@ -996,14 +989,6 @@ namespace OpenSim.Framework.Communications
996 return false; 989 return false;
997 } 990 }
998 991
999 // Customise the response
1000 //response.Home =
1001 // string.Format(
1002 // "{{'region_handle':[r{0},r{1}], 'position':[r{2},r{3},r{4}], 'look_at':[r{5},r{6},r{7}]}}",
1003 // (SimInfo.regionLocX * Constants.RegionSize),
1004 // (SimInfo.regionLocY*Constants.RegionSize),
1005 // theUser.HomeLocation.X, theUser.HomeLocation.Y, theUser.HomeLocation.Z,
1006 // theUser.HomeLookAt.X, theUser.HomeLookAt.Y, theUser.HomeLookAt.Z);
1007 theUser.CurrentAgent.Position = new Vector3(128, 128, 0); 992 theUser.CurrentAgent.Position = new Vector3(128, 128, 0);
1008 response.StartLocation = "safe"; 993 response.StartLocation = "safe";
1009 994
@@ -1041,5 +1026,68 @@ namespace OpenSim.Framework.Communications
1041 } 1026 }
1042 response.ActiveGestures = list; 1027 response.ActiveGestures = list;
1043 } 1028 }
1029
1030 /// <summary>
1031 /// Get the initial login inventory skeleton (in other words, the folder structure) for the given user.
1032 /// </summary>
1033 /// <param name="userID"></param>
1034 /// <returns></returns>
1035 /// <exception cref='System.Exception'>This will be thrown if there is a problem with the inventory service</exception>
1036 protected InventoryData GetInventorySkeleton(UUID userID)
1037 {
1038 List<InventoryFolderBase> folders = m_inventoryService.GetInventorySkeleton(userID);
1039
1040 // If we have user auth but no inventory folders for some reason, create a new set of folders.
1041 if (folders == null || folders.Count == 0)
1042 {
1043 m_log.InfoFormat(
1044 "[LOGIN]: A root inventory folder for user {0} was not found. Requesting creation.", userID);
1045
1046 // Although the create user function creates a new agent inventory along with a new user profile, some
1047 // tools are creating the user profile directly in the database without creating the inventory. At
1048 // this time we'll accomodate them by lazily creating the user inventory now if it doesn't already
1049 // exist.
1050 if (!m_inventoryService.CreateNewUserInventory(userID))
1051 {
1052 throw new Exception(
1053 String.Format(
1054 "The inventory creation request for user {0} did not succeed."
1055 + " Please contact your inventory service provider for more information.",
1056 userID));
1057 }
1058
1059 m_log.InfoFormat("[LOGIN]: A new inventory skeleton was successfully created for user {0}", userID);
1060
1061 folders = m_inventoryService.GetInventorySkeleton(userID);
1062
1063 if (folders == null || folders.Count == 0)
1064 {
1065 throw new Exception(
1066 String.Format(
1067 "A root inventory folder for user {0} could not be retrieved from the inventory service",
1068 userID));
1069 }
1070 }
1071
1072 UUID rootID = UUID.Zero;
1073 ArrayList AgentInventoryArray = new ArrayList();
1074 Hashtable TempHash;
1075 foreach (InventoryFolderBase InvFolder in folders)
1076 {
1077 if (InvFolder.ParentID == UUID.Zero)
1078 {
1079 rootID = InvFolder.ID;
1080 }
1081 TempHash = new Hashtable();
1082 TempHash["name"] = InvFolder.Name;
1083 TempHash["parent_id"] = InvFolder.ParentID.ToString();
1084 TempHash["version"] = (Int32)InvFolder.Version;
1085 TempHash["type_default"] = (Int32)InvFolder.Type;
1086 TempHash["folder_id"] = InvFolder.ID.ToString();
1087 AgentInventoryArray.Add(TempHash);
1088 }
1089
1090 return new InventoryData(AgentInventoryArray, rootID);
1091 }
1044 } 1092 }
1045} 1093}