From e777f88028322c9a7042ba20669b00fd9fbd573c Mon Sep 17 00:00:00 2001
From: Teravus Ovares
Date: Tue, 15 Apr 2008 23:10:12 +0000
Subject: * A tweak of the caps system so that new caps have random paths
instead of a fixed path * This allows caps requests to be routed to regions
where the agent is currently a root agent instead of the region that they
logged into as it did previously. * This fixes a wide variety of bugs related
to 'can't do X once i've crossed a border'. * The first seed cap request
fails, the second one works. (this generates an error message on the
console) * Experimental.
---
OpenSim/Region/Environment/Scenes/Scene.cs | 21 +++++++++++++++++++--
OpenSim/Region/Environment/Scenes/SceneBase.cs | 12 ++++++++++++
2 files changed, 31 insertions(+), 2 deletions(-)
(limited to 'OpenSim/Region/Environment')
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs
index ba8a356..957c75c 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.cs
@@ -1867,8 +1867,25 @@ namespace OpenSim.Region.Environment.Scenes
///
///
public void AddCapsHandler(LLUUID agentId)
- {
- String capsObjectPath = GetCapsPath(agentId);
+ {
+ // Here we clear out old Caps handlers for the agent
+ // this is required because we potentially have multiple simulators in an instance nearby.
+ Caps oldcap = null;
+ lock (m_capsHandlers)
+ {
+ if (m_capsHandlers.ContainsKey(agentId))
+ oldcap = m_capsHandlers[agentId];
+ }
+ if (oldcap != null)
+ {
+ oldcap.DeregisterHandlers();
+ }
+
+ // Generate a new base caps path LLUUID.Random().ToString() instead of agentId.ToString()
+ // If the caps paths are not different for each region, the client and sim will do weird
+ // things like send the request to a region the agent is no longer in.
+
+ String capsObjectPath = GetNewCapsPath(agentId);
m_log.DebugFormat(
"[CAPS]: Setting up CAPS handler for root agent {0} in {1}",
diff --git a/OpenSim/Region/Environment/Scenes/SceneBase.cs b/OpenSim/Region/Environment/Scenes/SceneBase.cs
index 5551173..f863bff 100644
--- a/OpenSim/Region/Environment/Scenes/SceneBase.cs
+++ b/OpenSim/Region/Environment/Scenes/SceneBase.cs
@@ -214,5 +214,17 @@ namespace OpenSim.Region.Environment.Scenes
return null;
}
+ public string GetNewCapsPath(LLUUID agentID)
+ {
+ if (capsPaths.ContainsKey(agentID))
+ {
+ capsPaths[agentID] = LLUUID.Random().ToString();
+ }
+ else
+ {
+ capsPaths.Add(agentID, LLUUID.Random().ToString());
+ }
+ return GetCapsPath(agentID);
+ }
}
}
--
cgit v1.1