Add the OpenSim.ConsoleClient app.
Usage: OpenSim.ConsoleClient -h <host> -p <port> -u <user> -P <pass> host defaults to localhost, port defaults to 8003.arthursv
parent
b05539e7cf
commit
cef16bec6d
|
@ -0,0 +1,185 @@
|
||||||
|
/*
|
||||||
|
* 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 Nini.Config;
|
||||||
|
using log4net;
|
||||||
|
using System.Reflection;
|
||||||
|
using System;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using OpenSim.Server.Base;
|
||||||
|
using OpenSim.Framework.Console;
|
||||||
|
using OpenMetaverse;
|
||||||
|
|
||||||
|
namespace OpenSim.ConsoleClient
|
||||||
|
{
|
||||||
|
public class OpenSimConsoleClient
|
||||||
|
{
|
||||||
|
private static readonly ILog m_log =
|
||||||
|
LogManager.GetLogger(
|
||||||
|
MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
|
protected static ServicesServerBase m_Server = null;
|
||||||
|
private static string m_Host;
|
||||||
|
private static int m_Port;
|
||||||
|
private static string m_User;
|
||||||
|
private static string m_Pass;
|
||||||
|
private static UUID m_SessionID;
|
||||||
|
|
||||||
|
static int Main(string[] args)
|
||||||
|
{
|
||||||
|
m_Server = new ServicesServerBase("Client", args);
|
||||||
|
|
||||||
|
IConfig serverConfig = m_Server.Config.Configs["Startup"];
|
||||||
|
if (serverConfig == null)
|
||||||
|
{
|
||||||
|
System.Console.WriteLine("Startup config section missing in .ini file");
|
||||||
|
throw new Exception("Configuration error");
|
||||||
|
}
|
||||||
|
|
||||||
|
ArgvConfigSource argvConfig = new ArgvConfigSource(args);
|
||||||
|
|
||||||
|
argvConfig.AddSwitch("Startup", "host", "h");
|
||||||
|
argvConfig.AddSwitch("Startup", "port", "p");
|
||||||
|
argvConfig.AddSwitch("Startup", "user", "u");
|
||||||
|
argvConfig.AddSwitch("Startup", "pass", "P");
|
||||||
|
|
||||||
|
m_Server.Config.Merge(argvConfig);
|
||||||
|
|
||||||
|
m_User = serverConfig.GetString("user", "Test");
|
||||||
|
m_Host = serverConfig.GetString("host", "localhost");
|
||||||
|
m_Port = serverConfig.GetInt("port", 8003);
|
||||||
|
m_Pass = serverConfig.GetString("pass", "secret");
|
||||||
|
|
||||||
|
Requester.MakeRequest("http://"+m_Host+":"+m_Port.ToString()+"/StartSession/", String.Format("USER={0}&PASS={1}", m_User, m_Pass), LoginReply);
|
||||||
|
|
||||||
|
int res = m_Server.Run();
|
||||||
|
|
||||||
|
Environment.Exit(res);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendCommand(string module, string[] cmd)
|
||||||
|
{
|
||||||
|
string sendCmd = String.Join(" ", cmd);
|
||||||
|
|
||||||
|
Requester.MakeRequest("http://"+m_Host+":"+m_Port.ToString()+"/SessionCommand/", String.Format("ID={0}&COMMAND={1}", m_SessionID, sendCmd), CommandReply);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoginReply(string requestUrl, string requestData, string replyData)
|
||||||
|
{
|
||||||
|
XmlDocument doc = new XmlDocument();
|
||||||
|
|
||||||
|
doc.LoadXml(replyData);
|
||||||
|
|
||||||
|
XmlNodeList rootL = doc.GetElementsByTagName("ConsoleSession");
|
||||||
|
if (rootL.Count != 1)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
XmlElement rootNode = (XmlElement)rootL[0];
|
||||||
|
|
||||||
|
if (rootNode == null)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlNodeList helpNodeL = rootNode.GetElementsByTagName("HelpTree");
|
||||||
|
if (helpNodeL.Count != 1)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlElement helpNode = (XmlElement)helpNodeL[0];
|
||||||
|
if (helpNode == null)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlNodeList sessionL = rootNode.GetElementsByTagName("SessionID");
|
||||||
|
if (sessionL.Count != 1)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlElement sessionNode = (XmlElement)sessionL[0];
|
||||||
|
if (sessionNode == null)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!UUID.TryParse(sessionNode.InnerText, out m_SessionID))
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("Connection data info was not valid");
|
||||||
|
Environment.Exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
MainConsole.Instance.Commands.FromXml(helpNode, SendCommand);
|
||||||
|
|
||||||
|
Requester.MakeRequest("http://"+m_Host+":"+m_Port.ToString()+"/ReadResponses/"+m_SessionID.ToString()+"/", String.Empty, ReadResponses);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ReadResponses(string requestUrl, string requestData, string replyData)
|
||||||
|
{
|
||||||
|
XmlDocument doc = new XmlDocument();
|
||||||
|
|
||||||
|
doc.LoadXml(replyData);
|
||||||
|
|
||||||
|
XmlNodeList rootNodeL = doc.GetElementsByTagName("ConsoleSession");
|
||||||
|
if (rootNodeL.Count != 1 || rootNodeL[0] == null)
|
||||||
|
{
|
||||||
|
Requester.MakeRequest(requestUrl, requestData, ReadResponses);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (XmlNode part in rootNodeL[0].ChildNodes)
|
||||||
|
{
|
||||||
|
if (part.Name != "Line")
|
||||||
|
continue;
|
||||||
|
|
||||||
|
string[] parts = part.InnerText.Split(new char[] {':'}, 3);
|
||||||
|
if (parts.Length != 3)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
MainConsole.Instance.Output(parts[2], parts[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
Requester.MakeRequest(requestUrl, requestData, ReadResponses);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void CommandReply(string requestUrl, string requestData, string replyData)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -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 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.IO;
|
||||||
|
using System.Net;
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Text;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
using log4net;
|
||||||
|
|
||||||
|
namespace OpenSim.ConsoleClient
|
||||||
|
{
|
||||||
|
public delegate void ReplyDelegate(string requestUrl, string requestData, string replyData);
|
||||||
|
|
||||||
|
public class Requester
|
||||||
|
{
|
||||||
|
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
|
public static void MakeRequest(string requestUrl, string data,
|
||||||
|
ReplyDelegate action)
|
||||||
|
{
|
||||||
|
WebRequest request = WebRequest.Create(requestUrl);
|
||||||
|
WebResponse response = null;
|
||||||
|
|
||||||
|
request.Method = "POST";
|
||||||
|
|
||||||
|
request.ContentType = "application/x-www-form-urlencoded";
|
||||||
|
|
||||||
|
byte[] buffer = new System.Text.ASCIIEncoding().GetBytes(data);
|
||||||
|
int length = (int) buffer.Length;
|
||||||
|
request.ContentLength = length;
|
||||||
|
|
||||||
|
request.BeginGetRequestStream(delegate(IAsyncResult res)
|
||||||
|
{
|
||||||
|
Stream requestStream = request.EndGetRequestStream(res);
|
||||||
|
|
||||||
|
requestStream.Write(buffer, 0, length);
|
||||||
|
|
||||||
|
request.BeginGetResponse(delegate(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
string reply = String.Empty;
|
||||||
|
|
||||||
|
response = request.EndGetResponse(ar);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
StreamReader r = new StreamReader(response.GetResponseStream());
|
||||||
|
reply = r.ReadToEnd();
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (System.InvalidOperationException)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
action(requestUrl, data, reply);
|
||||||
|
}, null);
|
||||||
|
}, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -373,10 +373,28 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public XmlElement GetXml(XmlDocument doc)
|
public XmlElement GetXml(XmlDocument doc)
|
||||||
{
|
{
|
||||||
|
CommandInfo help = (CommandInfo)((Dictionary<string, object>)tree["help"])[String.Empty];
|
||||||
|
((Dictionary<string, object>)tree["help"]).Remove(string.Empty);
|
||||||
|
if (((Dictionary<string, object>)tree["help"]).Count == 0)
|
||||||
|
tree.Remove("help");
|
||||||
|
|
||||||
|
CommandInfo quit = (CommandInfo)((Dictionary<string, object>)tree["quit"])[String.Empty];
|
||||||
|
((Dictionary<string, object>)tree["quit"]).Remove(string.Empty);
|
||||||
|
if (((Dictionary<string, object>)tree["quit"]).Count == 0)
|
||||||
|
tree.Remove("quit");
|
||||||
|
|
||||||
XmlElement root = doc.CreateElement("", "HelpTree", "");
|
XmlElement root = doc.CreateElement("", "HelpTree", "");
|
||||||
|
|
||||||
ProcessTreeLevel(tree, root, doc);
|
ProcessTreeLevel(tree, root, doc);
|
||||||
|
|
||||||
|
if (!tree.ContainsKey("help"))
|
||||||
|
tree["help"] = (object) new Dictionary<string, object>();
|
||||||
|
((Dictionary<string, object>)tree["help"])[String.Empty] = help;
|
||||||
|
|
||||||
|
if (!tree.ContainsKey("quit"))
|
||||||
|
tree["quit"] = (object) new Dictionary<string, object>();
|
||||||
|
((Dictionary<string, object>)tree["quit"])[String.Empty] = quit;
|
||||||
|
|
||||||
return root;
|
return root;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -426,8 +444,80 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void FromXml(XmlElement root)
|
public void FromXml(XmlElement root, CommandDelegate fn)
|
||||||
{
|
{
|
||||||
|
CommandInfo help = (CommandInfo)((Dictionary<string, object>)tree["help"])[String.Empty];
|
||||||
|
((Dictionary<string, object>)tree["help"]).Remove(string.Empty);
|
||||||
|
if (((Dictionary<string, object>)tree["help"]).Count == 0)
|
||||||
|
tree.Remove("help");
|
||||||
|
|
||||||
|
CommandInfo quit = (CommandInfo)((Dictionary<string, object>)tree["quit"])[String.Empty];
|
||||||
|
((Dictionary<string, object>)tree["quit"]).Remove(string.Empty);
|
||||||
|
if (((Dictionary<string, object>)tree["quit"]).Count == 0)
|
||||||
|
tree.Remove("quit");
|
||||||
|
|
||||||
|
tree.Clear();
|
||||||
|
|
||||||
|
ReadTreeLevel(tree, root, fn);
|
||||||
|
|
||||||
|
if (!tree.ContainsKey("help"))
|
||||||
|
tree["help"] = (object) new Dictionary<string, object>();
|
||||||
|
((Dictionary<string, object>)tree["help"])[String.Empty] = help;
|
||||||
|
|
||||||
|
if (!tree.ContainsKey("quit"))
|
||||||
|
tree["quit"] = (object) new Dictionary<string, object>();
|
||||||
|
((Dictionary<string, object>)tree["quit"])[String.Empty] = quit;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ReadTreeLevel(Dictionary<string, object> level, XmlNode node, CommandDelegate fn)
|
||||||
|
{
|
||||||
|
Dictionary<string, object> next;
|
||||||
|
string name;
|
||||||
|
|
||||||
|
XmlNodeList nodeL = node.ChildNodes;
|
||||||
|
XmlNodeList cmdL;
|
||||||
|
CommandInfo c;
|
||||||
|
|
||||||
|
foreach (XmlNode part in nodeL)
|
||||||
|
{
|
||||||
|
switch (part.Name)
|
||||||
|
{
|
||||||
|
case "Level":
|
||||||
|
name = ((XmlElement)part).GetAttribute("Name");
|
||||||
|
next = new Dictionary<string, object>();
|
||||||
|
level[name] = next;
|
||||||
|
ReadTreeLevel(next, part, fn);
|
||||||
|
break;
|
||||||
|
case "Command":
|
||||||
|
cmdL = part.ChildNodes;
|
||||||
|
c = new CommandInfo();
|
||||||
|
foreach (XmlNode cmdPart in cmdL)
|
||||||
|
{
|
||||||
|
switch (cmdPart.Name)
|
||||||
|
{
|
||||||
|
case "Module":
|
||||||
|
c.module = cmdPart.InnerText;
|
||||||
|
break;
|
||||||
|
case "Shared":
|
||||||
|
c.shared = Convert.ToBoolean(cmdPart.InnerText);
|
||||||
|
break;
|
||||||
|
case "HelpText":
|
||||||
|
c.help_text = cmdPart.InnerText;
|
||||||
|
break;
|
||||||
|
case "LongHelp":
|
||||||
|
c.long_help = cmdPart.InnerText;
|
||||||
|
break;
|
||||||
|
case "Description":
|
||||||
|
c.descriptive_help = cmdPart.InnerText;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
c.fn = new List<CommandDelegate>();
|
||||||
|
c.fn.Add(fn);
|
||||||
|
level[String.Empty] = c;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -98,7 +98,12 @@ namespace OpenSim.Framework.Console
|
||||||
m_LineNumber++;
|
m_LineNumber++;
|
||||||
m_Scrollback.Add(String.Format("{0}", m_LineNumber)+":"+level+":"+text);
|
m_Scrollback.Add(String.Format("{0}", m_LineNumber)+":"+level+":"+text);
|
||||||
}
|
}
|
||||||
System.Console.Write(text);
|
System.Console.WriteLine(text.Trim());
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Output(string text)
|
||||||
|
{
|
||||||
|
Output(text, "normal");
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ReadLine(string p, bool isCommand, bool e)
|
public override string ReadLine(string p, bool isCommand, bool e)
|
||||||
|
@ -152,9 +157,8 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
foreach (UUID id in expired)
|
foreach (UUID id in expired)
|
||||||
{
|
{
|
||||||
System.Console.WriteLine("Expired {0}", id.ToString());
|
|
||||||
CloseConnection(id);
|
|
||||||
m_Connections.Remove(id);
|
m_Connections.Remove(id);
|
||||||
|
CloseConnection(id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -244,8 +248,8 @@ namespace OpenSim.Framework.Console
|
||||||
{
|
{
|
||||||
if (m_Connections.ContainsKey(id))
|
if (m_Connections.ContainsKey(id))
|
||||||
{
|
{
|
||||||
CloseConnection(id);
|
|
||||||
m_Connections.Remove(id);
|
m_Connections.Remove(id);
|
||||||
|
CloseConnection(id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -346,9 +350,15 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public void CloseConnection(UUID id)
|
public void CloseConnection(UUID id)
|
||||||
{
|
{
|
||||||
string uri = "/ReadResponses/" + id.ToString() + "/";
|
try
|
||||||
|
{
|
||||||
|
string uri = "/ReadResponses/" + id.ToString() + "/";
|
||||||
|
|
||||||
m_Server.RemovePollServiceHTTPHandler("", uri);
|
m_Server.RemovePollServiceHTTPHandler("", uri);
|
||||||
|
}
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool HasEvents(UUID sessionID)
|
private bool HasEvents(UUID sessionID)
|
||||||
|
@ -394,8 +404,11 @@ namespace OpenSim.Framework.Console
|
||||||
lock (m_Scrollback)
|
lock (m_Scrollback)
|
||||||
{
|
{
|
||||||
long startLine = m_LineNumber - m_Scrollback.Count;
|
long startLine = m_LineNumber - m_Scrollback.Count;
|
||||||
|
long sendStart = startLine;
|
||||||
|
if (sendStart < c.lastLineSeen)
|
||||||
|
sendStart = c.lastLineSeen;
|
||||||
|
|
||||||
for (long i = startLine ; i < m_LineNumber ; i++)
|
for (long i = sendStart ; i < m_LineNumber ; i++)
|
||||||
{
|
{
|
||||||
XmlElement res = xmldoc.CreateElement("", "Line", "");
|
XmlElement res = xmldoc.CreateElement("", "Line", "");
|
||||||
long line = i + 1;
|
long line = i + 1;
|
||||||
|
@ -422,12 +435,21 @@ namespace OpenSim.Framework.Console
|
||||||
{
|
{
|
||||||
Hashtable result = new Hashtable();
|
Hashtable result = new Hashtable();
|
||||||
|
|
||||||
result["int_response_code"] = 502;
|
XmlDocument xmldoc = new XmlDocument();
|
||||||
result["content_type"] = "text/plain";
|
XmlNode xmlnode = xmldoc.CreateNode(XmlNodeType.XmlDeclaration,
|
||||||
|
"", "");
|
||||||
|
|
||||||
|
xmldoc.AppendChild(xmlnode);
|
||||||
|
XmlElement rootElement = xmldoc.CreateElement("", "ConsoleSession",
|
||||||
|
"");
|
||||||
|
|
||||||
|
xmldoc.AppendChild(rootElement);
|
||||||
|
|
||||||
|
result["str_response_string"] = xmldoc.InnerXml;
|
||||||
|
result["int_response_code"] = 200;
|
||||||
|
result["content_type"] = "text/xml";
|
||||||
result["keepalive"] = false;
|
result["keepalive"] = false;
|
||||||
result["reusecontext"] = false;
|
result["reusecontext"] = false;
|
||||||
result["str_response_string"] = "Upstream error: ";
|
|
||||||
result["error_status_text"] = "Upstream error:";
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
|
<configuration>
|
||||||
|
<configSections>
|
||||||
|
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
|
||||||
|
</configSections>
|
||||||
|
<runtime>
|
||||||
|
<gcConcurrent enabled="true" />
|
||||||
|
<gcServer enabled="true" />
|
||||||
|
</runtime>
|
||||||
|
<appSettings>
|
||||||
|
</appSettings>
|
||||||
|
<log4net>
|
||||||
|
<appender name="Console" type="OpenSim.Framework.Console.OpenSimAppender, OpenSim.Framework.Console">
|
||||||
|
<layout type="log4net.Layout.PatternLayout">
|
||||||
|
<conversionPattern value="%date{HH:mm:ss} - %message%newline" />
|
||||||
|
</layout>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<appender name="LogFileAppender" type="log4net.Appender.FileAppender">
|
||||||
|
<file value="OpenSim.log" />
|
||||||
|
<appendToFile value="true" />
|
||||||
|
<layout type="log4net.Layout.PatternLayout">
|
||||||
|
<conversionPattern value="%date %-5level - %logger %message%newline" />
|
||||||
|
</layout>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<root>
|
||||||
|
<level value="DEBUG" />
|
||||||
|
<appender-ref ref="Console" />
|
||||||
|
<appender-ref ref="LogFileAppender" />
|
||||||
|
</root>
|
||||||
|
</log4net>
|
||||||
|
</configuration>
|
|
@ -0,0 +1 @@
|
||||||
|
[Startup]
|
32
prebuild.xml
32
prebuild.xml
|
@ -1595,6 +1595,38 @@
|
||||||
</Files>
|
</Files>
|
||||||
</Project>
|
</Project>
|
||||||
|
|
||||||
|
<Project frameworkVersion="v3_5" name="OpenSim.ConsoleClient" path="OpenSim/ConsoleClient" type="Exe">
|
||||||
|
<Configuration name="Debug">
|
||||||
|
<Options>
|
||||||
|
<OutputPath>../../bin/</OutputPath>
|
||||||
|
</Options>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration name="Release">
|
||||||
|
<Options>
|
||||||
|
<OutputPath>../../bin/</OutputPath>
|
||||||
|
</Options>
|
||||||
|
</Configuration>
|
||||||
|
|
||||||
|
<ReferencePath>../../bin/</ReferencePath>
|
||||||
|
<Reference name="System"/>
|
||||||
|
<Reference name="System.Xml"/>
|
||||||
|
<Reference name="OpenMetaverseTypes.dll"/>
|
||||||
|
<Reference name="OpenMetaverse.dll"/>
|
||||||
|
<Reference name="OpenMetaverse.StructuredData.dll"/>
|
||||||
|
<Reference name="OpenSim.Framework"/>
|
||||||
|
<Reference name="OpenSim.Framework.Console"/>
|
||||||
|
<Reference name="OpenSim.Framework.Servers.HttpServer"/>
|
||||||
|
<Reference name="OpenSim.Server.Base"/>
|
||||||
|
<Reference name="Nini.dll" />
|
||||||
|
<Reference name="log4net.dll"/>
|
||||||
|
|
||||||
|
<Files>
|
||||||
|
<Match pattern="*.cs" recurse="false">
|
||||||
|
<Exclude pattern="Tests" />
|
||||||
|
</Match>
|
||||||
|
</Files>
|
||||||
|
</Project>
|
||||||
|
|
||||||
<Project frameworkVersion="v3_5" name="OpenSim.Region.CoreModules" path="OpenSim/Region/CoreModules" type="Library">
|
<Project frameworkVersion="v3_5" name="OpenSim.Region.CoreModules" path="OpenSim/Region/CoreModules" type="Library">
|
||||||
<Configuration name="Debug">
|
<Configuration name="Debug">
|
||||||
<Options>
|
<Options>
|
||||||
|
|
Loading…
Reference in New Issue