diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs | 145 |
1 files changed, 136 insertions, 9 deletions
diff --git a/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs b/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs index 2df129b..fdb24b1 100644 --- a/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs +++ b/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs | |||
@@ -33,6 +33,7 @@ using System.Net.Security; | |||
33 | using System.Security.Cryptography.X509Certificates; | 33 | using System.Security.Cryptography.X509Certificates; |
34 | using System.Reflection; | 34 | using System.Reflection; |
35 | using System.Threading; | 35 | using System.Threading; |
36 | using System.Web; | ||
36 | 37 | ||
37 | using OpenMetaverse; | 38 | using OpenMetaverse; |
38 | using OpenMetaverse.StructuredData; | 39 | using OpenMetaverse.StructuredData; |
@@ -75,8 +76,9 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
75 | public int src_version; | 76 | public int src_version; |
76 | public int src_parent_estate_id; | 77 | public int src_parent_estate_id; |
77 | public bool visible_to_parent; | 78 | public bool visible_to_parent; |
79 | public string teleported_into_region; | ||
78 | } | 80 | } |
79 | 81 | ||
80 | public class OpenGridProtocolModule : IRegionModule | 82 | public class OpenGridProtocolModule : IRegionModule |
81 | { | 83 | { |
82 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 84 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
@@ -84,6 +86,9 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
84 | 86 | ||
85 | private Dictionary<string, AgentCircuitData> CapsLoginID = new Dictionary<string, AgentCircuitData>(); | 87 | private Dictionary<string, AgentCircuitData> CapsLoginID = new Dictionary<string, AgentCircuitData>(); |
86 | private Dictionary<UUID, OGPState> m_OGPState = new Dictionary<UUID, OGPState>(); | 88 | private Dictionary<UUID, OGPState> m_OGPState = new Dictionary<UUID, OGPState>(); |
89 | private Dictionary<string, string> m_loginToRegionState = new Dictionary<string, string>(); | ||
90 | |||
91 | |||
87 | private string LastNameSuffix = "_EXTERNAL"; | 92 | private string LastNameSuffix = "_EXTERNAL"; |
88 | private string FirstNamePrefix = ""; | 93 | private string FirstNamePrefix = ""; |
89 | private string httpsCN = ""; | 94 | private string httpsCN = ""; |
@@ -127,7 +132,7 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
127 | if (m_scene.Count == 0) | 132 | if (m_scene.Count == 0) |
128 | { | 133 | { |
129 | scene.AddLLSDHandler("/agent/", ProcessAgentDomainMessage); | 134 | scene.AddLLSDHandler("/agent/", ProcessAgentDomainMessage); |
130 | scene.AddLLSDHandler("/", ProcessAgentDomainMessage); | 135 | scene.AddLLSDHandler("/", ProcessRegionDomainSeed); |
131 | try | 136 | try |
132 | { | 137 | { |
133 | ServicePointManager.ServerCertificateValidationCallback += customXertificateValidation; | 138 | ServicePointManager.ServerCertificateValidationCallback += customXertificateValidation; |
@@ -148,6 +153,12 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
148 | } | 153 | } |
149 | 154 | ||
150 | } | 155 | } |
156 | // can't pick the region 'agent' because it would conflict with our agent domain handler | ||
157 | // a zero length region name would conflict with are base region seed cap | ||
158 | if (!SceneListDuplicateCheck(scene.RegionInfo.RegionName) && scene.RegionInfo.RegionName.ToLower() != "agent" && scene.RegionInfo.RegionName.Length > 0) | ||
159 | { | ||
160 | scene.AddLLSDHandler("/" + HttpUtility.UrlPathEncode(scene.RegionInfo.RegionName.ToLower()),ProcessRegionDomainSeed); | ||
161 | } | ||
151 | 162 | ||
152 | if (!m_scene.Contains(scene)) | 163 | if (!m_scene.Contains(scene)) |
153 | m_scene.Add(scene); | 164 | m_scene.Add(scene); |
@@ -196,6 +207,26 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
196 | 207 | ||
197 | #endregion | 208 | #endregion |
198 | 209 | ||
210 | public LLSD ProcessRegionDomainSeed(string path, LLSD request, string endpoint) | ||
211 | { | ||
212 | string[] pathSegments = path.Split('/'); | ||
213 | |||
214 | if (pathSegments.Length <= 1) | ||
215 | { | ||
216 | return GenerateNoHandlerMessage(); | ||
217 | |||
218 | } | ||
219 | |||
220 | return GenerateRezAvatarRequestMessage(pathSegments[1]); | ||
221 | |||
222 | |||
223 | |||
224 | //m_log.InfoFormat("[OGP]: path {0}, segments {1} segment[1] {2} Last segment {3}", | ||
225 | // path, pathSegments.Length, pathSegments[1], pathSegments[pathSegments.Length - 1]); | ||
226 | //return new LLSDMap(); | ||
227 | |||
228 | } | ||
229 | |||
199 | public LLSD ProcessAgentDomainMessage(string path, LLSD request, string endpoint) | 230 | public LLSD ProcessAgentDomainMessage(string path, LLSD request, string endpoint) |
200 | { | 231 | { |
201 | // /agent/* | 232 | // /agent/* |
@@ -206,12 +237,10 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
206 | return GenerateNoHandlerMessage(); | 237 | return GenerateNoHandlerMessage(); |
207 | 238 | ||
208 | } | 239 | } |
209 | |||
210 | if (pathSegments[0].Length == 0 && pathSegments[1].Length == 0) | 240 | if (pathSegments[0].Length == 0 && pathSegments[1].Length == 0) |
211 | { | 241 | { |
212 | return GenerateRezAvatarRequestMessage(""); | 242 | return GenerateRezAvatarRequestMessage(""); |
213 | } | 243 | } |
214 | |||
215 | m_log.InfoFormat("[OGP]: path {0}, segments {1} segment[1] {2} Last segment {3}", | 244 | m_log.InfoFormat("[OGP]: path {0}, segments {1} segment[1] {2} Last segment {3}", |
216 | path, pathSegments.Length, pathSegments[1], pathSegments[pathSegments.Length - 1]); | 245 | path, pathSegments.Length, pathSegments[1], pathSegments[pathSegments.Length - 1]); |
217 | 246 | ||
@@ -248,7 +277,33 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
248 | 277 | ||
249 | private LLSD GenerateRezAvatarRequestMessage(string regionname) | 278 | private LLSD GenerateRezAvatarRequestMessage(string regionname) |
250 | { | 279 | { |
251 | Scene region = GetRootScene(); | 280 | Scene region = null; |
281 | bool usedroot = false; | ||
282 | |||
283 | if (regionname.Length == 0) | ||
284 | { | ||
285 | region = GetRootScene(); | ||
286 | usedroot = true; | ||
287 | } | ||
288 | else | ||
289 | { | ||
290 | region = GetScene(HttpUtility.UrlDecode(regionname).ToLower()); | ||
291 | } | ||
292 | |||
293 | // this shouldn't happen since we don't listen for a region that is down.. but | ||
294 | // it might if the region was taken down or is in the middle of restarting | ||
295 | |||
296 | if (region == null) | ||
297 | { | ||
298 | region = GetRootScene(); | ||
299 | usedroot = true; | ||
300 | } | ||
301 | |||
302 | UUID statekeeper = UUID.Random(); | ||
303 | |||
304 | |||
305 | |||
306 | |||
252 | RegionInfo reg = region.RegionInfo; | 307 | RegionInfo reg = region.RegionInfo; |
253 | 308 | ||
254 | LLSDMap responseMap = new LLSDMap(); | 309 | LLSDMap responseMap = new LLSDMap(); |
@@ -256,7 +311,18 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
256 | //string regionCapsHttpProtocol = "http://"; | 311 | //string regionCapsHttpProtocol = "http://"; |
257 | string httpaddr = reg.ExternalHostName; | 312 | string httpaddr = reg.ExternalHostName; |
258 | string urlport = reg.HttpPort.ToString(); | 313 | string urlport = reg.HttpPort.ToString(); |
259 | string requestpath = "/agent/" + UUID.Zero + "/rez_avatar/request"; | 314 | string requestpath = "/agent/" + statekeeper + "/rez_avatar/request"; |
315 | |||
316 | if (!usedroot) | ||
317 | { | ||
318 | lock (m_loginToRegionState) | ||
319 | { | ||
320 | if (!m_loginToRegionState.ContainsKey(requestpath)) | ||
321 | { | ||
322 | m_loginToRegionState.Add(requestpath, region.RegionInfo.RegionName.ToLower()); | ||
323 | } | ||
324 | } | ||
325 | } | ||
260 | 326 | ||
261 | if (httpSSL) | 327 | if (httpSSL) |
262 | { | 328 | { |
@@ -301,8 +367,26 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
301 | 367 | ||
302 | LLSDMap requestMap = (LLSDMap)request; | 368 | LLSDMap requestMap = (LLSDMap)request; |
303 | 369 | ||
304 | Scene homeScene = GetRootScene(); | ||
305 | 370 | ||
371 | Scene homeScene = null; | ||
372 | |||
373 | lock (m_loginToRegionState) | ||
374 | { | ||
375 | if (m_loginToRegionState.ContainsKey(path)) | ||
376 | { | ||
377 | homeScene = GetScene(m_loginToRegionState[path]); | ||
378 | m_loginToRegionState.Remove(path); | ||
379 | |||
380 | if (homeScene == null) | ||
381 | homeScene = GetRootScene(); | ||
382 | } | ||
383 | else | ||
384 | { | ||
385 | homeScene = GetRootScene(); | ||
386 | } | ||
387 | } | ||
388 | |||
389 | // Homescene is still null, we must have no regions that are up | ||
306 | if (homeScene == null) | 390 | if (homeScene == null) |
307 | return GenerateNoHandlerMessage(); | 391 | return GenerateNoHandlerMessage(); |
308 | 392 | ||
@@ -338,6 +422,7 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
338 | userState.src_can_see_mainland = requestMap["src_can_see_mainland"].AsBoolean(); | 422 | userState.src_can_see_mainland = requestMap["src_can_see_mainland"].AsBoolean(); |
339 | userState.src_estate_id = requestMap["src_estate_id"].AsInteger(); | 423 | userState.src_estate_id = requestMap["src_estate_id"].AsInteger(); |
340 | userState.local_agent_id = LocalAgentID; | 424 | userState.local_agent_id = LocalAgentID; |
425 | userState.teleported_into_region = reg.RegionName.ToLower(); | ||
341 | 426 | ||
342 | UpdateOGPState(LocalAgentID, userState); | 427 | UpdateOGPState(LocalAgentID, userState); |
343 | 428 | ||
@@ -548,8 +633,15 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
548 | userData.SecureSessionID = SecureSessionID; | 633 | userData.SecureSessionID = SecureSessionID; |
549 | userData.SessionID = SessionID; | 634 | userData.SessionID = SessionID; |
550 | 635 | ||
636 | OGPState userState = GetOGPState(userData.AgentID); | ||
637 | |||
551 | // Locate a home scene suitable for the user. | 638 | // Locate a home scene suitable for the user. |
552 | Scene homeScene = GetRootScene(); | 639 | Scene homeScene = null; |
640 | |||
641 | homeScene = GetScene(userState.teleported_into_region); | ||
642 | |||
643 | if (homeScene == null) | ||
644 | homeScene = GetRootScene(); | ||
553 | 645 | ||
554 | if (homeScene != null) | 646 | if (homeScene != null) |
555 | { | 647 | { |
@@ -562,7 +654,7 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
562 | homeScene.ChangeCircuitCode(userData.circuitcode,(uint)circuitcode); | 654 | homeScene.ChangeCircuitCode(userData.circuitcode,(uint)circuitcode); |
563 | 655 | ||
564 | // Load state | 656 | // Load state |
565 | OGPState userState = GetOGPState(userData.AgentID); | 657 | |
566 | 658 | ||
567 | // Keep state changes | 659 | // Keep state changes |
568 | userState.first_name = requestMap["first_name"].AsString(); | 660 | userState.first_name = requestMap["first_name"].AsString(); |
@@ -926,6 +1018,24 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
926 | return ReturnScene; | 1018 | return ReturnScene; |
927 | } | 1019 | } |
928 | 1020 | ||
1021 | private Scene GetScene(string scenename) | ||
1022 | { | ||
1023 | Scene ReturnScene = null; | ||
1024 | lock (m_scene) | ||
1025 | { | ||
1026 | foreach (Scene s in m_scene) | ||
1027 | { | ||
1028 | if (s.RegionInfo.RegionName.ToLower() == scenename) | ||
1029 | { | ||
1030 | ReturnScene = s; | ||
1031 | break; | ||
1032 | } | ||
1033 | } | ||
1034 | } | ||
1035 | |||
1036 | return ReturnScene; | ||
1037 | } | ||
1038 | |||
929 | private ulong GetOSCompatibleRegionHandle(RegionInfo reg) | 1039 | private ulong GetOSCompatibleRegionHandle(RegionInfo reg) |
930 | { | 1040 | { |
931 | return Util.UIntsToLong(reg.RegionLocX, reg.RegionLocY); | 1041 | return Util.UIntsToLong(reg.RegionLocX, reg.RegionLocY); |
@@ -957,6 +1067,7 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
957 | returnState.src_version = 1; | 1067 | returnState.src_version = 1; |
958 | returnState.src_parent_estate_id = 1; | 1068 | returnState.src_parent_estate_id = 1; |
959 | returnState.visible_to_parent = true; | 1069 | returnState.visible_to_parent = true; |
1070 | returnState.teleported_into_region = ""; | ||
960 | 1071 | ||
961 | return returnState; | 1072 | return returnState; |
962 | } | 1073 | } |
@@ -999,6 +1110,22 @@ namespace OpenSim.Region.Environment.Modules.InterGrid | |||
999 | } | 1110 | } |
1000 | } | 1111 | } |
1001 | } | 1112 | } |
1113 | private bool SceneListDuplicateCheck(string str) | ||
1114 | { | ||
1115 | // no lock, called from locked space! | ||
1116 | bool found = false; | ||
1117 | |||
1118 | foreach (Scene s in m_scene) | ||
1119 | { | ||
1120 | if (s.RegionInfo.RegionName == str) | ||
1121 | { | ||
1122 | found = true; | ||
1123 | break; | ||
1124 | } | ||
1125 | } | ||
1126 | |||
1127 | return found; | ||
1128 | } | ||
1002 | 1129 | ||
1003 | public void ShutdownConnection(UUID avatarId, OpenGridProtocolModule mod) | 1130 | public void ShutdownConnection(UUID avatarId, OpenGridProtocolModule mod) |
1004 | { | 1131 | { |