* Rex merges, Grid Server

afrisby-3
Adam Frisby 2008-02-23 02:44:32 +00:00
parent f55bba8019
commit 79cb89f406
4 changed files with 1360 additions and 1293 deletions

View File

@ -1,170 +1,172 @@
/* /*
* Copyright (c) Contributors, http://opensimulator.org/ * Copyright (c) Contributors, http://opensimulator.org/
* See CONTRIBUTORS.TXT for a full list of copyright holders. * See CONTRIBUTORS.TXT for a full list of copyright holders.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met: * modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright * * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer. * notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright * * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the * notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution. * documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSim Project nor the * * Neither the name of the OpenSim Project nor the
* names of its contributors may be used to endorse or promote products * names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission. * derived from this software without specific prior written permission.
* *
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * 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 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* *
*/ */
using System; using System;
using Db4objects.Db4o; using Db4objects.Db4o;
using OpenSim.Framework.Configuration; using OpenSim.Framework.Configuration;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Framework.Interfaces; using OpenSim.Framework.Interfaces;
namespace OpenGrid.Config.GridConfigDb4o namespace OpenGrid.Config.GridConfigDb4o
{ {
/// <summary> /// <summary>
/// A grid configuration interface for returning the DB4o Config Provider /// A grid configuration interface for returning the DB4o Config Provider
/// </summary> /// </summary>
public class Db40ConfigPlugin: IGridConfig public class Db40ConfigPlugin: IGridConfig
{ {
/// <summary> private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
/// Loads and returns a configuration objeect
/// </summary> /// <summary>
/// <returns>A grid configuration object</returns> /// Loads and returns a configuration objeect
public GridConfig GetConfigObject() /// </summary>
{ /// <returns>A grid configuration object</returns>
MainLog.Instance.Verbose("DBGRIDCONFIG", "Loading Db40Config dll"); public GridConfig GetConfigObject()
return new DbGridConfig(); {
} m_log.Info("[DBGRIDCONFIG]: Loading Db40Config dll");
} return new DbGridConfig();
}
/// <summary> }
/// A DB4o based Gridserver configuration object
/// </summary> /// <summary>
public class DbGridConfig : GridConfig /// A DB4o based Gridserver configuration object
{ /// </summary>
/// <summary> public class DbGridConfig : GridConfig
/// The DB4o Database {
/// </summary> /// <summary>
private IObjectContainer db; /// The DB4o Database
/// </summary>
/// <summary> private IObjectContainer db;
/// User configuration for the Grid Config interfaces
/// </summary> /// <summary>
public void LoadDefaults() /// User configuration for the Grid Config interfaces
{ /// </summary>
MainLog.Instance.Notice("DbGridConfig.cs:LoadDefaults() - Please press enter to retain default or enter new settings"); public void LoadDefaults()
{
// About the grid options MainConsole.Instance.Info("DbGridConfig.cs:LoadDefaults() - Please press enter to retain default or enter new settings");
this.GridOwner = MainLog.Instance.CmdPrompt("Grid owner", "OGS development team");
// About the grid options
// Asset Options this.GridOwner = MainConsole.Instance.CmdPrompt("Grid owner", "OGS development team");
this.DefaultAssetServer = MainLog.Instance.CmdPrompt("Default asset server","http://127.0.0.1:" + AssetConfig.DefaultHttpPort.ToString() + "/");
this.AssetSendKey = MainLog.Instance.CmdPrompt("Key to send to asset server","null"); // Asset Options
this.AssetRecvKey = MainLog.Instance.CmdPrompt("Key to expect from asset server","null"); this.DefaultAssetServer = MainConsole.Instance.CmdPrompt("Default asset server","http://127.0.0.1:" + AssetConfig.DefaultHttpPort.ToString() + "/");
this.AssetSendKey = MainConsole.Instance.CmdPrompt("Key to send to asset server","null");
// User Server Options this.AssetRecvKey = MainConsole.Instance.CmdPrompt("Key to expect from asset server","null");
this.DefaultUserServer = MainLog.Instance.CmdPrompt("Default user server","http://127.0.0.1:" + UserConfig.DefaultHttpPort.ToString() + "/");
this.UserSendKey = MainLog.Instance.CmdPrompt("Key to send to user server","null"); // User Server Options
this.UserRecvKey = MainLog.Instance.CmdPrompt("Key to expect from user server","null"); this.DefaultUserServer = MainConsole.Instance.CmdPrompt("Default user server","http://127.0.0.1:" + UserConfig.DefaultHttpPort.ToString() + "/");
this.UserSendKey = MainConsole.Instance.CmdPrompt("Key to send to user server","null");
// Region Server Options this.UserRecvKey = MainConsole.Instance.CmdPrompt("Key to expect from user server","null");
this.SimSendKey = MainLog.Instance.CmdPrompt("Key to send to sims","null");
this.SimRecvKey = MainLog.Instance.CmdPrompt("Key to expect from sims","null"); // Region Server Options
} this.SimSendKey = MainConsole.Instance.CmdPrompt("Key to send to sims","null");
this.SimRecvKey = MainConsole.Instance.CmdPrompt("Key to expect from sims","null");
/// <summary> }
/// Initialises a new configuration object
/// </summary> /// <summary>
public override void InitConfig() /// Initialises a new configuration object
{ /// </summary>
try public override void InitConfig()
{ {
// Perform Db4o initialisation try
db = Db4oFactory.OpenFile("opengrid.yap"); {
// Perform Db4o initialisation
// Locate the grid configuration object db = Db4oFactory.OpenFile("opengrid.yap");
IObjectSet result = db.Get(typeof(DbGridConfig));
// Found? // Locate the grid configuration object
if (result.Count==1) IObjectSet result = db.Get(typeof(DbGridConfig));
{ // Found?
MainLog.Instance.Verbose("DBGRIDCONFIG", "Found a GridConfig object in the local database, loading"); if (result.Count==1)
foreach (DbGridConfig cfg in result) {
{ m_log.Info("[DBGRIDCONFIG]: Found a GridConfig object in the local database, loading");
// Import each setting into this class foreach (DbGridConfig cfg in result)
// Grid Settings {
this.GridOwner=cfg.GridOwner; // Import each setting into this class
// Asset Settings // Grid Settings
this.DefaultAssetServer=cfg.DefaultAssetServer; this.GridOwner=cfg.GridOwner;
this.AssetSendKey=cfg.AssetSendKey; // Asset Settings
this.AssetRecvKey=cfg.AssetRecvKey; this.DefaultAssetServer=cfg.DefaultAssetServer;
// User Settings this.AssetSendKey=cfg.AssetSendKey;
this.DefaultUserServer=cfg.DefaultUserServer; this.AssetRecvKey=cfg.AssetRecvKey;
this.UserSendKey=cfg.UserSendKey; // User Settings
this.UserRecvKey=cfg.UserRecvKey; this.DefaultUserServer=cfg.DefaultUserServer;
// Region Settings this.UserSendKey=cfg.UserSendKey;
this.SimSendKey=cfg.SimSendKey; this.UserRecvKey=cfg.UserRecvKey;
this.SimRecvKey=cfg.SimRecvKey; // Region Settings
} this.SimSendKey=cfg.SimSendKey;
// Create a new configuration object from this class this.SimRecvKey=cfg.SimRecvKey;
} }
else // Create a new configuration object from this class
{ }
MainLog.Instance.Verbose("DBGRIDCONFIG", "Could not find object in database, loading precompiled defaults"); else
{
// Load default settings into this class m_log.Info("[DBGRIDCONFIG]: Could not find object in database, loading precompiled defaults");
LoadDefaults();
// Load default settings into this class
// Saves to the database file... LoadDefaults();
MainLog.Instance.Verbose("DBGRIDCONFIG", "Writing out default settings to local database");
db.Set(this); // Saves to the database file...
m_log.Info("[DBGRIDCONFIG]: Writing out default settings to local database");
// Closes file locks db.Set(this);
db.Close();
} // Closes file locks
} db.Close();
catch(Exception e) }
{ }
MainLog.Instance.Warn("DbGridConfig.cs:InitConfig() - Exception occured"); catch(Exception e)
MainLog.Instance.Warn(e.ToString()); {
} m_log.Warn("DbGridConfig.cs:InitConfig() - Exception occured");
m_log.Warn(e.ToString());
// Grid Settings }
MainLog.Instance.Verbose("DBGRIDCONFIG", "Grid settings loaded:");
MainLog.Instance.Verbose("DBGRIDCONFIG", "Grid owner: " + this.GridOwner); // Grid Settings
m_log.Info("[DBGRIDCONFIG]: Grid settings loaded:");
// Asset Settings m_log.Info("[DBGRIDCONFIG]: Grid owner: " + this.GridOwner);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Default asset server: " + this.DefaultAssetServer);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to send to asset server: " + this.AssetSendKey); // Asset Settings
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to expect from asset server: " + this.AssetRecvKey); m_log.Info("[DBGRIDCONFIG]: Default asset server: " + this.DefaultAssetServer);
m_log.Info("[DBGRIDCONFIG]: Key to send to asset server: " + this.AssetSendKey);
// User Settings m_log.Info("[DBGRIDCONFIG]: Key to expect from asset server: " + this.AssetRecvKey);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Default user server: " + this.DefaultUserServer);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to send to user server: " + this.UserSendKey); // User Settings
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to expect from user server: " + this.UserRecvKey); m_log.Info("[DBGRIDCONFIG]: Default user server: " + this.DefaultUserServer);
m_log.Info("[DBGRIDCONFIG]: Key to send to user server: " + this.UserSendKey);
// Region Settings m_log.Info("[DBGRIDCONFIG]: Key to expect from user server: " + this.UserRecvKey);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to send to sims: " + this.SimSendKey);
MainLog.Instance.Verbose("DBGRIDCONFIG", "Key to expect from sims: " + this.SimRecvKey); // Region Settings
} m_log.Info("[DBGRIDCONFIG]: Key to send to sims: " + this.SimSendKey);
m_log.Info("[DBGRIDCONFIG]: Key to expect from sims: " + this.SimRecvKey);
/// <summary> }
/// Closes down the database and releases filesystem locks
/// </summary> /// <summary>
public void Shutdown() /// Closes down the database and releases filesystem locks
{ /// </summary>
db.Close(); public void Shutdown()
} {
} db.Close();
} }
}
}

File diff suppressed because it is too large Load Diff

View File

@ -1,226 +1,220 @@
/* /*
* Copyright (c) Contributors, http://opensimulator.org/ * Copyright (c) Contributors, http://opensimulator.org/
* See CONTRIBUTORS.TXT for a full list of copyright holders. * See CONTRIBUTORS.TXT for a full list of copyright holders.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met: * modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright * * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer. * notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright * * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the * notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution. * documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSim Project nor the * * Neither the name of the OpenSim Project nor the
* names of its contributors may be used to endorse or promote products * names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission. * derived from this software without specific prior written permission.
* *
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * 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 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* *
*/ */
using System; using System;
using System.IO; using System.IO;
using System.Timers; using System.Timers;
using OpenSim.Framework; using OpenSim.Framework;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Framework.Servers; using OpenSim.Framework.Servers;
namespace OpenSim.Grid.GridServer namespace OpenSim.Grid.GridServer
{ {
/// <summary> /// <summary>
/// </summary> /// </summary>
public class OpenGrid_Main : conscmd_callback public class OpenGrid_Main : BaseOpenSimServer, conscmd_callback
{ {
public GridConfig Cfg; private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public static OpenGrid_Main thegrid; public GridConfig Cfg;
public static bool setuponly; public static OpenGrid_Main thegrid;
//public LLUUID highestUUID; public static bool setuponly;
// private SimProfileManager m_simProfileManager; //public LLUUID highestUUID;
private GridManager m_gridManager; // private SimProfileManager m_simProfileManager;
private LogBase m_console; private GridManager m_gridManager;
[STAThread] [STAThread]
public static void Main(string[] args) public static void Main(string[] args)
{ {
if (args.Length > 0) log4net.Config.XmlConfigurator.Configure();
{
if (args[0] == "-setuponly") setuponly = true; if (args.Length > 0)
} {
Console.WriteLine("Starting...\n"); if (args[0] == "-setuponly") setuponly = true;
}
thegrid = new OpenGrid_Main(); m_log.Info("Starting...\n");
thegrid.Startup();
thegrid = new OpenGrid_Main();
thegrid.Work(); thegrid.Startup();
}
thegrid.Work();
private void Work() }
{
m_console.Notice("Enter help for a list of commands\n"); private void Work()
{
while (true) m_console.Notice("Enter help for a list of commands\n");
{
m_console.MainLogPrompt(); while (true)
} {
} m_console.Prompt();
}
private OpenGrid_Main() }
{
if (!Directory.Exists(Util.logDir())) private OpenGrid_Main()
{ {
Directory.CreateDirectory(Util.logDir()); m_console = new ConsoleBase("OpenGrid", this);
} MainConsole.Instance = m_console;
m_console = }
new LogBase((Path.Combine(Util.logDir(), "opengrid-gridserver-console.log")), "OpenGrid", this, true);
MainLog.Instance = m_console; public void managercallback(string cmd)
} {
switch (cmd)
public void managercallback(string cmd) {
{ case "shutdown":
switch (cmd) RunCmd("shutdown", new string[0]);
{ break;
case "shutdown": }
RunCmd("shutdown", new string[0]); }
break;
} public void Startup()
} {
Cfg = new GridConfig("GRID SERVER", (Path.Combine(Util.configDir(), "GridServer_Config.xml")));
//Yeah srsly, that's it.
public void Startup() if (setuponly) Environment.Exit(0);
{
Cfg = new GridConfig("GRID SERVER", (Path.Combine(Util.configDir(), "GridServer_Config.xml"))); m_log.Info("[GRID]: Connecting to Storage Server");
//Yeah srsly, that's it. m_gridManager = new GridManager();
if (setuponly) Environment.Exit(0); m_gridManager.AddPlugin(Cfg.DatabaseProvider); // Made of win
m_gridManager.config = Cfg;
m_console.Verbose("GRID", "Connecting to Storage Server");
m_gridManager = new GridManager(); m_log.Info("[GRID]: Starting HTTP process");
m_gridManager.AddPlugin(Cfg.DatabaseProvider); // Made of win BaseHttpServer httpServer = new BaseHttpServer(Cfg.HttpPort);
m_gridManager.config = Cfg; //GridManagementAgent GridManagerAgent = new GridManagementAgent(httpServer, "gridserver", Cfg.SimSendKey, Cfg.SimRecvKey, managercallback);
m_console.Verbose("GRID", "Starting HTTP process"); httpServer.AddXmlRPCHandler("simulator_login", m_gridManager.XmlRpcSimulatorLoginMethod);
BaseHttpServer httpServer = new BaseHttpServer(Cfg.HttpPort); httpServer.AddXmlRPCHandler("simulator_data_request", m_gridManager.XmlRpcSimulatorDataRequestMethod);
//GridManagementAgent GridManagerAgent = new GridManagementAgent(httpServer, "gridserver", Cfg.SimSendKey, Cfg.SimRecvKey, managercallback); httpServer.AddXmlRPCHandler("map_block", m_gridManager.XmlRpcMapBlockMethod);
httpServer.AddXmlRPCHandler("simulator_login", m_gridManager.XmlRpcSimulatorLoginMethod); // Message Server ---> Grid Server
httpServer.AddXmlRPCHandler("simulator_data_request", m_gridManager.XmlRpcSimulatorDataRequestMethod); httpServer.AddXmlRPCHandler("register_messageserver", m_gridManager.XmlRPCRegisterMessageServer);
httpServer.AddXmlRPCHandler("map_block", m_gridManager.XmlRpcMapBlockMethod); httpServer.AddXmlRPCHandler("deregister_messageserver", m_gridManager.XmlRPCDeRegisterMessageServer);
// Message Server ---> Grid Server
httpServer.AddXmlRPCHandler("register_messageserver", m_gridManager.XmlRPCRegisterMessageServer); httpServer.AddStreamHandler(new RestStreamHandler("GET", "/sims/", m_gridManager.RestGetSimMethod));
httpServer.AddXmlRPCHandler("deregister_messageserver", m_gridManager.XmlRPCDeRegisterMessageServer); httpServer.AddStreamHandler(new RestStreamHandler("POST", "/sims/", m_gridManager.RestSetSimMethod));
httpServer.AddStreamHandler(new RestStreamHandler("GET", "/regions/", m_gridManager.RestGetRegionMethod));
httpServer.AddStreamHandler(new RestStreamHandler("GET", "/sims/", m_gridManager.RestGetSimMethod)); httpServer.AddStreamHandler(new RestStreamHandler("POST", "/regions/", m_gridManager.RestSetRegionMethod));
httpServer.AddStreamHandler(new RestStreamHandler("POST", "/sims/", m_gridManager.RestSetSimMethod));
//httpServer.AddRestHandler("GET", "/sims/", m_gridManager.RestGetSimMethod);
httpServer.AddStreamHandler(new RestStreamHandler("GET", "/regions/", m_gridManager.RestGetRegionMethod)); //httpServer.AddRestHandler("POST", "/sims/", m_gridManager.RestSetSimMethod);
httpServer.AddStreamHandler(new RestStreamHandler("POST", "/regions/", m_gridManager.RestSetRegionMethod)); //httpServer.AddRestHandler("GET", "/regions/", m_gridManager.RestGetRegionMethod);
//httpServer.AddRestHandler("POST", "/regions/", m_gridManager.RestSetRegionMethod);
//httpServer.AddRestHandler("GET", "/sims/", m_gridManager.RestGetSimMethod);
//httpServer.AddRestHandler("POST", "/sims/", m_gridManager.RestSetSimMethod); httpServer.Start();
//httpServer.AddRestHandler("GET", "/regions/", m_gridManager.RestGetRegionMethod);
//httpServer.AddRestHandler("POST", "/regions/", m_gridManager.RestSetRegionMethod); m_log.Info("[GRID]: Starting sim status checker");
httpServer.Start(); Timer simCheckTimer = new Timer(3600000*3); // 3 Hours between updates.
simCheckTimer.Elapsed += new ElapsedEventHandler(CheckSims);
m_console.Verbose("GRID", "Starting sim status checker"); simCheckTimer.Enabled = true;
}
Timer simCheckTimer = new Timer(3600000*3); // 3 Hours between updates.
simCheckTimer.Elapsed += new ElapsedEventHandler(CheckSims); public void CheckSims(object sender, ElapsedEventArgs e)
simCheckTimer.Enabled = true; {
} /*
foreach (SimProfileBase sim in m_simProfileManager.SimProfiles.Values)
public void CheckSims(object sender, ElapsedEventArgs e) {
{ string SimResponse = String.Empty;
/* try
foreach (SimProfileBase sim in m_simProfileManager.SimProfiles.Values) {
{ WebRequest CheckSim = WebRequest.Create("http://" + sim.sim_ip + ":" + sim.sim_port.ToString() + "/checkstatus/");
string SimResponse = ""; CheckSim.Method = "GET";
try CheckSim.ContentType = "text/plaintext";
{ CheckSim.ContentLength = 0;
WebRequest CheckSim = WebRequest.Create("http://" + sim.sim_ip + ":" + sim.sim_port.ToString() + "/checkstatus/");
CheckSim.Method = "GET"; StreamWriter stOut = new StreamWriter(CheckSim.GetRequestStream(), System.Text.Encoding.ASCII);
CheckSim.ContentType = "text/plaintext"; stOut.Write(String.Empty);
CheckSim.ContentLength = 0; stOut.Close();
StreamWriter stOut = new StreamWriter(CheckSim.GetRequestStream(), System.Text.Encoding.ASCII); StreamReader stIn = new StreamReader(CheckSim.GetResponse().GetResponseStream());
stOut.Write(""); SimResponse = stIn.ReadToEnd();
stOut.Close(); stIn.Close();
}
StreamReader stIn = new StreamReader(CheckSim.GetResponse().GetResponseStream()); catch
SimResponse = stIn.ReadToEnd(); {
stIn.Close(); }
}
catch if (SimResponse == "OK")
{ {
} m_simProfileManager.SimProfiles[sim.UUID].online = true;
}
if (SimResponse == "OK") else
{ {
m_simProfileManager.SimProfiles[sim.UUID].online = true; m_simProfileManager.SimProfiles[sim.UUID].online = false;
} }
else }
{ */
m_simProfileManager.SimProfiles[sim.UUID].online = false; }
}
} public override void RunCmd(string cmd, string[] cmdparams)
*/ {
} base.RunCmd(cmd, cmdparams);
public void RunCmd(string cmd, string[] cmdparams) switch (cmd)
{ {
switch (cmd) case "help":
{ m_console.Notice("shutdown - shutdown the grid (USE CAUTION!)");
case "help": break;
m_console.Notice("shutdown - shutdown the grid (USE CAUTION!)");
break; case "shutdown":
m_console.Close();
case "shutdown": Environment.Exit(0);
m_console.Close(); break;
Environment.Exit(0); }
break; }
}
} /*private void ConfigDB(IGenericConfig configData)
{
public void Show(string ShowWhat) try
{ {
} string attri = String.Empty;
attri = configData.GetAttribute("DataBaseProvider");
/*private void ConfigDB(IGenericConfig configData) if (attri == String.Empty)
{ {
try GridDll = "OpenSim.Framework.Data.DB4o.dll";
{ configData.SetAttribute("DataBaseProvider", "OpenSim.Framework.Data.DB4o.dll");
string attri = ""; }
attri = configData.GetAttribute("DataBaseProvider"); else
if (attri == "") {
{ GridDll = attri;
GridDll = "OpenSim.Framework.Data.DB4o.dll"; }
configData.SetAttribute("DataBaseProvider", "OpenSim.Framework.Data.DB4o.dll"); configData.Commit();
} }
else catch
{ {
GridDll = attri;
} }
configData.Commit(); }*/
} }
catch }
{
}
}*/
}
}

