Merge branch 'master' into careminster
Conflicts: OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs OpenSim/Region/ScriptEngine/XEngine/XEngine.csavinationmerge
commit
c0f70d17fc
|
@ -162,7 +162,7 @@ namespace OpenSim.Data.MySQL
|
||||||
using (GZipStream decompressionStream = new GZipStream(new MemoryStream(asset.Data), CompressionMode.Decompress))
|
using (GZipStream decompressionStream = new GZipStream(new MemoryStream(asset.Data), CompressionMode.Decompress))
|
||||||
{
|
{
|
||||||
MemoryStream outputStream = new MemoryStream();
|
MemoryStream outputStream = new MemoryStream();
|
||||||
WebUtil.CopyTo(decompressionStream, outputStream, int.MaxValue);
|
WebUtil.CopyStream(decompressionStream, outputStream, int.MaxValue);
|
||||||
// int compressedLength = asset.Data.Length;
|
// int compressedLength = asset.Data.Length;
|
||||||
asset.Data = outputStream.ToArray();
|
asset.Data = outputStream.ToArray();
|
||||||
|
|
||||||
|
|
|
@ -119,7 +119,7 @@ namespace OpenSim.Framework
|
||||||
// Copy the temporary stream to the network stream
|
// Copy the temporary stream to the network stream
|
||||||
formDataStream.Seek(0, SeekOrigin.Begin);
|
formDataStream.Seek(0, SeekOrigin.Begin);
|
||||||
using (Stream requestStream = request.GetRequestStream())
|
using (Stream requestStream = request.GetRequestStream())
|
||||||
formDataStream.CopyTo(requestStream, (int)formDataStream.Length);
|
formDataStream.CopyStream(requestStream, (int)formDataStream.Length);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Stream Writing
|
#endregion Stream Writing
|
||||||
|
|
|
@ -511,8 +511,13 @@ namespace OpenSim.Framework
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// Copying begins at the streams' current positions. The positions are
|
/// Copying begins at the streams' current positions. The positions are
|
||||||
/// NOT reset after copying is complete.
|
/// NOT reset after copying is complete.
|
||||||
|
/// NOTE!! .NET 4.0 adds the method 'Stream.CopyTo(stream, bufferSize)'.
|
||||||
|
/// This function could be replaced with that method once we move
|
||||||
|
/// totally to .NET 4.0. For versions before, this routine exists.
|
||||||
|
/// This routine used to be named 'CopyTo' but the int parameter has
|
||||||
|
/// a different meaning so this method was renamed to avoid any confusion.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
public static int CopyTo(this Stream copyFrom, Stream copyTo, int maximumBytesToCopy)
|
public static int CopyStream(this Stream copyFrom, Stream copyTo, int maximumBytesToCopy)
|
||||||
{
|
{
|
||||||
byte[] buffer = new byte[4096];
|
byte[] buffer = new byte[4096];
|
||||||
int readBytes;
|
int readBytes;
|
||||||
|
|
|
@ -305,6 +305,9 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (IsInTransit(sp.UUID)) // Avie is already on the way. Caller shouldn't do this.
|
||||||
|
return;
|
||||||
|
|
||||||
m_log.DebugFormat(
|
m_log.DebugFormat(
|
||||||
"[ENTITY TRANSFER MODULE]: Request Teleport to {0} ({1}) {2}/{3}",
|
"[ENTITY TRANSFER MODULE]: Request Teleport to {0} ({1}) {2}/{3}",
|
||||||
reg.ServerURI, finalDestination.ServerURI, finalDestination.RegionName, position);
|
reg.ServerURI, finalDestination.ServerURI, finalDestination.RegionName, position);
|
||||||
|
@ -1825,6 +1828,16 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected bool IsInTransit(UUID id)
|
||||||
|
{
|
||||||
|
lock (m_agentsInTransit)
|
||||||
|
{
|
||||||
|
if (m_agentsInTransit.Contains(id))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected bool ResetFromTransit(UUID id)
|
protected bool ResetFromTransit(UUID id)
|
||||||
{
|
{
|
||||||
lock (m_agentsInTransit)
|
lock (m_agentsInTransit)
|
||||||
|
|
|
@ -46,8 +46,6 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
private DataSnapshotManager m_externalData = null;
|
private DataSnapshotManager m_externalData = null;
|
||||||
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
private readonly string m_discoveryPath = "DS0001/";
|
|
||||||
|
|
||||||
public DataRequestHandler(Scene scene, DataSnapshotManager externalData)
|
public DataRequestHandler(Scene scene, DataSnapshotManager externalData)
|
||||||
{
|
{
|
||||||
m_scene = scene;
|
m_scene = scene;
|
||||||
|
@ -58,37 +56,9 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
{
|
{
|
||||||
m_log.Info("[DATASNAPSHOT]: Set up snapshot service");
|
m_log.Info("[DATASNAPSHOT]: Set up snapshot service");
|
||||||
}
|
}
|
||||||
|
// Register validation callback handler
|
||||||
|
MainServer.Instance.AddHTTPHandler("validate", OnValidate);
|
||||||
|
|
||||||
//Register CAPS handler event
|
|
||||||
m_scene.EventManager.OnRegisterCaps += OnRegisterCaps;
|
|
||||||
|
|
||||||
//harbl
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnRegisterCaps(UUID agentID, Caps caps)
|
|
||||||
{
|
|
||||||
// m_log.InfoFormat("[DATASNAPSHOT]: Registering service discovery capability for {0}", agentID);
|
|
||||||
string capsBase = "/CAPS/" + caps.CapsObjectPath;
|
|
||||||
caps.RegisterHandler("PublicSnapshotDataInfo",
|
|
||||||
new RestStreamHandler("POST", capsBase + m_discoveryPath, OnDiscoveryAttempt));
|
|
||||||
}
|
|
||||||
|
|
||||||
public string OnDiscoveryAttempt(string request, string path, string param,
|
|
||||||
IOSHttpRequest httpRequest, IOSHttpResponse httpResponse)
|
|
||||||
{
|
|
||||||
//Very static for now, flexible enough to add new formats
|
|
||||||
LLSDDiscoveryResponse llsd_response = new LLSDDiscoveryResponse();
|
|
||||||
llsd_response.snapshot_resources = new OSDArray();
|
|
||||||
|
|
||||||
LLSDDiscoveryDataURL llsd_dataurl = new LLSDDiscoveryDataURL();
|
|
||||||
llsd_dataurl.snapshot_format = "os-datasnapshot-v1";
|
|
||||||
llsd_dataurl.snapshot_url = "http://" + m_externalData.m_hostname + ":" + m_externalData.m_listener_port + "/?method=collector";
|
|
||||||
|
|
||||||
llsd_response.snapshot_resources.Array.Add(llsd_dataurl);
|
|
||||||
|
|
||||||
string response = LLSDHelpers.SerialiseLLSDReply(llsd_response);
|
|
||||||
|
|
||||||
return response;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Hashtable OnGetSnapshot(Hashtable keysvals)
|
public Hashtable OnGetSnapshot(Hashtable keysvals)
|
||||||
|
@ -107,5 +77,23 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
|
|
||||||
return reply;
|
return reply;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Hashtable OnValidate(Hashtable keysvals)
|
||||||
|
{
|
||||||
|
m_log.Info("[DATASNAPSHOT] Received validation request");
|
||||||
|
Hashtable reply = new Hashtable();
|
||||||
|
int statuscode = 200;
|
||||||
|
|
||||||
|
string secret = (string)keysvals["secret"];
|
||||||
|
if (secret == m_externalData.Secret.ToString())
|
||||||
|
statuscode = 403;
|
||||||
|
|
||||||
|
reply["str_response_string"] = string.Empty;
|
||||||
|
reply["int_response_code"] = statuscode;
|
||||||
|
reply["content_type"] = "text/plain";
|
||||||
|
|
||||||
|
return reply;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,6 +66,7 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
private string m_dataServices = "noservices";
|
private string m_dataServices = "noservices";
|
||||||
public string m_listener_port = ConfigSettings.DefaultRegionHttpPort.ToString();
|
public string m_listener_port = ConfigSettings.DefaultRegionHttpPort.ToString();
|
||||||
public string m_hostname = "127.0.0.1";
|
public string m_hostname = "127.0.0.1";
|
||||||
|
private UUID m_Secret = UUID.Random();
|
||||||
|
|
||||||
//Update timers
|
//Update timers
|
||||||
private int m_period = 20; // in seconds
|
private int m_period = 20; // in seconds
|
||||||
|
@ -85,6 +86,11 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
get { return m_exposure_level; }
|
get { return m_exposure_level; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public UUID Secret
|
||||||
|
{
|
||||||
|
get { return m_Secret; }
|
||||||
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region IRegionModule
|
#region IRegionModule
|
||||||
|
@ -103,10 +109,10 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
m_enabled = config.Configs["DataSnapshot"].GetBoolean("index_sims", m_enabled);
|
m_enabled = config.Configs["DataSnapshot"].GetBoolean("index_sims", m_enabled);
|
||||||
IConfig conf = config.Configs["GridService"];
|
IConfig conf = config.Configs["GridService"];
|
||||||
if (conf != null)
|
if (conf != null)
|
||||||
m_gridinfo.Add("gridserverURL", conf.GetString("GridServerURI", "http://127.0.0.1:8003"));
|
m_gridinfo.Add("gatekeeperURL", conf.GetString("Gatekeeper", String.Empty));
|
||||||
|
|
||||||
m_gridinfo.Add(
|
m_gridinfo.Add(
|
||||||
"Name", config.Configs["DataSnapshot"].GetString("gridname", "the lost continent of hippo"));
|
"name", config.Configs["DataSnapshot"].GetString("gridname", "the lost continent of hippo"));
|
||||||
m_exposure_level = config.Configs["DataSnapshot"].GetString("data_exposure", m_exposure_level);
|
m_exposure_level = config.Configs["DataSnapshot"].GetString("data_exposure", m_exposure_level);
|
||||||
m_period = config.Configs["DataSnapshot"].GetInt("default_snapshot_period", m_period);
|
m_period = config.Configs["DataSnapshot"].GetInt("default_snapshot_period", m_period);
|
||||||
m_maxStales = config.Configs["DataSnapshot"].GetInt("max_changes_before_update", m_maxStales);
|
m_maxStales = config.Configs["DataSnapshot"].GetInt("max_changes_before_update", m_maxStales);
|
||||||
|
@ -315,6 +321,7 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
cli.AddQueryParameter("service", serviceName);
|
cli.AddQueryParameter("service", serviceName);
|
||||||
cli.AddQueryParameter("host", m_hostname);
|
cli.AddQueryParameter("host", m_hostname);
|
||||||
cli.AddQueryParameter("port", m_listener_port);
|
cli.AddQueryParameter("port", m_listener_port);
|
||||||
|
cli.AddQueryParameter("secret", m_Secret.ToString());
|
||||||
cli.RequestMethod = "GET";
|
cli.RequestMethod = "GET";
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -341,7 +348,7 @@ namespace OpenSim.Region.DataSnapshot
|
||||||
}
|
}
|
||||||
// This is not quite working, so...
|
// This is not quite working, so...
|
||||||
// string responseStr = Util.UTF8.GetString(response);
|
// string responseStr = Util.UTF8.GetString(response);
|
||||||
m_log.Info("[DATASNAPSHOT]: data service notified: " + url);
|
m_log.Info("[DATASNAPSHOT]: data service " + url + " notified. Secret: " + m_Secret);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,7 @@ namespace OpenSim.Region.ScriptEngine.Interfaces
|
||||||
void Start();
|
void Start();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Stop the script.
|
/// Stop the script instance.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="timeout"></param>
|
/// <param name="timeout"></param>
|
||||||
/// <returns>true if the script was successfully stopped, false otherwise</returns>
|
/// <returns>true if the script was successfully stopped, false otherwise</returns>
|
||||||
|
@ -97,13 +97,17 @@ namespace OpenSim.Region.ScriptEngine.Interfaces
|
||||||
|
|
||||||
void SetState(string state);
|
void SetState(string state);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Post an event to this script instance.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="data"></param>
|
||||||
void PostEvent(EventParams data);
|
void PostEvent(EventParams data);
|
||||||
|
|
||||||
void Suspend();
|
void Suspend();
|
||||||
void Resume();
|
void Resume();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Process the next event queued for this script
|
/// Process the next event queued for this script instance.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
object EventProcessor();
|
object EventProcessor();
|
||||||
|
|
|
@ -2102,6 +2102,20 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
||||||
return HomeURI;
|
return HomeURI;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string osGetGridGatekeeperURI()
|
||||||
|
{
|
||||||
|
CheckThreatLevel(ThreatLevel.Moderate, "osGetGridGatekeeperURI");
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
|
||||||
|
string gatekeeperURI = String.Empty;
|
||||||
|
IConfigSource config = m_ScriptEngine.ConfigSource;
|
||||||
|
|
||||||
|
if (config.Configs["GridService"] != null)
|
||||||
|
gatekeeperURI = config.Configs["GridService"].GetString("Gatekeeper", gatekeeperURI);
|
||||||
|
|
||||||
|
return gatekeeperURI;
|
||||||
|
}
|
||||||
|
|
||||||
public string osGetGridCustom(string key)
|
public string osGetGridCustom(string key)
|
||||||
{
|
{
|
||||||
CheckThreatLevel(ThreatLevel.Moderate, "osGetGridCustom");
|
CheckThreatLevel(ThreatLevel.Moderate, "osGetGridCustom");
|
||||||
|
|
|
@ -161,6 +161,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api.Interfaces
|
||||||
string osGetGridName();
|
string osGetGridName();
|
||||||
string osGetGridLoginURI();
|
string osGetGridLoginURI();
|
||||||
string osGetGridHomeURI();
|
string osGetGridHomeURI();
|
||||||
|
string osGetGridGatekeeperURI();
|
||||||
string osGetGridCustom(string key);
|
string osGetGridCustom(string key);
|
||||||
|
|
||||||
LSL_String osFormatString(string str, LSL_List strings);
|
LSL_String osFormatString(string str, LSL_List strings);
|
||||||
|
|
|
@ -457,6 +457,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase
|
||||||
return m_OSSL_Functions.osGetGridHomeURI();
|
return m_OSSL_Functions.osGetGridHomeURI();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string osGetGridGatekeeperURI()
|
||||||
|
{
|
||||||
|
return m_OSSL_Functions.osGetGridGatekeeperURI();
|
||||||
|
}
|
||||||
|
|
||||||
public string osGetGridCustom(string key)
|
public string osGetGridCustom(string key)
|
||||||
{
|
{
|
||||||
return m_OSSL_Functions.osGetGridCustom(key);
|
return m_OSSL_Functions.osGetGridCustom(key);
|
||||||
|
|
|
@ -59,7 +59,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
private IScriptEngine m_Engine;
|
private IScriptEngine m_Engine;
|
||||||
private IScriptWorkItem m_CurrentResult = null;
|
|
||||||
|
/// <summary>
|
||||||
|
/// The current work item if an event for this script is running or waiting to run,
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// Null if there is no running or waiting to run event. Must be changed only under an m_EventQueue lock.
|
||||||
|
/// </remarks>
|
||||||
|
private IScriptWorkItem m_CurrentWorkItem;
|
||||||
|
|
||||||
private Queue m_EventQueue = new Queue(32);
|
private Queue m_EventQueue = new Queue(32);
|
||||||
private bool m_RunEvents = false;
|
private bool m_RunEvents = false;
|
||||||
private UUID m_ItemID;
|
private UUID m_ItemID;
|
||||||
|
@ -158,7 +166,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
{
|
{
|
||||||
// Need to place ourselves back in a work item if there are events to process
|
// Need to place ourselves back in a work item if there are events to process
|
||||||
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
||||||
m_CurrentResult = m_Engine.QueueEventHandler(this);
|
m_CurrentWorkItem = m_Engine.QueueEventHandler(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -528,8 +536,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
|
|
||||||
if (m_EventQueue.Count > 0)
|
if (m_EventQueue.Count > 0)
|
||||||
{
|
{
|
||||||
if (m_CurrentResult == null)
|
if (m_CurrentWorkItem == null)
|
||||||
m_CurrentResult = m_Engine.QueueEventHandler(this);
|
m_CurrentWorkItem = m_Engine.QueueEventHandler(this);
|
||||||
// else
|
// else
|
||||||
// m_log.Error("[Script] Tried to start a script that was already queued");
|
// m_log.Error("[Script] Tried to start a script that was already queued");
|
||||||
}
|
}
|
||||||
|
@ -541,49 +549,58 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
// m_log.DebugFormat(
|
// m_log.DebugFormat(
|
||||||
// "[SCRIPT INSTANCE]: Stopping script {0} {1} with timeout {2}", ScriptName, ItemID, timeout);
|
// "[SCRIPT INSTANCE]: Stopping script {0} {1} with timeout {2}", ScriptName, ItemID, timeout);
|
||||||
|
|
||||||
IScriptWorkItem result;
|
IScriptWorkItem workItem;
|
||||||
|
|
||||||
lock (m_EventQueue)
|
lock (m_EventQueue)
|
||||||
{
|
{
|
||||||
if (!Running)
|
if (!Running)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (m_CurrentResult == null)
|
// If we're not running or waiting to run an event then we can safely stop.
|
||||||
|
if (m_CurrentWorkItem == null)
|
||||||
{
|
{
|
||||||
m_RunEvents = false;
|
m_RunEvents = false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_CurrentResult.Cancel())
|
// If we are waiting to run an event then we can try to cancel it.
|
||||||
|
if (m_CurrentWorkItem.Cancel())
|
||||||
{
|
{
|
||||||
m_CurrentResult = null;
|
m_CurrentWorkItem = null;
|
||||||
m_RunEvents = false;
|
m_RunEvents = false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = m_CurrentResult;
|
workItem = m_CurrentWorkItem;
|
||||||
m_RunEvents = false;
|
m_RunEvents = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result.Wait(new TimeSpan((long)timeout * 100000)))
|
// Wait for the current event to complete.
|
||||||
|
if (workItem.Wait(new TimeSpan((long)timeout * 100000)))
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
lock (m_EventQueue)
|
lock (m_EventQueue)
|
||||||
{
|
{
|
||||||
result = m_CurrentResult;
|
workItem = m_CurrentWorkItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result == null)
|
if (workItem == null)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
// If the event still hasn't stopped and we the stop isn't the result of script or object removal, then
|
||||||
|
// forcibly abort the work item (this aborts the underlying thread).
|
||||||
if (!m_InSelfDelete)
|
if (!m_InSelfDelete)
|
||||||
result.Abort();
|
{
|
||||||
|
// m_log.ErrorFormat("[SCRIPT INSTANCE]: Aborting script {0} {1}", ScriptName, ItemID);
|
||||||
|
|
||||||
|
workItem.Abort();
|
||||||
|
}
|
||||||
|
|
||||||
lock (m_EventQueue)
|
lock (m_EventQueue)
|
||||||
{
|
{
|
||||||
m_CurrentResult = null;
|
m_CurrentWorkItem = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -605,6 +622,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
throw new EventAbortException();
|
throw new EventAbortException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Post an event to this script instance.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// The request to run the event is sent
|
||||||
|
/// </remarks>
|
||||||
|
/// <param name="data"></param>
|
||||||
public void PostEvent(EventParams data)
|
public void PostEvent(EventParams data)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[Script] Posted event {2} in state {3} to {0}.{1}",
|
// m_log.DebugFormat("[Script] Posted event {2} in state {3} to {0}.{1}",
|
||||||
|
@ -671,9 +695,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
|
|
||||||
m_EventQueue.Enqueue(data);
|
m_EventQueue.Enqueue(data);
|
||||||
|
|
||||||
if (m_CurrentResult == null)
|
if (m_CurrentWorkItem == null)
|
||||||
{
|
{
|
||||||
m_CurrentResult = m_Engine.QueueEventHandler(this);
|
m_CurrentWorkItem = m_Engine.QueueEventHandler(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -698,11 +722,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
{
|
{
|
||||||
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
||||||
{
|
{
|
||||||
m_CurrentResult = m_Engine.QueueEventHandler(this);
|
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
||||||
|
{
|
||||||
|
m_CurrentWorkItem = m_Engine.QueueEventHandler(this);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_CurrentWorkItem = null;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_CurrentResult = null;
|
m_CurrentWorkItem = null;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -825,15 +857,18 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// If there are more events and we are currently running and not shutting down, then ask the
|
||||||
|
// script engine to run the next event.
|
||||||
lock (m_EventQueue)
|
lock (m_EventQueue)
|
||||||
{
|
{
|
||||||
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown))
|
||||||
{
|
{
|
||||||
m_CurrentResult = m_Engine.QueueEventHandler(this);
|
m_CurrentWorkItem = m_Engine.QueueEventHandler(this);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_CurrentResult = null;
|
m_CurrentWorkItem = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -941,8 +976,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance
|
||||||
|
|
||||||
public void SaveState(string assembly)
|
public void SaveState(string assembly)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
// If we're currently in an event, just tell it to save upon return
|
// If we're currently in an event, just tell it to save upon return
|
||||||
//
|
//
|
||||||
if (m_InEvent)
|
if (m_InEvent)
|
||||||
|
|
|
@ -452,6 +452,8 @@ namespace OpenSim.Region.ScriptEngine.XEngine
|
||||||
|
|
||||||
sb.AppendFormat("Unique scripts : {0}\n", m_uniqueScripts.Count);
|
sb.AppendFormat("Unique scripts : {0}\n", m_uniqueScripts.Count);
|
||||||
sb.AppendFormat("Scripts waiting for load : {0}\n", m_CompileQueue.Count);
|
sb.AppendFormat("Scripts waiting for load : {0}\n", m_CompileQueue.Count);
|
||||||
|
sb.AppendFormat("Max threads : {0}\n", m_ThreadPool.MaxThreads);
|
||||||
|
sb.AppendFormat("Min threads : {0}\n", m_ThreadPool.MinThreads);
|
||||||
sb.AppendFormat("Allocated threads : {0}\n", m_ThreadPool.ActiveThreads);
|
sb.AppendFormat("Allocated threads : {0}\n", m_ThreadPool.ActiveThreads);
|
||||||
sb.AppendFormat("In use threads : {0}\n", m_ThreadPool.InUseThreads);
|
sb.AppendFormat("In use threads : {0}\n", m_ThreadPool.InUseThreads);
|
||||||
sb.AppendFormat("Work items waiting : {0}\n", m_ThreadPool.WaitingCallbacks);
|
sb.AppendFormat("Work items waiting : {0}\n", m_ThreadPool.WaitingCallbacks);
|
||||||
|
|
|
@ -295,23 +295,28 @@ namespace OpenSim.Server.Handlers.Simulation
|
||||||
keysvals.Add("headers", headervals);
|
keysvals.Add("headers", headervals);
|
||||||
keysvals.Add("querystringkeys", querystringkeys);
|
keysvals.Add("querystringkeys", querystringkeys);
|
||||||
|
|
||||||
Stream inputStream;
|
httpResponse.StatusCode = 200;
|
||||||
|
httpResponse.ContentType = "text/html";
|
||||||
|
httpResponse.KeepAlive = false;
|
||||||
|
Encoding encoding = Encoding.UTF8;
|
||||||
|
|
||||||
|
Stream inputStream = null;
|
||||||
if (httpRequest.ContentType == "application/x-gzip")
|
if (httpRequest.ContentType == "application/x-gzip")
|
||||||
inputStream = new GZipStream(request, CompressionMode.Decompress);
|
inputStream = new GZipStream(request, CompressionMode.Decompress);
|
||||||
else
|
else if (httpRequest.ContentType == "application/json")
|
||||||
inputStream = request;
|
inputStream = request;
|
||||||
|
else // no go
|
||||||
|
{
|
||||||
|
httpResponse.StatusCode = 406;
|
||||||
|
return encoding.GetBytes("false");
|
||||||
|
}
|
||||||
|
|
||||||
Encoding encoding = Encoding.UTF8;
|
|
||||||
StreamReader reader = new StreamReader(inputStream, encoding);
|
StreamReader reader = new StreamReader(inputStream, encoding);
|
||||||
|
|
||||||
string requestBody = reader.ReadToEnd();
|
string requestBody = reader.ReadToEnd();
|
||||||
reader.Close();
|
reader.Close();
|
||||||
keysvals.Add("body", requestBody);
|
keysvals.Add("body", requestBody);
|
||||||
|
|
||||||
httpResponse.StatusCode = 200;
|
|
||||||
httpResponse.ContentType = "text/html";
|
|
||||||
httpResponse.KeepAlive = false;
|
|
||||||
|
|
||||||
Hashtable responsedata = new Hashtable();
|
Hashtable responsedata = new Hashtable();
|
||||||
|
|
||||||
UUID agentID;
|
UUID agentID;
|
||||||
|
|
|
@ -477,7 +477,7 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
||||||
// Grab the asset data from the response stream
|
// Grab the asset data from the response stream
|
||||||
using (MemoryStream stream = new MemoryStream())
|
using (MemoryStream stream = new MemoryStream())
|
||||||
{
|
{
|
||||||
responseStream.CopyTo(stream, 4096);
|
responseStream.CopyStream(stream, Int32.MaxValue);
|
||||||
asset.Data = stream.ToArray();
|
asset.Data = stream.ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,6 +172,7 @@
|
||||||
|
|
||||||
;# {permissionmodules} {} {Permission modules to use (may specify multiple modules, separated by comma} {} DefaultPermissionsModule
|
;# {permissionmodules} {} {Permission modules to use (may specify multiple modules, separated by comma} {} DefaultPermissionsModule
|
||||||
;; Permission modules to use, separated by comma.
|
;; Permission modules to use, separated by comma.
|
||||||
|
;; Possible modules are DefaultPermissionsModule, PrimLimitsModule
|
||||||
; permissionmodules = DefaultPermissionsModule
|
; permissionmodules = DefaultPermissionsModule
|
||||||
|
|
||||||
;# {serverside_object_permissions} {permissionmodules:DefaultPermissionsModule} {Activate permission handling by the sim?} {true false} true
|
;# {serverside_object_permissions} {permissionmodules:DefaultPermissionsModule} {Activate permission handling by the sim?} {true false} true
|
||||||
|
@ -790,11 +791,6 @@
|
||||||
; Enabled = false
|
; Enabled = false
|
||||||
|
|
||||||
|
|
||||||
[PrimLimitsModule]
|
|
||||||
;# {EnforcePrimLimits} {} {Enforce parcel prim limits} {true false} false
|
|
||||||
;; Enable parcel prim limits. Off by default to emulate pre-existing behavior.
|
|
||||||
; EnforcePrimLimits = false
|
|
||||||
|
|
||||||
|
|
||||||
[Architecture]
|
[Architecture]
|
||||||
;# {Include-Architecture} {} {Choose one of the following architectures} {config-include/Standalone.ini config-include/StandaloneHypergrid.ini config-include/Grid.ini config-include/GridHypergrid.ini config-include/SimianGrid.ini config-include/HyperSimianGrid.ini} config-include/Standalone.ini
|
;# {Include-Architecture} {} {Choose one of the following architectures} {config-include/Standalone.ini config-include/StandaloneHypergrid.ini config-include/Grid.ini config-include/GridHypergrid.ini config-include/SimianGrid.ini config-include/HyperSimianGrid.ini} config-include/Standalone.ini
|
||||||
|
|
Loading…
Reference in New Issue