/*
* 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.
*
*/
/* Original code: Tedd Hansen */
using System;
using libsecondlife;
using OpenSim.Framework;
using OpenSim.Grid.ScriptServer;
using OpenSim.Region.ScriptEngine.DotNetEngine;
namespace OpenSim.Region.ScriptEngine.RemoteServer
{
///
/// Handles events from OpenSim. Uses RemoteServer to send commands.
///
[Serializable]
internal class EventManager
{
System.Collections.Generic.Dictionary remoteScript = new System.Collections.Generic.Dictionary();
private ScriptEngine myScriptEngine;
public EventManager(ScriptEngine _ScriptEngine)
{
myScriptEngine = _ScriptEngine;
myScriptEngine.Log.Verbose("RemoteEngine", "Hooking up to server events");
//myScriptEngine.World.EventManager.OnObjectGrab += touch_start;
myScriptEngine.World.EventManager.OnRezScript += OnRezScript;
//myScriptEngine.World.EventManager.OnRemoveScript += OnRemoveScript;
}
public void OnRezScript(uint localID, LLUUID itemID, string script)
{
// WE ARE CREATING A NEW SCRIPT ... CREATE SCRIPT, GET A REMOTEID THAT WE MAP FROM LOCALID
OpenSim.Grid.ScriptServer.RemotingObject obj = myScriptEngine.m_RemoteServer.Connect("localhost", 1234);
remoteScript.Add(localID, obj);
try
{
remoteScript[localID].ScriptEngine.m_EventManager.OnRezScript(localID, itemID, script);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void touch_start(uint localID, LLVector3 offsetPos, IClientAPI remoteClient)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.touch_start(localID, offsetPos, remoteClient);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void OnRemoveScript(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.OnRemoveScript(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void state_exit(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.state_exit(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void touch(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.touch(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void touch_end(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.touch_end(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void collision_start(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.collision_start(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void collision(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.collision(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void collision_end(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.collision_end(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void land_collision_start(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.land_collision_start(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void land_collision(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.land_collision(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void land_collision_end(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.land_collision_end(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void timer(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.timer(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void listen(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.listen(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void on_rez(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.on_rez(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void sensor(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.sensor(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void no_sensor(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.no_sensor(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void control(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.control(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void money(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.money(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void email(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.email(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void at_target(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.at_target(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void not_at_target(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.not_at_target(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void at_rot_target(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.at_rot_target(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void not_at_rot_target(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.not_at_rot_target(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void run_time_permissions(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.run_time_permissions(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void changed(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.changed(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void attach(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.attach(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void dataserver(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.dataserver(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void link_message(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.link_message(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void moving_start(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.moving_start(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void moving_end(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.moving_end(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void object_rez(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.object_rez(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void remote_data(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.remote_data(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
public void http_response(uint localID, LLUUID itemID)
{
try
{
remoteScript[localID].ScriptEngine.m_EventManager.http_response(localID, itemID);
}
catch (System.NullReferenceException)
{
OpenSim.Framework.Console.MainLog.Instance.Error("SCRIPTS", "Error Connecting to Remote Script Server. Is it running?");
}
}
}
}