From c1beb85315aad09197ca7ffaa8ec194346af82cb Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Thu, 20 Mar 2008 20:04:45 +0000 Subject: * First draft resolution of mantis 777, 734, 389 - scripts do not save in non-home regions * Should work in multi-region standalone and grid modes * This should also solve other non-home region caps issues (map requests, RC client inventory requests, etc) * We now pass CAPS information on to the destination region on region crossing, and set up a CAPS object when an agent becomes a master * Current limitation is that this will only work if your http_listener_port is 9000 * This is a very early code cut (lots of bad practice, hard coding and inefficiency). However, I wanted to get this out there for feedback and my own sanity. Next few patches will clean up the mess. --- OpenSim/Region/Environment/Scenes/Scene.cs | 100 +++++++++++---------- OpenSim/Region/Environment/Scenes/SceneBase.cs | 15 ++++ .../Scenes/SceneCommunicationService.cs | 8 +- OpenSim/Region/Environment/Scenes/ScenePresence.cs | 11 ++- 4 files changed, 85 insertions(+), 49 deletions(-) (limited to 'OpenSim/Region/Environment') diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index e036a3a..7948a6f 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs @@ -1649,53 +1649,11 @@ namespace OpenSim.Region.Environment.Scenes { if (regionHandle == m_regInfo.RegionHandle) { - if (agent.CapsPath != String.Empty) - { - m_log.DebugFormat( - "[CONNECTION DEBUGGING]: Setting up CAPS handler for avatar {0} at {1} in {2}", - agent.AgentID, agent.CapsPath, RegionInfo.RegionName); + capsPaths[agent.AgentID] = agent.CapsPath; - Caps cap = - new Caps(AssetCache, m_httpListener, m_regInfo.ExternalHostName, m_httpListener.Port, - agent.CapsPath, agent.AgentID, m_dumpAssetsToFile); - - Util.SetCapsURL(agent.AgentID, - "http://" + m_regInfo.ExternalHostName + ":" + m_httpListener.Port.ToString() + - "/CAPS/" + agent.CapsPath + "0000/"); - cap.RegisterHandlers(); - if (agent.child) - { - - } - cap.AddNewInventoryItem = AddInventoryItem; - cap.ItemUpdatedCall = CapsUpdateInventoryItemAsset; - cap.TaskScriptUpdatedCall = CapsUpdateTaskInventoryScriptAsset; - cap.CAPSFetchInventoryDescendents = CommsManager.UserProfileCacheService.HandleFetchInventoryDescendentsCAPS; - - if (m_capsHandlers.ContainsKey(agent.AgentID)) - { - m_log.DebugFormat( - "[CONNECTION DEBUGGING]: Caps path already in use for avatar {0} in region {1}", - agent.AgentID, RegionInfo.RegionName); - - try - { - m_capsHandlers[agent.AgentID] = cap; - } - catch (KeyNotFoundException) - { - m_log.DebugFormat( - "[CONNECTION DEBUGGING]: Caught exception adding handler for avatar {0} at {1}", - agent.AgentID, RegionInfo.RegionName); - - // Fix for a potential race condition. - m_capsHandlers.Add(agent.AgentID, cap); - } - } - else - { - m_capsHandlers.Add(agent.AgentID, cap); - } + if (!agent.child) + { + AddCapsHandler(agent.AgentID); } else { @@ -1716,6 +1674,56 @@ namespace OpenSim.Region.Environment.Scenes "[CONNECTION DEBUGGING]: Skipping this region for welcoming avatar {0} [{1}] at {2}", agent.AgentID, regionHandle, RegionInfo.RegionName); } + } + + /// + /// Add a caps handler for the given agent. + /// + /// + /// + public void AddCapsHandler(LLUUID agentId) + { + String capsObjectPath = GetCapsPath(agentId); + + m_log.DebugFormat( + "[CONNECTION DEBUGGING]: Setting up CAPS handler for avatar {0} at {1} in {2}", + agentId, capsObjectPath, RegionInfo.RegionName); + + Caps cap = + new Caps(AssetCache, m_httpListener, m_regInfo.ExternalHostName, m_httpListener.Port, + capsObjectPath, agentId, m_dumpAssetsToFile); + + cap.RegisterHandlers(); + + cap.AddNewInventoryItem = AddInventoryItem; + cap.ItemUpdatedCall = CapsUpdateInventoryItemAsset; + cap.TaskScriptUpdatedCall = CapsUpdateTaskInventoryScriptAsset; + cap.CAPSFetchInventoryDescendents = CommsManager.UserProfileCacheService.HandleFetchInventoryDescendentsCAPS; + + if (m_capsHandlers.ContainsKey(agentId)) + { + m_log.DebugFormat( + "[CONNECTION DEBUGGING]: Caps path already in use for avatar {0} in region {1}", + agentId, RegionInfo.RegionName); + + try + { + m_capsHandlers[agentId] = cap; + } + catch (KeyNotFoundException) + { + m_log.DebugFormat( + "[CONNECTION DEBUGGING]: Caught exception adding handler for avatar {0} at {1}", + agentId, RegionInfo.RegionName); + + // Fix for a potential race condition. + m_capsHandlers.Add(agentId, cap); + } + } + else + { + m_capsHandlers.Add(agentId, cap); + } } /// diff --git a/OpenSim/Region/Environment/Scenes/SceneBase.cs b/OpenSim/Region/Environment/Scenes/SceneBase.cs index 2cc5c4f..4002aaf 100644 --- a/OpenSim/Region/Environment/Scenes/SceneBase.cs +++ b/OpenSim/Region/Environment/Scenes/SceneBase.cs @@ -26,6 +26,7 @@ */ using System; +using System.Collections.Generic; using libsecondlife; using OpenSim.Framework; using OpenSim.Framework.Communications.Cache; @@ -196,5 +197,19 @@ namespace OpenSim.Region.Environment.Scenes } #endregion + + /// + /// XXX These two methods are very temporary + /// + protected Dictionary capsPaths = new Dictionary(); + public string GetCapsPath(LLUUID agentId) + { + if (capsPaths.ContainsKey(agentId)) + { + return capsPaths[agentId]; + } + + return null; + } } } diff --git a/OpenSim/Region/Environment/Scenes/SceneCommunicationService.cs b/OpenSim/Region/Environment/Scenes/SceneCommunicationService.cs index e51c58d..d9c34e4 100644 --- a/OpenSim/Region/Environment/Scenes/SceneCommunicationService.cs +++ b/OpenSim/Region/Environment/Scenes/SceneCommunicationService.cs @@ -483,7 +483,7 @@ namespace OpenSim.Region.Environment.Scenes } /// - /// + /// Try to teleport an agent to a new region. /// /// /// @@ -530,7 +530,11 @@ namespace OpenSim.Region.Environment.Scenes m_commsProvider.InterRegion.ExpectAvatarCrossing(regionHandle, avatar.ControllingClient.AgentId, position, false); AgentCircuitData circuitdata = avatar.ControllingClient.RequestClientInfo(); - string capsPath = Util.GetCapsURL(avatar.ControllingClient.AgentId); + + // TODO Should construct this behind a method + string capsPath = + "http://" + reg.ExternalHostName + ":" + 9000 + "/CAPS/" + circuitdata.CapsPath + "0000/"; + avatar.ControllingClient.SendRegionTeleport(regionHandle, 13, reg.ExternalEndPoint, 4, (1 << 4), capsPath); avatar.MakeChildAgent(); diff --git a/OpenSim/Region/Environment/Scenes/ScenePresence.cs b/OpenSim/Region/Environment/Scenes/ScenePresence.cs index 050bf95..67a4b97 100644 --- a/OpenSim/Region/Environment/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Environment/Scenes/ScenePresence.cs @@ -545,6 +545,7 @@ namespace OpenSim.Region.Environment.Scenes m_scene.SwapRootAgentCount(false); m_scene.CommsManager.UserProfileCacheService.UpdateUserInventory(m_uuid); + m_scene.AddCapsHandler(m_uuid); //if (!m_gotAllObjectsInScene) //{ m_scene.SendAllSceneObjectsToClient(this); @@ -1616,7 +1617,15 @@ namespace OpenSim.Region.Environment.Scenes if (res) { AgentCircuitData circuitdata = m_controllingClient.RequestClientInfo(); - string capsPath = Util.GetCapsURL(m_controllingClient.AgentId); + + // TODO Should construct this behind a method + string capsPath = + "http://" + neighbourRegion.ExternalHostName + ":" + 9000 + + "/CAPS/" + circuitdata.CapsPath + "0000/"; + + m_log.DebugFormat( + "[CONNECTION DEBUGGING]: Sending new CAPS seed url {0} to avatar {1}", capsPath, m_uuid); + m_controllingClient.CrossRegion(neighbourHandle, newpos, vel, neighbourRegion.ExternalEndPoint, capsPath); MakeChildAgent(); -- cgit v1.1