From 72adbd976cce9c20e908e4e9046d8b039194851c Mon Sep 17 00:00:00 2001 From: Melanie Thielker Date: Mon, 18 May 2009 12:10:56 +0000 Subject: Nonowrking intermadiate commit,, DO NOT USE --- OpenSim/Server/Base/HttpServerBase.cs | 86 +++++++++++ OpenSim/Server/Base/ServerUtils.cs | 148 +++++++++++++++++++ OpenSim/Server/Base/ServicesServerBase.cs | 233 ++++++++++++++++++++++++++++++ 3 files changed, 467 insertions(+) create mode 100644 OpenSim/Server/Base/HttpServerBase.cs create mode 100644 OpenSim/Server/Base/ServerUtils.cs create mode 100644 OpenSim/Server/Base/ServicesServerBase.cs (limited to 'OpenSim/Server/Base') diff --git a/OpenSim/Server/Base/HttpServerBase.cs b/OpenSim/Server/Base/HttpServerBase.cs new file mode 100644 index 0000000..dc12cf9 --- /dev/null +++ b/OpenSim/Server/Base/HttpServerBase.cs @@ -0,0 +1,86 @@ +/* + * 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 OpenSim 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.Threading; +using System.Reflection; +using OpenSim.Framework.Console; +using OpenSim.Framework.Servers.HttpServer; +using log4net; +using Nini.Config; + +namespace OpenSim.Server.Base +{ + public class HttpServerBase : ServicesServerBase + { + // Logger + // + private static readonly ILog m_log = + LogManager.GetLogger( + MethodBase.GetCurrentMethod().DeclaringType); + + // The http server instance + // + protected BaseHttpServer m_HttpServer = null; + + public IHttpServer HttpServer + { + get { return m_HttpServer; } + } + + // Handle all the automagical stuff + // + public HttpServerBase(string prompt, string[] args) : base(prompt, args) + { + } + + protected override void ReadConfig() + { + IConfig networkConfig = m_Config.Configs["Network"]; + + if (networkConfig == null) + { + System.Console.WriteLine("Section 'Network' not found, server can't start"); + Thread.CurrentThread.Abort(); + } + uint port = (uint)networkConfig.GetInt("port", 0); + + if (port == 0) + { + System.Console.WriteLine("Port number not specified or 0, server can't start"); + Thread.CurrentThread.Abort(); + } + + m_HttpServer = new BaseHttpServer(port); + } + + protected override void Initialise() + { + m_HttpServer.Start(); + } + } +} diff --git a/OpenSim/Server/Base/ServerUtils.cs b/OpenSim/Server/Base/ServerUtils.cs new file mode 100644 index 0000000..ae0c3d4 --- /dev/null +++ b/OpenSim/Server/Base/ServerUtils.cs @@ -0,0 +1,148 @@ +/* + * 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 OpenSim 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.IO; +using System.Reflection; +using System.Xml; +using System.Xml.Serialization; +using System.Text; + +namespace OpenSim.Server.Base +{ + public static class ServerUtils + { + public static string SLAssetTypeToContentType(int assetType) + { + switch (assetType) + { + case 0: + return "image/jp2"; + case 1: + return "application/ogg"; + case 2: + return "application/x-metaverse-callingcard"; + case 3: + return "application/x-metaverse-landmark"; + case 5: + return "application/x-metaverse-clothing"; + case 6: + return "application/x-metaverse-primitive"; + case 7: + return "application/x-metaverse-notecard"; + case 8: + return "application/x-metaverse-folder"; + case 10: + return "application/x-metaverse-lsl"; + case 11: + return "application/x-metaverse-lso"; + case 12: + return "image/tga"; + case 13: + return "application/x-metaverse-bodypart"; + case 17: + return "audio/x-wav"; + case 19: + return "image/jpeg"; + case 20: + return "application/x-metaverse-animation"; + case 21: + return "application/x-metaverse-gesture"; + case 22: + return "application/x-metaverse-simstate"; + default: + return "application/octet-stream"; + } + } + + public static byte[] SerializeResult(XmlSerializer xs, object data) + { + MemoryStream ms = new MemoryStream(); + XmlTextWriter xw = new XmlTextWriter(ms, Encoding.UTF8); + xw.Formatting = Formatting.Indented; + xs.Serialize(xw, data); + xw.Flush(); + + ms.Seek(0, SeekOrigin.Begin); + byte[] ret = ms.GetBuffer(); + Array.Resize(ref ret, (int)ms.Length); + + return ret; + } + + public static T LoadPlugin(string dllName, Object[] args) where T:class + { + string[] parts = dllName.Split(new char[] {':'}); + + dllName = parts[0]; + + string className = String.Empty; + + if (parts.Length > 1) + className = parts[1]; + + return LoadPlugin(dllName, className, args); + } + + public static T LoadPlugin(string dllName, string className, Object[] args) where T:class + { + string interfaceName = typeof(T).ToString(); + + try + { + Assembly pluginAssembly = Assembly.LoadFrom(dllName); + + foreach (Type pluginType in pluginAssembly.GetTypes()) + { + if (pluginType.IsPublic) + { + if (className != String.Empty && + pluginType.ToString() != + pluginType.Namespace + "." + className) + continue; + + Type typeInterface = + pluginType.GetInterface(interfaceName, true); + if (typeInterface != null) + { + T plug = (T)Activator.CreateInstance(pluginType, + args); + + return plug; + } + } + } + + return null; + } + catch (Exception e) + { + return null; + } + } + } +} diff --git a/OpenSim/Server/Base/ServicesServerBase.cs b/OpenSim/Server/Base/ServicesServerBase.cs new file mode 100644 index 0000000..5350bce --- /dev/null +++ b/OpenSim/Server/Base/ServicesServerBase.cs @@ -0,0 +1,233 @@ +/* + * 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 OpenSim 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.Xml; +using System.Threading; +using System.Reflection; +using OpenSim.Framework.Console; +using log4net; +using log4net.Config; +using log4net.Appender; +using log4net.Core; +using log4net.Repository; +using Nini.Config; + +namespace OpenSim.Server.Base +{ + public class ServicesServerBase + { + // Logger + // + private static readonly ILog m_log = + LogManager.GetLogger( + MethodBase.GetCurrentMethod().DeclaringType); + + // Command line args + // + protected string[] m_Arguments; + + // Configuration + // + protected IConfigSource m_Config = null; + + public IConfigSource Config + { + get { return m_Config; } + } + + // Run flag + // + private bool m_Running = true; + + // Handle all the automagical stuff + // + public ServicesServerBase(string prompt, string[] args) + { + // Save raw arguments + // + m_Arguments = args; + + // Read command line + // + ArgvConfigSource argvConfig = new ArgvConfigSource(args); + + argvConfig.AddSwitch("Startup", "console", "c"); + argvConfig.AddSwitch("Startup", "logfile", "l"); + argvConfig.AddSwitch("Startup", "inifile", "i"); + + // Automagically create the ini file name + // + string fullName = Assembly.GetEntryAssembly().FullName; + AssemblyName assemblyName = new AssemblyName(fullName); + + string iniFile = assemblyName.Name + ".ini"; + + // Check if a file name was given on the command line + // + IConfig startupConfig = argvConfig.Configs["Startup"]; + if (startupConfig != null) + iniFile = startupConfig.GetString("inifile", iniFile); + + // Find out of the file name is a URI and remote load it + // if it's possible. Load it as a local file otherwise. + // + Uri configUri; + + try + { + if (Uri.TryCreate(iniFile, UriKind.Absolute, out configUri) && + configUri.Scheme == Uri.UriSchemeHttp) + { + XmlReader r = XmlReader.Create(iniFile); + m_Config = new XmlConfigSource(r); + } + else + { + m_Config = new IniConfigSource(iniFile); + } + } + catch (Exception) + { + System.Console.WriteLine("Error reading from config source {0}", + iniFile); + Thread.CurrentThread.Abort(); + } + + // Merge the configuration from the command line into the + // loaded file + // + m_Config.Merge(argvConfig); + + // Refresh the startupConfig post merge + // + if (m_Config.Configs["Startup"] != null) + { + startupConfig = m_Config.Configs["Startup"]; + } + + // Allow derived classes to load config before the console is + // opened. + // + ReadConfig(); + + // Create main console + // + string consoleType = "local"; + if (startupConfig != null) + consoleType = startupConfig.GetString("console", consoleType); + + if (consoleType == "basic") + { + MainConsole.Instance = new CommandConsole(prompt); + } + else + { + MainConsole.Instance = new LocalConsole(prompt); + } + + // Configure the appenders for log4net + // + OpenSimAppender consoleAppender = null; + FileAppender fileAppender = null; + + XmlConfigurator.Configure(); + + ILoggerRepository repository = LogManager.GetRepository(); + IAppender[] appenders = repository.GetAppenders(); + + foreach (IAppender appender in appenders) + { + if (appender.Name == "Console") + { + consoleAppender = (OpenSimAppender)appender; + } + if (appender.Name == "LogFileAppender") + { + fileAppender = (FileAppender)appender; + } + } + + if (consoleAppender == null) + { + System.Console.WriteLine("No console appender found. Server can't start"); + Thread.CurrentThread.Abort(); + } + else + { + consoleAppender.Console = MainConsole.Instance; + + if (null == consoleAppender.Threshold) + consoleAppender.Threshold = Level.All; + } + + // Set log file + // + if (fileAppender != null) + { + if (startupConfig != null) + fileAppender.File = startupConfig.GetString("logfile", + assemblyName.Name + ".log"); + } + + // Register the quit command + // + MainConsole.Instance.Commands.AddCommand("base", false, "quit", + "quit", + "Quit the application", HandleQuit); + + // Allow derived classes to perform initialization that + // needs to be done after the console has opened + // + Initialise(); + } + + public virtual int Run() + { + while (m_Running) + { + MainConsole.Instance.Prompt(); + } + + return 0; + } + + protected virtual void HandleQuit(string module, string[] args) + { + m_Running = false; + m_log.Info("[CONSOLE] Quitting"); + } + + protected virtual void ReadConfig() + { + } + + protected virtual void Initialise() + { + } + } +} -- cgit v1.1