From 9b96fc9029b7934743a81b98bfbdfba01e68f2f5 Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Wed, 7 Jan 2009 20:09:37 +0000 Subject: [PATCH] * refactor: Establish DialogModule, move some alert code from Scene to here --- .../Environment/Interfaces/IDialogModule.cs | 59 +++++++++++++ .../Modules/Avatar/Dialog/DialogModule.cs | 83 +++++++++++++++++++ OpenSim/Region/Environment/Scenes/Scene.cs | 57 +++---------- 3 files changed, 153 insertions(+), 46 deletions(-) create mode 100644 OpenSim/Region/Environment/Interfaces/IDialogModule.cs create mode 100644 OpenSim/Region/Environment/Modules/Avatar/Dialog/DialogModule.cs diff --git a/OpenSim/Region/Environment/Interfaces/IDialogModule.cs b/OpenSim/Region/Environment/Interfaces/IDialogModule.cs new file mode 100644 index 0000000000..15f0471a09 --- /dev/null +++ b/OpenSim/Region/Environment/Interfaces/IDialogModule.cs @@ -0,0 +1,59 @@ +/* + * 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 OpenMetaverse; + +namespace OpenSim.Region.Environment.Interfaces +{ + public interface IDialogModule + { + /// + /// Send a non-modal alert message to a particular user. + /// + /// + /// + void SendAlertToUser(UUID agentID, string message); + + /// + /// Send an alert message to a particular user. + /// + /// + /// + /// + void SendAlertToUser(UUID agentID, string message, bool modal); + + /// + /// Send an alert message to a particular user. + /// + /// + /// + /// + /// + void SendAlertToUser(string firstName, string lastName, string message, bool modal); + } +} diff --git a/OpenSim/Region/Environment/Modules/Avatar/Dialog/DialogModule.cs b/OpenSim/Region/Environment/Modules/Avatar/Dialog/DialogModule.cs new file mode 100644 index 0000000000..e036c73892 --- /dev/null +++ b/OpenSim/Region/Environment/Modules/Avatar/Dialog/DialogModule.cs @@ -0,0 +1,83 @@ +/* + * 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.Collections.Generic; +using System.Reflection; +using log4net; +using Nini.Config; +using OpenMetaverse; +using OpenSim.Framework; +using OpenSim.Region.Environment.Interfaces; +using OpenSim.Region.Environment.Scenes; + +namespace OpenSim.Region.Environment.Modules.Avatar.Dialog +{ + public class DialogModule : IRegionModule, IDialogModule + { + //private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); + + protected Scene m_scene; + + public void Initialise(Scene scene, IConfigSource source) + { + m_scene = scene; + m_scene.RegisterModuleInterface(this); + } + + public void PostInitialise() {} + public void Close() {} + public string Name { get { return "Dialog Module"; } } + public bool IsSharedModule { get { return false; } } + + public void SendAlertToUser(UUID agentID, string message) + { + SendAlertToUser(agentID, message, false); + } + + public void SendAlertToUser(UUID agentID, string message, bool modal) + { + ScenePresence sp = m_scene.GetScenePresence(agentID); + + if (sp != null) + sp.ControllingClient.SendAgentAlertMessage(message, modal); + } + + public void SendAlertToUser(string firstName, string lastName, string message, bool modal) + { + List presenceList = m_scene.GetScenePresences(); + + foreach (ScenePresence presence in presenceList) + { + if (presence.Firstname == firstName && presence.Lastname == lastName) + { + presence.ControllingClient.SendAgentAlertMessage(message, modal); + break; + } + } + } + } +} diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index 9a07f6be3b..c3f2417a61 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs @@ -414,7 +414,10 @@ namespace OpenSim.Region.Environment.Scenes protected virtual void RegisterDefaultSceneEvents() { - m_eventManager.OnPermissionError += SendPermissionAlert; + IDialogModule dm = RequestModuleInterface(); + + if (dm != null) + m_eventManager.OnPermissionError += dm.SendAlertToUser; } public override string GetSimulatorVersion() @@ -3429,11 +3432,6 @@ namespace OpenSim.Region.Environment.Scenes #region Alert Methods - private void SendPermissionAlert(UUID user, string reason) - { - SendAlertToUser(user, reason, false); - } - /// /// Send an alert messages to all avatars in this scene. /// @@ -3449,23 +3447,6 @@ namespace OpenSim.Region.Environment.Scenes } } - /// - /// Send an alert message to a particular agent. - /// - /// - /// - /// - public void SendAlertToUser(UUID agentID, string message, bool modal) - { - lock (m_scenePresences) - { - if (m_scenePresences.ContainsKey(agentID)) - { - m_scenePresences[agentID].ControllingClient.SendAgentAlertMessage(message, modal); - } - } - } - /// /// Handle a request for admin rights /// @@ -3625,27 +3606,6 @@ namespace OpenSim.Region.Environment.Scenes } } - /// - /// - /// - /// - /// - /// - /// - public void SendAlertToUser(string firstName, string lastName, string message, bool modal) - { - List presenceList = GetScenePresences(); - - foreach (ScenePresence presence in presenceList) - { - if (presence.Firstname == firstName && presence.Lastname == lastName) - { - presence.ControllingClient.SendAgentAlertMessage(message, modal); - break; - } - } - } - /// /// Handle an alert command from the console. /// FIXME: Command parsing code really shouldn't be in this core Scene class. @@ -3660,8 +3620,13 @@ namespace OpenSim.Region.Environment.Scenes } else { - string message = CombineParams(commandParams, 2); - SendAlertToUser(commandParams[0], commandParams[1], message, false); + IDialogModule dm = RequestModuleInterface(); + + if (dm != null) + { + string message = CombineParams(commandParams, 2); + dm.SendAlertToUser(commandParams[0], commandParams[1], message, false); + } } }