From 49618dc102c42b7125303511d826f76f0ebaab4c Mon Sep 17 00:00:00 2001
From: Diva Canto
Date: Sun, 10 Jan 2010 19:19:34 -0800
Subject: Moved GridInfo service from where it was to Handlers/Grid
---
.../CreateCommsManager/CreateCommsManagerPlugin.cs | 6 -
.../Communications/Services/GridInfoService.cs | 176 ---------------------
.../UserServer.Modules/GridInfoServiceModule.cs | 79 ---------
OpenSim/Grid/UserServer/Main.cs | 7 -
OpenSim/Region/Application/OpenSimBase.cs | 2 -
.../Resources/CoreModulePlugin.addin.xml | 1 +
.../Grid/GridInfoServiceInConnectorModule.cs | 123 ++++++++++++++
OpenSim/Server/Handlers/Grid/GridInfoHandlers.cs | 154 ++++++++++++++++++
.../Handlers/Grid/GridInfoServerInConnector.cs | 55 +++++++
9 files changed, 333 insertions(+), 270 deletions(-)
delete mode 100644 OpenSim/Framework/Communications/Services/GridInfoService.cs
delete mode 100644 OpenSim/Grid/UserServer.Modules/GridInfoServiceModule.cs
create mode 100644 OpenSim/Region/CoreModules/ServiceConnectorsIn/Grid/GridInfoServiceInConnectorModule.cs
create mode 100644 OpenSim/Server/Handlers/Grid/GridInfoHandlers.cs
create mode 100644 OpenSim/Server/Handlers/Grid/GridInfoServerInConnector.cs
(limited to 'OpenSim')
diff --git a/OpenSim/ApplicationPlugins/CreateCommsManager/CreateCommsManagerPlugin.cs b/OpenSim/ApplicationPlugins/CreateCommsManager/CreateCommsManagerPlugin.cs
index 02ee025..c5a52fa 100644
--- a/OpenSim/ApplicationPlugins/CreateCommsManager/CreateCommsManagerPlugin.cs
+++ b/OpenSim/ApplicationPlugins/CreateCommsManager/CreateCommsManagerPlugin.cs
@@ -68,7 +68,6 @@ namespace OpenSim.ApplicationPlugins.CreateCommsManager
protected BaseHttpServer m_httpServer;
protected CommunicationsManager m_commsManager;
- protected GridInfoService m_gridInfoService;
protected IRegionCreator m_regionCreator;
@@ -201,11 +200,6 @@ namespace OpenSim.ApplicationPlugins.CreateCommsManager
private void CreateGridInfoService()
{
- // provide grid info
- m_gridInfoService = new GridInfoService(m_openSim.ConfigSource.Source);
- m_httpServer.AddXmlRPCHandler("get_grid_info", m_gridInfoService.XmlRpcGridInfoMethod);
- m_httpServer.AddStreamHandler(
- new RestStreamHandler("GET", "/get_grid_info", m_gridInfoService.RestGetGridInfoMethod));
}
}
}
diff --git a/OpenSim/Framework/Communications/Services/GridInfoService.cs b/OpenSim/Framework/Communications/Services/GridInfoService.cs
deleted file mode 100644
index cd2a152..0000000
--- a/OpenSim/Framework/Communications/Services/GridInfoService.cs
+++ /dev/null
@@ -1,176 +0,0 @@
-/*
- * Copyright (c) Contributors, http://opensimulator.org/
- * See CONTRIBUTORS.TXT for a full list of copyright holders.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * * Neither the name of the OpenSimulator Project nor the
- * names of its contributors may be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-using System;
-using System.Collections;
-using System.IO;
-using System.Net;
-using System.Reflection;
-using System.Text;
-using log4net;
-using Nini.Config;
-using Nwc.XmlRpc;
-using OpenSim.Framework.Servers.HttpServer;
-
-namespace OpenSim.Framework.Communications.Services
-{
- public class GridInfoService
- {
- private static readonly ILog _log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
-
- private Hashtable _info = new Hashtable();
-
- ///
- /// Instantiate a GridInfoService object.
- ///
- /// path to config path containing
- /// grid information
- ///
- /// GridInfoService uses the [GridInfo] section of the
- /// standard OpenSim.ini file --- which is not optimal, but
- /// anything else requires a general redesign of the config
- /// system.
- ///
- public GridInfoService(IConfigSource configSource)
- {
- loadGridInfo(configSource);
- }
-
- ///
- /// Default constructor, uses OpenSim.ini.
- ///
- public GridInfoService()
- {
- try
- {
- IConfigSource configSource = new IniConfigSource(Path.Combine(Util.configDir(), "OpenSim.ini"));
- loadGridInfo(configSource);
- }
- catch (FileNotFoundException)
- {
- _log.Warn(
- "[GRID INFO SERVICE]: No OpenSim.ini file found --- GridInfoServices WILL NOT BE AVAILABLE to your users");
- }
- }
-
- private void loadGridInfo(IConfigSource configSource)
- {
- _info["platform"] = "OpenSim";
- try
- {
- IConfig startupCfg = configSource.Configs["Startup"];
- IConfig gridCfg = configSource.Configs["GridInfo"];
- IConfig netCfg = configSource.Configs["Network"];
-
- bool grid = startupCfg.GetBoolean("gridmode", false);
-
- if (grid)
- _info["mode"] = "grid";
- else
- _info["mode"] = "standalone";
-
-
- if (null != gridCfg)
- {
- foreach (string k in gridCfg.GetKeys())
- {
- _info[k] = gridCfg.GetString(k);
- }
- }
- else if (null != netCfg)
- {
- if (grid)
- _info["login"]
- = netCfg.GetString(
- "user_server_url", "http://127.0.0.1:" + ConfigSettings.DefaultUserServerHttpPort.ToString());
- else
- _info["login"]
- = String.Format(
- "http://127.0.0.1:{0}/",
- netCfg.GetString(
- "http_listener_port", ConfigSettings.DefaultRegionHttpPort.ToString()));
-
- IssueWarning();
- }
- else
- {
- _info["login"] = "http://127.0.0.1:9000/";
- IssueWarning();
- }
- }
- catch (Exception)
- {
- _log.Debug("[GRID INFO SERVICE]: Cannot get grid info from config source, using minimal defaults");
- }
-
- _log.DebugFormat("[GRID INFO SERVICE]: Grid info service initialized with {0} keys", _info.Count);
-
- }
-
- private void IssueWarning()
- {
- _log.Warn("[GRID INFO SERVICE]: found no [GridInfo] section in your OpenSim.ini");
- _log.Warn("[GRID INFO SERVICE]: trying to guess sensible defaults, you might want to provide better ones:");
-
- foreach (string k in _info.Keys)
- {
- _log.WarnFormat("[GRID INFO SERVICE]: {0}: {1}", k, _info[k]);
- }
- }
-
- public XmlRpcResponse XmlRpcGridInfoMethod(XmlRpcRequest request, IPEndPoint remoteClient)
- {
- XmlRpcResponse response = new XmlRpcResponse();
- Hashtable responseData = new Hashtable();
-
- _log.Info("[GRID INFO SERVICE]: Request for grid info");
-
- foreach (string k in _info.Keys)
- {
- responseData[k] = _info[k];
- }
- response.Value = responseData;
-
- return response;
- }
-
- public string RestGetGridInfoMethod(string request, string path, string param,
- OSHttpRequest httpRequest, OSHttpResponse httpResponse)
- {
- StringBuilder sb = new StringBuilder();
-
- sb.Append("\n");
- foreach (string k in _info.Keys)
- {
- sb.AppendFormat("<{0}>{1}{0}>\n", k, _info[k]);
- }
- sb.Append("\n");
-
- return sb.ToString();
- }
- }
-}
diff --git a/OpenSim/Grid/UserServer.Modules/GridInfoServiceModule.cs b/OpenSim/Grid/UserServer.Modules/GridInfoServiceModule.cs
deleted file mode 100644
index 0c84348..0000000
--- a/OpenSim/Grid/UserServer.Modules/GridInfoServiceModule.cs
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (c) Contributors, http://opensimulator.org/
- * See CONTRIBUTORS.TXT for a full list of copyright holders.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * * Neither the name of the OpenSimulator Project nor the
- * names of its contributors may be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Reflection;
-using log4net;
-using log4net.Config;
-using OpenMetaverse;
-using OpenSim.Framework;
-using OpenSim.Framework.Communications;
-using OpenSim.Framework.Communications.Services;
-using OpenSim.Framework.Communications.Cache;
-using OpenSim.Framework.Servers;
-using OpenSim.Framework.Servers.HttpServer;
-using OpenSim.Grid.Communications.OGS1;
-using OpenSim.Grid.Framework;
-
-namespace OpenSim.Grid.UserServer.Modules
-{
- public class GridInfoServiceModule
- {
- protected IGridServiceCore m_core;
- protected GridInfoService m_gridInfoService;
- protected BaseHttpServer m_httpServer;
-
- public GridInfoServiceModule()
- {
- }
-
- public void Initialise(IGridServiceCore core)
- {
- m_core = core;
- m_gridInfoService = new GridInfoService();
- }
-
- public void PostInitialise()
- {
-
- }
-
- public void RegisterHandlers(BaseHttpServer httpServer)
- {
- m_httpServer = httpServer;
- m_httpServer.AddStreamHandler(new RestStreamHandler("GET", "/get_grid_info",
- m_gridInfoService.RestGetGridInfoMethod));
- m_httpServer.AddXmlRPCHandler("get_grid_info", m_gridInfoService.XmlRpcGridInfoMethod);
- }
-
- public void Close()
- {
- }
- }
-}
diff --git a/OpenSim/Grid/UserServer/Main.cs b/OpenSim/Grid/UserServer/Main.cs
index 5bf728a..d598728 100644
--- a/OpenSim/Grid/UserServer/Main.cs
+++ b/OpenSim/Grid/UserServer/Main.cs
@@ -66,8 +66,6 @@ namespace OpenSim.Grid.UserServer
public UserLoginService m_loginService;
public MessageServersConnector m_messagesService;
- protected GridInfoServiceModule m_gridInfoService;
-
protected UserServerCommandModule m_consoleCommandModule;
protected UserServerEventDispatchModule m_eventDispatcher;
@@ -213,9 +211,6 @@ namespace OpenSim.Grid.UserServer
m_messagesService = new MessageServersConnector();
m_messagesService.Initialise(this);
-
- m_gridInfoService = new GridInfoServiceModule();
- m_gridInfoService.Initialise(this);
}
protected virtual void StartOtherComponents(IInterServiceInventoryServices inventoryService)
@@ -252,7 +247,6 @@ namespace OpenSim.Grid.UserServer
m_userDataBaseService.PostInitialise();
m_messagesService.PostInitialise();
m_eventDispatcher.PostInitialise(); //it will register event handlers in here
- m_gridInfoService.PostInitialise();
m_userManager.PostInitialise();
m_avatarAppearanceModule.PostInitialise();
m_friendsModule.PostInitialise();
@@ -266,7 +260,6 @@ namespace OpenSim.Grid.UserServer
m_friendsModule.RegisterHandlers(m_httpServer);
m_avatarAppearanceModule.RegisterHandlers(m_httpServer);
m_messagesService.RegisterHandlers(m_httpServer);
- m_gridInfoService.RegisterHandlers(m_httpServer);
}
public override void ShutdownSpecific()
diff --git a/OpenSim/Region/Application/OpenSimBase.cs b/OpenSim/Region/Application/OpenSimBase.cs
index 2db17b1..a834786 100644
--- a/OpenSim/Region/Application/OpenSimBase.cs
+++ b/OpenSim/Region/Application/OpenSimBase.cs
@@ -85,8 +85,6 @@ namespace OpenSim
protected ConfigurationLoader m_configLoader;
- protected GridInfoService m_gridInfoService;
-
public ConsoleCommand CreateAccount = null;
protected List m_plugins = new List();
diff --git a/OpenSim/Region/CoreModules/Resources/CoreModulePlugin.addin.xml b/OpenSim/Region/CoreModules/Resources/CoreModulePlugin.addin.xml
index a43b728..1cc8ca9 100644
--- a/OpenSim/Region/CoreModules/Resources/CoreModulePlugin.addin.xml
+++ b/OpenSim/Region/CoreModules/Resources/CoreModulePlugin.addin.xml
@@ -63,6 +63,7 @@
\
\
\
+ \
diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsIn/Grid/GridInfoServiceInConnectorModule.cs b/OpenSim/Region/CoreModules/ServiceConnectorsIn/Grid/GridInfoServiceInConnectorModule.cs
new file mode 100644
index 0000000..7c9b752
--- /dev/null
+++ b/OpenSim/Region/CoreModules/ServiceConnectorsIn/Grid/GridInfoServiceInConnectorModule.cs
@@ -0,0 +1,123 @@
+/*
+ * Copyright (c) Contributors, http://opensimulator.org/
+ * See CONTRIBUTORS.TXT for a full list of copyright holders.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the OpenSimulator Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+using System;
+using System.Reflection;
+using System.Collections.Generic;
+using log4net;
+using Nini.Config;
+using OpenSim.Framework;
+using OpenSim.Framework.Servers.HttpServer;
+using OpenSim.Region.Framework.Scenes;
+using OpenSim.Region.Framework.Interfaces;
+using OpenSim.Server.Base;
+using OpenSim.Server.Handlers.Base;
+using OpenSim.Server.Handlers.Grid;
+using OpenSim.Services.Interfaces;
+
+namespace OpenSim.Region.CoreModules.ServiceConnectorsIn.Grid
+{
+ public class GridInfoServiceInConnectorModule : ISharedRegionModule
+ {
+ private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
+ private static bool m_Enabled = false;
+
+ private IConfigSource m_Config;
+ bool m_Registered = false;
+
+ #region IRegionModule interface
+
+ public void Initialise(IConfigSource config)
+ {
+ //// This module is only on for standalones in hypergrid mode
+ //enabled = (!config.Configs["Startup"].GetBoolean("gridmode", true)) &&
+ // config.Configs["Startup"].GetBoolean("hypergrid", true);
+ //m_log.DebugFormat("[RegionInventoryService]: enabled? {0}", enabled);
+ m_Config = config;
+ IConfig moduleConfig = config.Configs["Modules"];
+ if (moduleConfig != null)
+ {
+ m_Enabled = moduleConfig.GetBoolean("GridInfoServiceInConnector", false);
+ if (m_Enabled)
+ {
+ m_log.Info("[GRIDINFO IN CONNECTOR]: GridInfo Service In Connector enabled");
+ }
+
+ }
+
+ }
+
+ public void PostInitialise()
+ {
+ }
+
+ public void Close()
+ {
+ }
+
+ public Type ReplaceableInterface
+ {
+ get { return null; }
+ }
+
+ public string Name
+ {
+ get { return "GridInfoService"; }
+ }
+
+ public void AddRegion(Scene scene)
+ {
+ if (!m_Enabled)
+ return;
+ }
+
+ public void RemoveRegion(Scene scene)
+ {
+ if (!m_Enabled)
+ return;
+ }
+
+ public void RegionLoaded(Scene scene)
+ {
+ if (!m_Enabled)
+ return;
+
+ if (!m_Registered)
+ {
+ m_Registered = true;
+
+ m_log.Info("[GridInfo]: Starting...");
+
+ new GridInfoServerInConnector(m_Config, MainServer.Instance, "GridInfoService");
+ }
+
+ }
+
+ #endregion
+
+ }
+}
diff --git a/OpenSim/Server/Handlers/Grid/GridInfoHandlers.cs b/OpenSim/Server/Handlers/Grid/GridInfoHandlers.cs
new file mode 100644
index 0000000..d1233dc
--- /dev/null
+++ b/OpenSim/Server/Handlers/Grid/GridInfoHandlers.cs
@@ -0,0 +1,154 @@
+/*
+ * Copyright (c) Contributors, http://opensimulator.org/
+ * See CONTRIBUTORS.TXT for a full list of copyright holders.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the OpenSimulator Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+using System;
+using System.Collections;
+using System.IO;
+using System.Net;
+using System.Reflection;
+using System.Text;
+using log4net;
+using Nini.Config;
+using Nwc.XmlRpc;
+using OpenSim.Framework;
+using OpenSim.Framework.Servers.HttpServer;
+
+namespace OpenSim.Server.Handlers.Grid
+{
+ public class GridInfoHandlers
+ {
+ private static readonly ILog _log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
+
+ private Hashtable _info = new Hashtable();
+
+ ///
+ /// Instantiate a GridInfoService object.
+ ///
+ /// path to config path containing
+ /// grid information
+ ///
+ /// GridInfoService uses the [GridInfo] section of the
+ /// standard OpenSim.ini file --- which is not optimal, but
+ /// anything else requires a general redesign of the config
+ /// system.
+ ///
+ public GridInfoHandlers(IConfigSource configSource)
+ {
+ loadGridInfo(configSource);
+ }
+
+ private void loadGridInfo(IConfigSource configSource)
+ {
+ _info["platform"] = "OpenSim";
+ try
+ {
+ IConfig startupCfg = configSource.Configs["Startup"];
+ IConfig gridCfg = configSource.Configs["GridInfoService"];
+ IConfig netCfg = configSource.Configs["Network"];
+
+ bool grid = startupCfg.GetBoolean("gridmode", false);
+
+ if (null != gridCfg)
+ {
+ foreach (string k in gridCfg.GetKeys())
+ {
+ _info[k] = gridCfg.GetString(k);
+ }
+ }
+ else if (null != netCfg)
+ {
+ if (grid)
+ _info["login"]
+ = netCfg.GetString(
+ "user_server_url", "http://127.0.0.1:" + ConfigSettings.DefaultUserServerHttpPort.ToString());
+ else
+ _info["login"]
+ = String.Format(
+ "http://127.0.0.1:{0}/",
+ netCfg.GetString(
+ "http_listener_port", ConfigSettings.DefaultRegionHttpPort.ToString()));
+
+ IssueWarning();
+ }
+ else
+ {
+ _info["login"] = "http://127.0.0.1:9000/";
+ IssueWarning();
+ }
+ }
+ catch (Exception)
+ {
+ _log.Debug("[GRID INFO SERVICE]: Cannot get grid info from config source, using minimal defaults");
+ }
+
+ _log.DebugFormat("[GRID INFO SERVICE]: Grid info service initialized with {0} keys", _info.Count);
+
+ }
+
+ private void IssueWarning()
+ {
+ _log.Warn("[GRID INFO SERVICE]: found no [GridInfo] section in your OpenSim.ini");
+ _log.Warn("[GRID INFO SERVICE]: trying to guess sensible defaults, you might want to provide better ones:");
+
+ foreach (string k in _info.Keys)
+ {
+ _log.WarnFormat("[GRID INFO SERVICE]: {0}: {1}", k, _info[k]);
+ }
+ }
+
+ public XmlRpcResponse XmlRpcGridInfoMethod(XmlRpcRequest request, IPEndPoint remoteClient)
+ {
+ XmlRpcResponse response = new XmlRpcResponse();
+ Hashtable responseData = new Hashtable();
+
+ _log.Info("[GRID INFO SERVICE]: Request for grid info");
+
+ foreach (string k in _info.Keys)
+ {
+ responseData[k] = _info[k];
+ }
+ response.Value = responseData;
+
+ return response;
+ }
+
+ public string RestGetGridInfoMethod(string request, string path, string param,
+ OSHttpRequest httpRequest, OSHttpResponse httpResponse)
+ {
+ StringBuilder sb = new StringBuilder();
+
+ sb.Append("\n");
+ foreach (string k in _info.Keys)
+ {
+ sb.AppendFormat("<{0}>{1}{0}>\n", k, _info[k]);
+ }
+ sb.Append("\n");
+
+ return sb.ToString();
+ }
+ }
+}
diff --git a/OpenSim/Server/Handlers/Grid/GridInfoServerInConnector.cs b/OpenSim/Server/Handlers/Grid/GridInfoServerInConnector.cs
new file mode 100644
index 0000000..c9e80d9
--- /dev/null
+++ b/OpenSim/Server/Handlers/Grid/GridInfoServerInConnector.cs
@@ -0,0 +1,55 @@
+/*
+ * Copyright (c) Contributors, http://opensimulator.org/
+ * See CONTRIBUTORS.TXT for a full list of copyright holders.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the OpenSimulator Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+using System;
+using System.Collections.Generic;
+using System.Reflection;
+using log4net;
+using OpenMetaverse;
+using Nini.Config;
+using OpenSim.Framework;
+using OpenSim.Framework.Servers.HttpServer;
+using OpenSim.Server.Handlers.Base;
+
+namespace OpenSim.Server.Handlers.Grid
+{
+ public class GridInfoServerInConnector : ServiceConnector
+ {
+ private string m_ConfigName = "GridInfoService";
+
+ public GridInfoServerInConnector(IConfigSource config, IHttpServer server, string configName) :
+ base(config, server, configName)
+ {
+ GridInfoHandlers handlers = new GridInfoHandlers(config);
+
+ server.AddStreamHandler(new RestStreamHandler("GET", "/get_grid_info",
+ handlers.RestGetGridInfoMethod));
+ server.AddXmlRPCHandler("get_grid_info", handlers.XmlRpcGridInfoMethod);
+ }
+
+ }
+}
--
cgit v1.1