diff options
Merge branch 'master' into careminster-presence-refactor
Diffstat (limited to 'OpenSim/Region/Framework/Scenes')
4 files changed, 35 insertions, 14 deletions
diff --git a/OpenSim/Region/Framework/Scenes/EventManager.cs b/OpenSim/Region/Framework/Scenes/EventManager.cs index 33069da..f24c53c 100644 --- a/OpenSim/Region/Framework/Scenes/EventManager.cs +++ b/OpenSim/Region/Framework/Scenes/EventManager.cs | |||
@@ -300,7 +300,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
300 | /// ChatToClientsEvent is triggered via ChatModule (or | 300 | /// ChatToClientsEvent is triggered via ChatModule (or |
301 | /// substitutes thereof) when a chat message is actually sent to clients. Clients will only be sent a | 301 | /// substitutes thereof) when a chat message is actually sent to clients. Clients will only be sent a |
302 | /// received chat message if they satisfy various conditions (within audible range, etc.) | 302 | /// received chat message if they satisfy various conditions (within audible range, etc.) |
303 | /// </summary> | 303 | /// </summary> |
304 | public delegate void ChatToClientsEvent( | 304 | public delegate void ChatToClientsEvent( |
305 | UUID senderID, HashSet<UUID> receiverIDs, | 305 | UUID senderID, HashSet<UUID> receiverIDs, |
306 | string message, ChatTypeEnum type, Vector3 fromPos, string fromName, | 306 | string message, ChatTypeEnum type, Vector3 fromPos, string fromName, |
@@ -1660,8 +1660,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
1660 | e.Message, e.StackTrace); | 1660 | e.Message, e.StackTrace); |
1661 | } | 1661 | } |
1662 | } | 1662 | } |
1663 | } | 1663 | } |
1664 | } | 1664 | } |
1665 | 1665 | ||
1666 | public void TriggerOnChatBroadcast(Object sender, OSChatMessage chat) | 1666 | public void TriggerOnChatBroadcast(Object sender, OSChatMessage chat) |
1667 | { | 1667 | { |
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs index 5428e5d..c3edeb3 100644 --- a/OpenSim/Region/Framework/Scenes/Scene.cs +++ b/OpenSim/Region/Framework/Scenes/Scene.cs | |||
@@ -3394,7 +3394,6 @@ namespace OpenSim.Region.Framework.Scenes | |||
3394 | m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName); | 3394 | m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName); |
3395 | } | 3395 | } |
3396 | 3396 | ||
3397 | |||
3398 | /// <summary> | 3397 | /// <summary> |
3399 | /// Do the work necessary to initiate a new user connection for a particular scene. | 3398 | /// Do the work necessary to initiate a new user connection for a particular scene. |
3400 | /// At the moment, this consists of setting up the caps infrastructure | 3399 | /// At the moment, this consists of setting up the caps infrastructure |
@@ -3407,6 +3406,23 @@ namespace OpenSim.Region.Framework.Scenes | |||
3407 | /// also return a reason.</returns> | 3406 | /// also return a reason.</returns> |
3408 | public bool NewUserConnection(AgentCircuitData agent, uint teleportFlags, out string reason) | 3407 | public bool NewUserConnection(AgentCircuitData agent, uint teleportFlags, out string reason) |
3409 | { | 3408 | { |
3409 | return NewUserConnection(agent, teleportFlags, out reason, true); | ||
3410 | } | ||
3411 | |||
3412 | /// <summary> | ||
3413 | /// Do the work necessary to initiate a new user connection for a particular scene. | ||
3414 | /// At the moment, this consists of setting up the caps infrastructure | ||
3415 | /// The return bool should allow for connections to be refused, but as not all calling paths | ||
3416 | /// take proper notice of it let, we allowed banned users in still. | ||
3417 | /// </summary> | ||
3418 | /// <param name="agent">CircuitData of the agent who is connecting</param> | ||
3419 | /// <param name="reason">Outputs the reason for the false response on this string</param> | ||
3420 | /// <param name="requirePresenceLookup">True for normal presence. False for NPC | ||
3421 | /// or other applications where a full grid/Hypergrid presence may not be required.</param> | ||
3422 | /// <returns>True if the region accepts this agent. False if it does not. False will | ||
3423 | /// also return a reason.</returns> | ||
3424 | public bool NewUserConnection(AgentCircuitData agent, uint teleportFlags, out string reason, bool requirePresenceLookup) | ||
3425 | { | ||
3410 | bool vialogin = ((teleportFlags & (uint)Constants.TeleportFlags.ViaLogin) != 0 || | 3426 | bool vialogin = ((teleportFlags & (uint)Constants.TeleportFlags.ViaLogin) != 0 || |
3411 | (teleportFlags & (uint)Constants.TeleportFlags.ViaHGLogin) != 0); | 3427 | (teleportFlags & (uint)Constants.TeleportFlags.ViaHGLogin) != 0); |
3412 | reason = String.Empty; | 3428 | reason = String.Empty; |
@@ -3456,16 +3472,18 @@ namespace OpenSim.Region.Framework.Scenes | |||
3456 | 3472 | ||
3457 | if (sp == null) // We don't have an [child] agent here already | 3473 | if (sp == null) // We don't have an [child] agent here already |
3458 | { | 3474 | { |
3459 | 3475 | if (requirePresenceLookup) | |
3460 | try | ||
3461 | { | 3476 | { |
3462 | if (!VerifyUserPresence(agent, out reason)) | 3477 | try |
3478 | { | ||
3479 | if (!VerifyUserPresence(agent, out reason)) | ||
3480 | return false; | ||
3481 | } | ||
3482 | catch (Exception e) | ||
3483 | { | ||
3484 | m_log.ErrorFormat("[CONNECTION BEGIN]: Exception verifying presence " + e.ToString()); | ||
3463 | return false; | 3485 | return false; |
3464 | } | 3486 | } |
3465 | catch (Exception e) | ||
3466 | { | ||
3467 | m_log.ErrorFormat("[CONNECTION BEGIN]: Exception verifying presence " + e.ToString()); | ||
3468 | return false; | ||
3469 | } | 3487 | } |
3470 | 3488 | ||
3471 | try | 3489 | try |
diff --git a/OpenSim/Region/Framework/Scenes/SceneGraph.cs b/OpenSim/Region/Framework/Scenes/SceneGraph.cs index d4e3717..b016065 100644 --- a/OpenSim/Region/Framework/Scenes/SceneGraph.cs +++ b/OpenSim/Region/Framework/Scenes/SceneGraph.cs | |||
@@ -428,11 +428,14 @@ namespace OpenSim.Region.Framework.Scenes | |||
428 | public bool DeleteSceneObject(UUID uuid, bool resultOfObjectLinked) | 428 | public bool DeleteSceneObject(UUID uuid, bool resultOfObjectLinked) |
429 | { | 429 | { |
430 | EntityBase entity; | 430 | EntityBase entity; |
431 | if (!Entities.TryGetValue(uuid, out entity) && entity is SceneObjectGroup) | 431 | if (!Entities.TryGetValue(uuid, out entity) || (!(entity is SceneObjectGroup))) |
432 | return false; | 432 | return false; |
433 | 433 | ||
434 | SceneObjectGroup grp = (SceneObjectGroup)entity; | 434 | SceneObjectGroup grp = (SceneObjectGroup)entity; |
435 | 435 | ||
436 | if (entity == null) | ||
437 | return false; | ||
438 | |||
436 | if (!resultOfObjectLinked) | 439 | if (!resultOfObjectLinked) |
437 | { | 440 | { |
438 | m_numPrim -= grp.PrimCount; | 441 | m_numPrim -= grp.PrimCount; |
diff --git a/OpenSim/Region/Framework/Scenes/Serialization/SceneObjectSerializer.cs b/OpenSim/Region/Framework/Scenes/Serialization/SceneObjectSerializer.cs index ad994c9..4aadfdb 100644 --- a/OpenSim/Region/Framework/Scenes/Serialization/SceneObjectSerializer.cs +++ b/OpenSim/Region/Framework/Scenes/Serialization/SceneObjectSerializer.cs | |||
@@ -804,7 +804,7 @@ namespace OpenSim.Region.Framework.Scenes.Serialization | |||
804 | private static void ProcessShpTextureEntry(PrimitiveBaseShape shp, XmlTextReader reader) | 804 | private static void ProcessShpTextureEntry(PrimitiveBaseShape shp, XmlTextReader reader) |
805 | { | 805 | { |
806 | byte[] teData = Convert.FromBase64String(reader.ReadElementString("TextureEntry")); | 806 | byte[] teData = Convert.FromBase64String(reader.ReadElementString("TextureEntry")); |
807 | shp.Textures = new Primitive.TextureEntry(teData, 0, teData.Length); | 807 | shp.Textures = new Primitive.TextureEntry(teData, 0, teData.Length); |
808 | } | 808 | } |
809 | 809 | ||
810 | private static void ProcessShpExtraParams(PrimitiveBaseShape shp, XmlTextReader reader) | 810 | private static void ProcessShpExtraParams(PrimitiveBaseShape shp, XmlTextReader reader) |