aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs22
1 files changed, 21 insertions, 1 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
index 11cac05..ec45c81 100644
--- a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
+++ b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
@@ -86,6 +86,8 @@ namespace OpenSim.Region.ClientStack.Linden
86 // These are normaly set in their respective modules 86 // These are normaly set in their respective modules
87 m_SearchURL = config.GetString("SearchServerURI", m_SearchURL); 87 m_SearchURL = config.GetString("SearchServerURI", m_SearchURL);
88 m_DestinationGuideURL = config.GetString ("DestinationGuideURI", m_DestinationGuideURL); 88 m_DestinationGuideURL = config.GetString ("DestinationGuideURI", m_DestinationGuideURL);
89 if (m_DestinationGuideURL == string.Empty) // Make this consistent with the variable in the LoginService config
90 m_DestinationGuideURL = config.GetString("DestinationGuide", m_DestinationGuideURL);
89 m_ExportSupported = config.GetBoolean("ExportSupported", m_ExportSupported); 91 m_ExportSupported = config.GetBoolean("ExportSupported", m_ExportSupported);
90 m_GridURL = Util.GetConfigVarFromSections<string>(source, "GatekeeperURI", 92 m_GridURL = Util.GetConfigVarFromSections<string>(source, "GatekeeperURI",
91 new string[] { "Startup", "Hypergrid", "SimulatorFeatures" }, String.Empty); 93 new string[] { "Startup", "Hypergrid", "SimulatorFeatures" }, String.Empty);
@@ -225,10 +227,14 @@ namespace OpenSim.Region.ClientStack.Linden
225 227
226 private Hashtable HandleSimulatorFeaturesRequest(Hashtable mDhttpMethod, UUID agentID) 228 private Hashtable HandleSimulatorFeaturesRequest(Hashtable mDhttpMethod, UUID agentID)
227 { 229 {
228// m_log.DebugFormat("[SIMULATOR FEATURES MODULE]: SimulatorFeatures request"); 230 m_log.DebugFormat("[SIMULATOR FEATURES MODULE]: SimulatorFeatures request");
229 231
230 OSDMap copy = DeepCopy(); 232 OSDMap copy = DeepCopy();
231 233
234 // Let's add the agentID to the destination guide, if it is expecting that.
235 if (copy.ContainsKey("OpenSimExtras") && ((OSDMap)(copy["OpenSimExtras"])).ContainsKey("destination-guide-url"))
236 ((OSDMap)copy["OpenSimExtras"])["destination-guide-url"] = Replace(((OSDMap)copy["OpenSimExtras"])["destination-guide-url"], "[USERID]", agentID.ToString());
237
232 SimulatorFeaturesRequestDelegate handlerOnSimulatorFeaturesRequest = OnSimulatorFeaturesRequest; 238 SimulatorFeaturesRequestDelegate handlerOnSimulatorFeaturesRequest = OnSimulatorFeaturesRequest;
233 239
234 if (handlerOnSimulatorFeaturesRequest != null) 240 if (handlerOnSimulatorFeaturesRequest != null)
@@ -254,6 +260,11 @@ namespace OpenSim.Region.ClientStack.Linden
254 private void GetGridExtraFeatures(Scene scene) 260 private void GetGridExtraFeatures(Scene scene)
255 { 261 {
256 Dictionary<string, object> extraFeatures = scene.GridService.GetExtraFeatures(); 262 Dictionary<string, object> extraFeatures = scene.GridService.GetExtraFeatures();
263 if (extraFeatures.ContainsKey("Result") && extraFeatures["Result"] != null && extraFeatures["Result"].ToString() == "Failure")
264 {
265 m_log.WarnFormat("[SIMULATOR FEATURES MODULE]: Unable to retrieve grid-wide features");
266 return;
267 }
257 268
258 lock (m_features) 269 lock (m_features)
259 { 270 {
@@ -269,7 +280,16 @@ namespace OpenSim.Region.ClientStack.Linden
269 } 280 }
270 } 281 }
271 m_features["OpenSimExtras"] = extrasMap; 282 m_features["OpenSimExtras"] = extrasMap;
283
272 } 284 }
273 } 285 }
286
287 private string Replace(string url, string substring, string replacement)
288 {
289 if (!String.IsNullOrEmpty(url) && url.Contains(substring))
290 return url.Replace(substring, replacement);
291
292 return url;
293 }
274 } 294 }
275} 295}