From 8d99c86f96319e143e8e3b5a642c420fd0867c57 Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Sun, 22 Jan 2017 05:07:43 +0000 Subject: share before groupr roles was a testing elsewhere induced mistake, clean it up --- .../World/Permissions/PermissionsModule.cs | 82 ++++++++++------------ 1 file changed, 36 insertions(+), 46 deletions(-) (limited to 'OpenSim') 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 } UUID taskGroupID = task.GroupID; - bool groupdOwned = taskOwnerID == taskGroupID; + bool notGroupdOwned = taskOwnerID != taskGroupID; // if friends with rights then owner - if (!groupdOwned && IsFriendWithPerms(spID, taskOwnerID)) + if (notGroupdOwned && IsFriendWithPerms(spID, taskOwnerID)) { returnMask = ApplyObjectModifyMasks(grp.EffectiveOwnerPerms, objflags, unlocked); returnMask |= EXTRAOWNERMASK; @@ -756,47 +756,37 @@ namespace OpenSim.Region.CoreModules.World.Permissions ulong powers = 0; if(taskGroupID != UUID.Zero && GroupMemberPowers(taskGroupID, sp, ref powers)) { - // shared as priority over group roles - bool notShared = (grp.EffectiveGroupPerms & SHAREDMASK) == 0; - if(groupdOwned && notShared) + if(notGroupdOwned) { - // object is owned by group, check role powers - if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) - { - // group sharing or everyone - returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked); - returnMask |= - (uint)PrimFlags.ObjectGroupOwned | - (uint)PrimFlags.ObjectAnyOwner; - return returnMask; - } - - // we may have copy without transfer - uint grpEffectiveOwnerPerms = grp.EffectiveOwnerPerms; - if((grpEffectiveOwnerPerms & (uint)PermissionMask.Transfer) == 0) - grpEffectiveOwnerPerms &= ~(uint)PermissionMask.Copy; - returnMask = ApplyObjectModifyMasks(grpEffectiveOwnerPerms, objflags, unlocked); - returnMask |= - (uint)PrimFlags.ObjectGroupOwned | - (uint)PrimFlags.ObjectAnyOwner; - if((returnMask & (uint)PrimFlags.ObjectModify) != 0) - returnMask |= (uint)PrimFlags.ObjectOwnerModify; + // group sharing or everyone + returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked); + if (taskOwnerID != UUID.Zero) + returnMask |= (uint)PrimFlags.ObjectAnyOwner; return returnMask; } - else + + // object is owned by group, check role powers + if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) { // group sharing or everyone returnMask = ApplyObjectModifyMasks(grp.EffectiveGroupOrEveryOnePerms, objflags, unlocked); - if(groupdOwned) - { - returnMask |= - (uint)PrimFlags.ObjectGroupOwned | - (uint)PrimFlags.ObjectAnyOwner; - } - else if (taskOwnerID != UUID.Zero) - returnMask |= (uint)PrimFlags.ObjectAnyOwner; + returnMask |= + (uint)PrimFlags.ObjectGroupOwned | + (uint)PrimFlags.ObjectAnyOwner; return returnMask; } + + // we may have copy without transfer + uint grpEffectiveOwnerPerms = grp.EffectiveOwnerPerms; + if((grpEffectiveOwnerPerms & (uint)PermissionMask.Transfer) == 0) + grpEffectiveOwnerPerms &= ~(uint)PermissionMask.Copy; + returnMask = ApplyObjectModifyMasks(grpEffectiveOwnerPerms, objflags, unlocked); + returnMask |= + (uint)PrimFlags.ObjectGroupOwned | + (uint)PrimFlags.ObjectYouOwner; + if((returnMask & (uint)PrimFlags.ObjectModify) != 0) + returnMask |= (uint)PrimFlags.ObjectOwnerModify; + return returnMask; } // fallback is everyone rights @@ -898,17 +888,17 @@ namespace OpenSim.Region.CoreModules.World.Permissions if (group.IsAttachment) return 0; - - if (IsFriendWithPerms(currentUser, objectOwner)) - return group.EffectiveOwnerPerms & lockmask; UUID sogGroupID = group.GroupID; + bool notgroudOwned = sogGroupID != objectOwner; + + if (notgroudOwned && IsFriendWithPerms(currentUser, objectOwner)) + return group.EffectiveOwnerPerms & lockmask; + ulong powers = 0; if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, currentUser, ref powers)) { - bool Shared = (group.EffectiveGroupPerms & SHAREDMASK) != 0; - - if(Shared || sogGroupID != objectOwner) + if(notgroudOwned) return group.EffectiveGroupOrEveryOnePerms & lockmask; if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) @@ -955,16 +945,16 @@ namespace OpenSim.Region.CoreModules.World.Permissions if (group.IsAttachment) return 0; - if (IsFriendWithPerms(spID, objectOwner)) + UUID sogGroupID = group.GroupID; + bool notgroudOwned = sogGroupID != objectOwner; + + if (notgroudOwned && IsFriendWithPerms(spID, objectOwner)) return group.EffectiveOwnerPerms & lockmask; - UUID sogGroupID = group.GroupID; ulong powers = 0; if (sogGroupID != UUID.Zero && GroupMemberPowers(sogGroupID, sp, ref powers)) { - bool Shared = (group.EffectiveGroupPerms & SHAREDMASK) != 0; - - if(Shared || sogGroupID != objectOwner) + if(notgroudOwned) return group.EffectiveGroupOrEveryOnePerms & lockmask; if((powers & (ulong)GroupPowers.ObjectManipulate) == 0) -- cgit v1.1