From e0d8f42e6be70974c1cdbf6ba3ff80c2eea7294d Mon Sep 17 00:00:00 2001 From: BlueWall Date: Wed, 30 Jul 2014 11:19:34 -0400 Subject: Simulator Extra Features Service Provide a means for regions to fetch extra features supported by modern viewers from a central location . --- .../Linden/Caps/SimulatorFeaturesModule.cs | 74 +++++++++++++++++++--- 1 file changed, 65 insertions(+), 9 deletions(-) (limited to 'OpenSim/Region/ClientStack') diff --git a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs index e4d8a20..587cb70 100644 --- a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs +++ b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs @@ -56,13 +56,15 @@ namespace OpenSim.Region.ClientStack.Linden [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "SimulatorFeaturesModule")] public class SimulatorFeaturesModule : ISharedRegionModule, ISimulatorFeaturesModule { -// private static readonly ILog m_log = -// LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); + private static readonly ILog m_log = + LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); public event SimulatorFeaturesRequestDelegate OnSimulatorFeaturesRequest; private Scene m_scene; + bool m_AllowOverride = true; + /// /// Simulator features /// @@ -75,8 +77,15 @@ namespace OpenSim.Region.ClientStack.Linden public void Initialise(IConfigSource source) { - IConfig config = source.Configs["SimulatorFeatures"]; - if (config != null) + IConfig config = source.Configs ["SimulatorFeatures"]; + string featuresURI = config.GetString ("ExtraFeaturesServiceURI", string.Empty); + if (string.IsNullOrEmpty (featuresURI)) { + m_log.Info ("ExtraFeaturesServiceURI is undefined. The grid's ExtraFeatures will not be available to regions in this instnace."); + } else { + GetGridExtraFeatures(featuresURI); + } + + if (config != null && m_AllowOverride == true) { m_SearchURL = config.GetString("SearchServerURI", string.Empty); @@ -126,6 +135,7 @@ namespace OpenSim.Region.ClientStack.Linden /// private void AddDefaultFeatures() { + lock (m_features) { m_features["MeshRezEnabled"] = true; @@ -141,15 +151,21 @@ namespace OpenSim.Region.ClientStack.Linden // Extra information for viewers that want to use it // TODO: Take these out of here into their respective modules, like map-server-url - OSDMap extrasMap = new OSDMap(); - if (m_SearchURL != string.Empty) + OSDMap extrasMap; + if(m_features.ContainsKey("OpenSimExtras")) + { + extrasMap = (OSDMap)m_features["OpenSimExtras"]; + } + else + extrasMap = new OSDMap(); + + if (m_SearchURL != string.Empty && m_AllowOverride == true) extrasMap["search-server-url"] = m_SearchURL; - if (m_ExportSupported) + if (m_ExportSupported && m_AllowOverride == true) extrasMap["ExportSupported"] = true; if (extrasMap.Count > 0) m_features["OpenSimExtras"] = extrasMap; - } } @@ -204,7 +220,10 @@ namespace OpenSim.Region.ClientStack.Linden OSDMap copy = DeepCopy(); SimulatorFeaturesRequestDelegate handlerOnSimulatorFeaturesRequest = OnSimulatorFeaturesRequest; - if (handlerOnSimulatorFeaturesRequest != null) + + // We will not trigger the event if m_AllowOverride == False + // See Robust.ini/Robust.HG.ini [GridExtraFeatures] - AllowRegionOverride + if (handlerOnSimulatorFeaturesRequest != null && m_AllowOverride == true) handlerOnSimulatorFeaturesRequest(agentID, ref copy); //Send back data @@ -217,5 +236,42 @@ namespace OpenSim.Region.ClientStack.Linden return responsedata; } + + /// + /// Gets the grid extra features. + /// + /// + /// The URI Robust uses to handle the get_extra_features request + /// + private void GetGridExtraFeatures(string featuresURI) + { + JsonRpcRequestManager rpc = new JsonRpcRequestManager (); + + OSDMap parameters = new OSDMap (); + OSD Params = (OSD)parameters; + if (!rpc.JsonRpcRequest (ref Params, "get_extra_features", featuresURI, UUID.Random ().ToString ())) + { + m_log.Error("[SIMFEATURES]: Could not retrieve extra features from grid. Please check configuration."); + return; + } + parameters = (OSDMap)Params; + OSDMap features = (OSDMap)parameters ["result"]; + + if(features.ContainsKey("region_override")) + m_AllowOverride = features ["region_override"].AsBoolean () ; + else + m_AllowOverride = true; + + OSDMap test = (OSDMap)features ["extra_features"]; + lock (m_features) + { + OSDMap extrasMap = new OSDMap(); + foreach (string key in test.Keys) + { + extrasMap[key] = test[key]; + } + m_features["OpenSimExtras"] = extrasMap; + } + } } } -- cgit v1.1