View File

@ -1,63 +1,63 @@
/* /*
* Copyright (c) Contributors, http://opensimulator.org/ * Copyright (c) Contributors, http://opensimulator.org/
* See CONTRIBUTORS.TXT for a full list of copyright holders. * See CONTRIBUTORS.TXT for a full list of copyright holders.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met: * modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright * * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer. * notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright * * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the * notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution. * documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSim Project nor the * * Neither the name of the OpenSim Project nor the
* names of its contributors may be used to endorse or promote products * names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission. * derived from this software without specific prior written permission.
* *
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * 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 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* *
*/ */
using System.Reflection; using System.Reflection;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
// General Information about an assembly is controlled through the following // General Information about an assembly is controlled through the following
// set of attributes. Change these attribute values to modify the information // set of attributes. Change these attribute values to modify the information
// associated with an assembly. // associated with an assembly.
[assembly : AssemblyTitle("OGS-GridServer")] [assembly : AssemblyTitle("OGS-GridServer")]
[assembly : AssemblyDescription("")] [assembly : AssemblyDescription("")]
[assembly : AssemblyConfiguration("")] [assembly : AssemblyConfiguration("")]
[assembly : AssemblyCompany("")] [assembly : AssemblyCompany("")]
[assembly : AssemblyProduct("OGS-GridServer")] [assembly : AssemblyProduct("OGS-GridServer")]
[assembly : AssemblyCopyright("Copyright © 2007")] [assembly : AssemblyCopyright("Copyright © OpenSimulator.org Developers 2007-2008")]
[assembly : AssemblyTrademark("")] [assembly : AssemblyTrademark("")]
[assembly : AssemblyCulture("")] [assembly : AssemblyCulture("")]
// Setting ComVisible to false makes the types in this assembly not visible // Setting ComVisible to false makes the types in this assembly not visible
// to COM components. If you need to access a type in this assembly from // to COM components. If you need to access a type in this assembly from
// COM, set the ComVisible attribute to true on that type. // COM, set the ComVisible attribute to true on that type.
[assembly : ComVisible(false)] [assembly : ComVisible(false)]
// The following GUID is for the ID of the typelib if this project is exposed to COM // The following GUID is for the ID of the typelib if this project is exposed to COM
[assembly : Guid("b541b244-3d1d-4625-9003-bc2a3a6a39a4")] [assembly : Guid("b541b244-3d1d-4625-9003-bc2a3a6a39a4")]
// Version information for an assembly consists of the following four values: // Version information for an assembly consists of the following four values:
// //
// Major Version // Major Version
// Minor Version // Minor Version
// Build Number // Build Number
// Revision // Revision
// //
[assembly : AssemblyVersion("1.0.0.0")] [assembly : AssemblyVersion("1.0.0.0")]
[assembly : AssemblyFileVersion("1.0.0.0")] [assembly : AssemblyFileVersion("1.0.0.0")]