aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/CoreModules/Avatar/Gods/GodsModule.cs39
1 files changed, 35 insertions, 4 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/Gods/GodsModule.cs b/OpenSim/Region/CoreModules/Avatar/Gods/GodsModule.cs
index 9fd3318..a83b3df 100644
--- a/OpenSim/Region/CoreModules/Avatar/Gods/GodsModule.cs
+++ b/OpenSim/Region/CoreModules/Avatar/Gods/GodsModule.cs
@@ -74,6 +74,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Gods
74 m_scene.EventManager.OnNewClient += SubscribeToClientEvents; 74 m_scene.EventManager.OnNewClient += SubscribeToClientEvents;
75 m_scene.EventManager.OnRegisterCaps += OnRegisterCaps; 75 m_scene.EventManager.OnRegisterCaps += OnRegisterCaps;
76 m_scene.EventManager.OnClientClosed += OnClientClosed; 76 m_scene.EventManager.OnClientClosed += OnClientClosed;
77 scene.EventManager.OnIncomingInstantMessage +=
78 OnIncomingInstantMessage;
77 } 79 }
78 80
79 public void PostInitialise() {} 81 public void PostInitialise() {}
@@ -128,6 +130,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Gods
128 uint kickFlags = userData["KickFlags"].AsUInteger(); 130 uint kickFlags = userData["KickFlags"].AsUInteger();
129 string reason = userData["Reason"].AsString(); 131 string reason = userData["Reason"].AsString();
130 132
133 ScenePresence god = m_scene.GetScenePresence(godID);
134 if (god == null || god.ControllingClient.SessionId != godSessionID)
135 return String.Empty;
136
131 KickUser(godID, godSessionID, agentID, kickFlags, Util.StringToBytes1024(reason)); 137 KickUser(godID, godSessionID, agentID, kickFlags, Util.StringToBytes1024(reason));
132 } 138 }
133 else 139 else
@@ -188,12 +194,24 @@ namespace OpenSim.Region.CoreModules.Avatar.Gods
188 if (!m_scene.Permissions.IsGod(godID)) 194 if (!m_scene.Permissions.IsGod(godID))
189 return; 195 return;
190 196
191 ScenePresence god = m_scene.GetScenePresence(godID);
192 if (god == null || god.ControllingClient.SessionId != sessionID)
193 return;
194
195 ScenePresence sp = m_scene.GetScenePresence(agentID); 197 ScenePresence sp = m_scene.GetScenePresence(agentID);
196 198
199 if (sp == null && agentID != ALL_AGENTS)
200 {
201 IMessageTransferModule transferModule =
202 m_scene.RequestModuleInterface<IMessageTransferModule>();
203 if (transferModule != null)
204 {
205 m_log.DebugFormat("[GODS]: Sending nonlocal kill for agent {0}", agentID);
206 transferModule.SendInstantMessage(new GridInstantMessage(
207 m_scene, godID, "God", agentID, (byte)250, false,
208 Utils.BytesToString(reason), UUID.Zero, true,
209 new Vector3(), new byte[] {(byte)kickflags}),
210 delegate(bool success) {} );
211 }
212 return;
213 }
214
197 switch (kickflags) 215 switch (kickflags)
198 { 216 {
199 case 0: 217 case 0:
@@ -240,5 +258,18 @@ namespace OpenSim.Region.CoreModules.Avatar.Gods
240 sp.ControllingClient.Kick(reason); 258 sp.ControllingClient.Kick(reason);
241 sp.Scene.IncomingCloseAgent(sp.UUID); 259 sp.Scene.IncomingCloseAgent(sp.UUID);
242 } 260 }
261
262 private void OnIncomingInstantMessage(GridInstantMessage msg)
263 {
264 if (msg.dialog == (uint)250) // Nonlocal kick
265 {
266 UUID agentID = new UUID(msg.toAgentID);
267 string reason = msg.message;
268 UUID godID = new UUID(msg.fromAgentID);
269 uint kickMode = (uint)msg.binaryBucket[0];
270
271 KickUser(godID, UUID.Zero, agentID, kickMode, Util.StringToBytes1024(reason));
272 }
273 }
243 } 274 }
244} 275}