aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/World
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules/World')
-rw-r--r--OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs82
1 files changed, 36 insertions, 46 deletions
diff --git a/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs b/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
index e16022d..b0fdd11 100644
--- a/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
+++ b/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
@@ -739,10 +739,10 @@ namespace OpenSim.Region.CoreModules.World.Permissions
739 } 739 }
740 740
741 UUID taskGroupID = task.GroupID; 741 UUID taskGroupID = task.GroupID;
742 bool groupdOwned = taskOwnerID == taskGroupID; 742 bool notGroupdOwned = taskOwnerID != taskGroupID;
743 743
744 // if friends with rights then owner 744 // if friends with rights then owner
745 if (!groupdOwned && IsFriendWithPerms(spID, taskOwnerID)) 745 if (notGroupdOwned && IsFriendWithPerms(spID, taskOwnerID))
746 { 746 {
747 returnMask = ApplyObjectModifyMasks(grp.EffectiveOwnerPerms, objflags, unlocked); 747 returnMask = ApplyObjectModifyMasks(grp.EffectiveOwnerPerms, objflags, unlocked);
748 returnMask |= EXTRAOWNERMASK; 748 returnMask |= EXTRAOWNERMASK;
@@ -756,47 +756,37 @@ namespace OpenSim.Region.CoreModules.World.Permissions
756 ulong powers = 0; 756 ulong powers = 0;
757 if(taskGroupID != UUID.Zero && GroupMemberPowers(taskGroupID, sp, ref powers)) 757 if(taskGroupID != UUID.Zero && GroupMemberPowers(taskGroupID, sp, ref powers))
758 { 758 {
759 // shared as priority over group roles 759 if(notGroupdOwned)
760 bool notShared = (grp.EffectiveGroupPerms & SHAREDMASK) == 0;
761 if(groupdOwned && notShared)
762 { 760 {
763 // object is owned by group, check role powers 761 // group sharing or everyone
764 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) 762 returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked);
765 { 763 if (taskOwnerID != UUID.Zero)
766 // group sharing or everyone 764 returnMask |= (uint)PrimFlags.ObjectAnyOwner;
767 returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked);
768 returnMask |=
769 (uint)PrimFlags.ObjectGroupOwned |
770 (uint)PrimFlags.ObjectAnyOwner;
771 return returnMask;
772 }
773
774 // we may have copy without transfer
775 uint grpEffectiveOwnerPerms = grp.EffectiveOwnerPerms;
776 if((grpEffectiveOwnerPerms & (uint)PermissionMask.Transfer) == 0)
777 grpEffectiveOwnerPerms &= ~(uint)PermissionMask.Copy;
778 returnMask = ApplyObjectModifyMasks(grpEffectiveOwnerPerms, objflags, unlocked);
779 returnMask |=
780 (uint)PrimFlags.ObjectGroupOwned |
781 (uint)PrimFlags.ObjectAnyOwner;
782 if((returnMask & (uint)PrimFlags.ObjectModify) != 0)
783 returnMask |= (uint)PrimFlags.ObjectOwnerModify;
784 return returnMask; 765 return returnMask;
785 } 766 }
786 else 767
768 // object is owned by group, check role powers
769 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0)
787 { 770 {
788 // group sharing or everyone 771 // group sharing or everyone
789 returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked); 772 returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked);
790 if(groupdOwned) 773 returnMask |=
791 { 774 (uint)PrimFlags.ObjectGroupOwned |
792 returnMask |= 775 (uint)PrimFlags.ObjectAnyOwner;
793 (uint)PrimFlags.ObjectGroupOwned |
794 (uint)PrimFlags.ObjectAnyOwner;
795 }
796 else if (taskOwnerID != UUID.Zero)
797 returnMask |= (uint)PrimFlags.ObjectAnyOwner;
798 return returnMask; 776 return returnMask;
799 } 777 }
778
779 // we may have copy without transfer
780 uint grpEffectiveOwnerPerms = grp.EffectiveOwnerPerms;
781 if((grpEffectiveOwnerPerms & (uint)PermissionMask.Transfer) == 0)
782 grpEffectiveOwnerPerms &= ~(uint)PermissionMask.Copy;
783 returnMask = ApplyObjectModifyMasks(grpEffectiveOwnerPerms, objflags, unlocked);
784 returnMask |=
785 (uint)PrimFlags.ObjectGroupOwned |
786 (uint)PrimFlags.ObjectYouOwner;
787 if((returnMask & (uint)PrimFlags.ObjectModify) != 0)
788 returnMask |= (uint)PrimFlags.ObjectOwnerModify;
789 return returnMask;
800 } 790 }
801 791
802 // fallback is everyone rights 792 // fallback is everyone rights
@@ -898,17 +888,17 @@ namespace OpenSim.Region.CoreModules.World.Permissions
898 888
899 if (group.IsAttachment) 889 if (group.IsAttachment)
900 return 0; 890 return 0;
901
902 if (IsFriendWithPerms(currentUser, objectOwner))
903 return group.EffectiveOwnerPerms & lockmask;
904 891
905 UUID sogGroupID = group.GroupID; 892 UUID sogGroupID = group.GroupID;
893 bool notgroudOwned = sogGroupID != objectOwner;
894
895 if (notgroudOwned && IsFriendWithPerms(currentUser, objectOwner))
896 return group.EffectiveOwnerPerms & lockmask;
897
906 ulong powers = 0; 898 ulong powers = 0;
907 if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, currentUser, ref powers)) 899 if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, currentUser, ref powers))
908 { 900 {
909 bool Shared = (group.EffectiveGroupPerms & SHAREDMASK) != 0; 901 if(notgroudOwned)
910
911 if(Shared || sogGroupID != objectOwner)
912 return group.EffectiveGroupOrEveryOnePerms & lockmask; 902 return group.EffectiveGroupOrEveryOnePerms & lockmask;
913 903
914 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) 904 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0)
@@ -955,16 +945,16 @@ namespace OpenSim.Region.CoreModules.World.Permissions
955 if (group.IsAttachment) 945 if (group.IsAttachment)
956 return 0; 946 return 0;
957 947
958 if (IsFriendWithPerms(spID, objectOwner)) 948 UUID sogGroupID = group.GroupID;
949 bool notgroudOwned = sogGroupID != objectOwner;
950
951 if (notgroudOwned && IsFriendWithPerms(spID, objectOwner))
959 return group.EffectiveOwnerPerms & lockmask; 952 return group.EffectiveOwnerPerms & lockmask;
960 953
961 UUID sogGroupID = group.GroupID;
962 ulong powers = 0; 954 ulong powers = 0;
963 if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, sp, ref powers)) 955 if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, sp, ref powers))
964 { 956 {
965 bool Shared = (group.EffectiveGroupPerms & SHAREDMASK) != 0; 957 if(notgroudOwned)
966
967 if(Shared || sogGroupID != objectOwner)
968 return group.EffectiveGroupOrEveryOnePerms & lockmask; 958 return group.EffectiveGroupOrEveryOnePerms & lockmask;
969 959
970 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) 960 if((powers & (ulong)GroupPowers.ObjectManipulate) == 0)