diff options
Diffstat (limited to 'OpenSim/Region')
-rw-r--r-- | OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs | 88 |
1 files changed, 48 insertions, 40 deletions
diff --git a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs index 41f0e8c..9bc7a09 100644 --- a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs +++ b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs | |||
@@ -822,7 +822,7 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
822 | return null; | 822 | return null; |
823 | } | 823 | } |
824 | 824 | ||
825 | for (int i = 0 ; i < objlist.Count; i++) | 825 | for (int i = 0; i < objlist.Count; i++) |
826 | { | 826 | { |
827 | group = objlist[i]; | 827 | group = objlist[i]; |
828 | 828 | ||
@@ -832,8 +832,6 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
832 | m_log.Debug("[InventoryAccessModule]: Inventory object has UUID.Zero! Position 3"); | 832 | m_log.Debug("[InventoryAccessModule]: Inventory object has UUID.Zero! Position 3"); |
833 | } | 833 | } |
834 | 834 | ||
835 | group.RootPart.FromFolderID = item.Folder; | ||
836 | |||
837 | // If it's rezzed in world, select it. Much easier to | 835 | // If it's rezzed in world, select it. Much easier to |
838 | // find small items. | 836 | // find small items. |
839 | // | 837 | // |
@@ -890,44 +888,8 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
890 | } | 888 | } |
891 | 889 | ||
892 | group.SetGroup(remoteClient.ActiveGroupId, remoteClient); | 890 | group.SetGroup(remoteClient.ActiveGroupId, remoteClient); |
893 | if ((rootPart.OwnerID != item.Owner) || | ||
894 | (item.CurrentPermissions & 16) != 0) | ||
895 | { | ||
896 | //Need to kill the for sale here | ||
897 | rootPart.ObjectSaleType = 0; | ||
898 | rootPart.SalePrice = 10; | ||
899 | |||
900 | if (m_Scene.Permissions.PropagatePermissions()) | ||
901 | { | ||
902 | foreach (SceneObjectPart part in group.Parts) | ||
903 | { | ||
904 | if ((item.Flags & (uint)InventoryItemFlags.ObjectHasMultipleItems) == 0) | ||
905 | { | ||
906 | part.EveryoneMask = item.EveryOnePermissions; | ||
907 | part.NextOwnerMask = item.NextPermissions; | ||
908 | } | ||
909 | part.GroupMask = 0; // DO NOT propagate here | ||
910 | } | ||
911 | |||
912 | group.ApplyNextOwnerPermissions(); | ||
913 | } | ||
914 | } | ||
915 | 891 | ||
916 | foreach (SceneObjectPart part in group.Parts) | 892 | DoPreRezWhenFromItem(item, group); |
917 | { | ||
918 | if ((part.OwnerID != item.Owner) || | ||
919 | (item.CurrentPermissions & 16) != 0) | ||
920 | { | ||
921 | part.LastOwnerID = part.OwnerID; | ||
922 | part.OwnerID = item.Owner; | ||
923 | part.Inventory.ChangeInventoryOwner(item.Owner); | ||
924 | part.GroupMask = 0; // DO NOT propagate here | ||
925 | } | ||
926 | part.EveryoneMask = item.EveryOnePermissions; | ||
927 | part.NextOwnerMask = item.NextPermissions; | ||
928 | } | ||
929 | |||
930 | rootPart.TrimPermissions(); | ||
931 | 893 | ||
932 | if (!attachment) | 894 | if (!attachment) |
933 | { | 895 | { |
@@ -951,6 +913,52 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
951 | return group; | 913 | return group; |
952 | } | 914 | } |
953 | 915 | ||
916 | private void DoPreRezWhenFromItem(InventoryItemBase item, SceneObjectGroup so) | ||
917 | { | ||
918 | so.RootPart.FromFolderID = item.Folder; | ||
919 | |||
920 | SceneObjectPart rootPart = so.RootPart; | ||
921 | |||
922 | if ((rootPart.OwnerID != item.Owner) || | ||
923 | (item.CurrentPermissions & 16) != 0) | ||
924 | { | ||
925 | //Need to kill the for sale here | ||
926 | rootPart.ObjectSaleType = 0; | ||
927 | rootPart.SalePrice = 10; | ||
928 | |||
929 | if (m_Scene.Permissions.PropagatePermissions()) | ||
930 | { | ||
931 | foreach (SceneObjectPart part in so.Parts) | ||
932 | { | ||
933 | if ((item.Flags & (uint)InventoryItemFlags.ObjectHasMultipleItems) == 0) | ||
934 | { | ||
935 | part.EveryoneMask = item.EveryOnePermissions; | ||
936 | part.NextOwnerMask = item.NextPermissions; | ||
937 | } | ||
938 | part.GroupMask = 0; // DO NOT propagate here | ||
939 | } | ||
940 | |||
941 | so.ApplyNextOwnerPermissions(); | ||
942 | } | ||
943 | } | ||
944 | |||
945 | foreach (SceneObjectPart part in so.Parts) | ||
946 | { | ||
947 | if ((part.OwnerID != item.Owner) || | ||
948 | (item.CurrentPermissions & 16) != 0) | ||
949 | { | ||
950 | part.LastOwnerID = part.OwnerID; | ||
951 | part.OwnerID = item.Owner; | ||
952 | part.Inventory.ChangeInventoryOwner(item.Owner); | ||
953 | part.GroupMask = 0; // DO NOT propagate here | ||
954 | } | ||
955 | part.EveryoneMask = item.EveryOnePermissions; | ||
956 | part.NextOwnerMask = item.NextPermissions; | ||
957 | } | ||
958 | |||
959 | rootPart.TrimPermissions(); | ||
960 | } | ||
961 | |||
954 | private void DoPostRezWhenFromItem(InventoryItemBase item, bool isAttachment) | 962 | private void DoPostRezWhenFromItem(InventoryItemBase item, bool isAttachment) |
955 | { | 963 | { |
956 | if (!m_Scene.Permissions.BypassPermissions()) | 964 | if (!m_Scene.Permissions.BypassPermissions()) |