diff options
Diffstat (limited to 'OpenSim/Region/CoreModules/Framework')
3 files changed, 41 insertions, 25 deletions
diff --git a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs index faccab2..25d5e0e 100644 --- a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs +++ b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs | |||
@@ -59,7 +59,6 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
59 | get { return m_MaxTransferDistance; } | 59 | get { return m_MaxTransferDistance; } |
60 | set { m_MaxTransferDistance = value; } | 60 | set { m_MaxTransferDistance = value; } |
61 | } | 61 | } |
62 | |||
63 | 62 | ||
64 | protected bool m_Enabled = false; | 63 | protected bool m_Enabled = false; |
65 | protected Scene m_aScene; | 64 | protected Scene m_aScene; |
@@ -68,7 +67,6 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
68 | private ExpiringCache<UUID, ExpiringCache<ulong, DateTime>> m_bannedRegions = | 67 | private ExpiringCache<UUID, ExpiringCache<ulong, DateTime>> m_bannedRegions = |
69 | new ExpiringCache<UUID, ExpiringCache<ulong, DateTime>>(); | 68 | new ExpiringCache<UUID, ExpiringCache<ulong, DateTime>>(); |
70 | 69 | ||
71 | |||
72 | #region ISharedRegionModule | 70 | #region ISharedRegionModule |
73 | 71 | ||
74 | public Type ReplaceableInterface | 72 | public Type ReplaceableInterface |
@@ -210,7 +208,10 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
210 | sp.Teleport(position); | 208 | sp.Teleport(position); |
211 | 209 | ||
212 | foreach (SceneObjectGroup grp in sp.GetAttachments()) | 210 | foreach (SceneObjectGroup grp in sp.GetAttachments()) |
213 | sp.Scene.EventManager.TriggerOnScriptChangedEvent(grp.LocalId, (uint)Changed.TELEPORT); | 211 | { |
212 | if (grp.IsDeleted) | ||
213 | sp.Scene.EventManager.TriggerOnScriptChangedEvent(grp.LocalId, (uint)Changed.TELEPORT); | ||
214 | } | ||
214 | } | 215 | } |
215 | else // Another region possibly in another simulator | 216 | else // Another region possibly in another simulator |
216 | { | 217 | { |
@@ -328,10 +329,15 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
328 | sp.StandUp(); | 329 | sp.StandUp(); |
329 | 330 | ||
330 | if (!sp.ValidateAttachments()) | 331 | if (!sp.ValidateAttachments()) |
331 | { | 332 | m_log.DebugFormat( |
332 | sp.ControllingClient.SendTeleportFailed("Inconsistent attachment state"); | 333 | "[ENTITY TRANSFER MODULE]: Failed validation of all attachments for teleport of {0} from {1} to {2}. Continuing.", |
333 | return; | 334 | sp.Name, sp.Scene.RegionInfo.RegionName, finalDestination.RegionName); |
334 | } | 335 | |
336 | // if (!sp.ValidateAttachments()) | ||
337 | // { | ||
338 | // sp.ControllingClient.SendTeleportFailed("Inconsistent attachment state"); | ||
339 | // return; | ||
340 | // } | ||
335 | 341 | ||
336 | string reason; | 342 | string reason; |
337 | string version; | 343 | string version; |
@@ -955,7 +961,9 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
955 | /// This Closes child agents on neighbouring regions | 961 | /// This Closes child agents on neighbouring regions |
956 | /// Calls an asynchronous method to do so.. so it doesn't lag the sim. | 962 | /// Calls an asynchronous method to do so.. so it doesn't lag the sim. |
957 | /// </summary> | 963 | /// </summary> |
958 | protected ScenePresence CrossAgentToNewRegionAsync(ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion, bool isFlying, string version) | 964 | protected ScenePresence CrossAgentToNewRegionAsync( |
965 | ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion, | ||
966 | bool isFlying, string version) | ||
959 | { | 967 | { |
960 | ulong neighbourHandle = Utils.UIntsToLong((uint)(neighbourx * Constants.RegionSize), (uint)(neighboury * Constants.RegionSize)); | 968 | ulong neighbourHandle = Utils.UIntsToLong((uint)(neighbourx * Constants.RegionSize), (uint)(neighboury * Constants.RegionSize)); |
961 | 969 | ||
@@ -963,8 +971,13 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
963 | 971 | ||
964 | Scene m_scene = agent.Scene; | 972 | Scene m_scene = agent.Scene; |
965 | 973 | ||
966 | if (neighbourRegion != null && agent.ValidateAttachments()) | 974 | if (neighbourRegion != null) |
967 | { | 975 | { |
976 | if (!agent.ValidateAttachments()) | ||
977 | m_log.DebugFormat( | ||
978 | "[ENTITY TRANSFER MODULE]: Failed validation of all attachments for region crossing of {0} from {1} to {2}. Continuing.", | ||
979 | agent.Name, agent.Scene.RegionInfo.RegionName, neighbourRegion.RegionName); | ||
980 | |||
968 | pos = pos + (agent.Velocity); | 981 | pos = pos + (agent.Velocity); |
969 | 982 | ||
970 | SetInTransit(agent.UUID); | 983 | SetInTransit(agent.UUID); |
@@ -1789,16 +1802,16 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
1789 | List<SceneObjectGroup> m_attachments = sp.GetAttachments(); | 1802 | List<SceneObjectGroup> m_attachments = sp.GetAttachments(); |
1790 | 1803 | ||
1791 | // Validate | 1804 | // Validate |
1792 | foreach (SceneObjectGroup gobj in m_attachments) | 1805 | // foreach (SceneObjectGroup gobj in m_attachments) |
1793 | { | 1806 | // { |
1794 | if (gobj == null || gobj.IsDeleted) | 1807 | // if (gobj == null || gobj.IsDeleted) |
1795 | return false; | 1808 | // return false; |
1796 | } | 1809 | // } |
1797 | 1810 | ||
1798 | foreach (SceneObjectGroup gobj in m_attachments) | 1811 | foreach (SceneObjectGroup gobj in m_attachments) |
1799 | { | 1812 | { |
1800 | // If the prim group is null then something must have happened to it! | 1813 | // If the prim group is null then something must have happened to it! |
1801 | if (gobj != null) | 1814 | if (gobj != null && !gobj.IsDeleted) |
1802 | { | 1815 | { |
1803 | // Set the parent localID to 0 so it transfers over properly. | 1816 | // Set the parent localID to 0 so it transfers over properly. |
1804 | gobj.RootPart.SetParentLocalId(0); | 1817 | gobj.RootPart.SetParentLocalId(0); |
diff --git a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs index a4bb40e..f05b090 100644 --- a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs +++ b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs | |||
@@ -726,8 +726,7 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
726 | SceneObjectGroup group = null; | 726 | SceneObjectGroup group = null; |
727 | 727 | ||
728 | string xmlData = Utils.BytesToString(rezAsset.Data); | 728 | string xmlData = Utils.BytesToString(rezAsset.Data); |
729 | List<SceneObjectGroup> objlist = | 729 | List<SceneObjectGroup> objlist = new List<SceneObjectGroup>(); |
730 | new List<SceneObjectGroup>(); | ||
731 | List<Vector3> veclist = new List<Vector3>(); | 730 | List<Vector3> veclist = new List<Vector3>(); |
732 | byte bRayEndIsIntersection = (byte)(RayEndIsIntersection ? 1 : 0); | 731 | byte bRayEndIsIntersection = (byte)(RayEndIsIntersection ? 1 : 0); |
733 | Vector3 pos; | 732 | Vector3 pos; |
@@ -799,6 +798,13 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
799 | m_log.Debug("[InventoryAccessModule]: Object has UUID.Zero! Position 3"); | 798 | m_log.Debug("[InventoryAccessModule]: Object has UUID.Zero! Position 3"); |
800 | } | 799 | } |
801 | 800 | ||
801 | foreach (SceneObjectPart part in group.Parts) | ||
802 | { | ||
803 | // Make the rezzer the owner, as this is not necessarily set correctly in the serialized asset. | ||
804 | part.LastOwnerID = part.OwnerID; | ||
805 | part.OwnerID = remoteClient.AgentId; | ||
806 | } | ||
807 | |||
802 | if (!attachment) | 808 | if (!attachment) |
803 | { | 809 | { |
804 | // If it's rezzed in world, select it. Much easier to | 810 | // If it's rezzed in world, select it. Much easier to |
@@ -839,7 +845,7 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
839 | 845 | ||
840 | if (!attachment) | 846 | if (!attachment) |
841 | { | 847 | { |
842 | if (group.RootPart.Shape.PCode == (byte)PCode.Prim) | 848 | if (rootPart.Shape.PCode == (byte)PCode.Prim) |
843 | group.ClearPartAttachmentData(); | 849 | group.ClearPartAttachmentData(); |
844 | 850 | ||
845 | // Fire on_rez | 851 | // Fire on_rez |
@@ -1017,11 +1023,10 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
1017 | if ((part.OwnerID != item.Owner) || | 1023 | if ((part.OwnerID != item.Owner) || |
1018 | (item.CurrentPermissions & 16) != 0) | 1024 | (item.CurrentPermissions & 16) != 0) |
1019 | { | 1025 | { |
1020 | part.LastOwnerID = part.OwnerID; | ||
1021 | part.OwnerID = item.Owner; | ||
1022 | part.Inventory.ChangeInventoryOwner(item.Owner); | 1026 | part.Inventory.ChangeInventoryOwner(item.Owner); |
1023 | part.GroupMask = 0; // DO NOT propagate here | 1027 | part.GroupMask = 0; // DO NOT propagate here |
1024 | } | 1028 | } |
1029 | |||
1025 | part.EveryoneMask = item.EveryOnePermissions; | 1030 | part.EveryoneMask = item.EveryOnePermissions; |
1026 | part.NextOwnerMask = item.NextPermissions; | 1031 | part.NextOwnerMask = item.NextPermissions; |
1027 | } | 1032 | } |
diff --git a/OpenSim/Region/CoreModules/Framework/UserManagement/UserManagementModule.cs b/OpenSim/Region/CoreModules/Framework/UserManagement/UserManagementModule.cs index b0b35e4..bef0d69 100644 --- a/OpenSim/Region/CoreModules/Framework/UserManagement/UserManagementModule.cs +++ b/OpenSim/Region/CoreModules/Framework/UserManagement/UserManagementModule.cs | |||
@@ -87,8 +87,6 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement | |||
87 | "Show the bindings between user UUIDs and user names", | 87 | "Show the bindings between user UUIDs and user names", |
88 | String.Empty, | 88 | String.Empty, |
89 | HandleShowUsers); | 89 | HandleShowUsers); |
90 | |||
91 | |||
92 | } | 90 | } |
93 | 91 | ||
94 | public bool IsSharedModule | 92 | public bool IsSharedModule |
@@ -365,9 +363,9 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement | |||
365 | lock (m_UserCache) | 363 | lock (m_UserCache) |
366 | m_UserCache[user.Id] = user; | 364 | m_UserCache[user.Id] = user; |
367 | 365 | ||
368 | m_log.DebugFormat( | 366 | // m_log.DebugFormat( |
369 | "[USER MANAGEMENT MODULE]: Added user {0} {1} {2} {3}", | 367 | // "[USER MANAGEMENT MODULE]: Added user {0} {1} {2} {3}", |
370 | user.Id, user.FirstName, user.LastName, user.HomeURL); | 368 | // user.Id, user.FirstName, user.LastName, user.HomeURL); |
371 | } | 369 | } |
372 | 370 | ||
373 | //public void AddUser(UUID uuid, string userData) | 371 | //public void AddUser(UUID uuid, string userData) |