diff options
author | Oren Hurvitz | 2013-11-07 17:25:39 +0200 |
---|---|---|
committer | Justin Clark-Casey (justincc) | 2014-01-10 20:01:08 +0000 |
commit | 88f01a41305364e0d505964c6743d95d1564530b (patch) | |
tree | 6a18abc03541d3cf2f8636c606128227affcf1da /OpenSim/Region | |
parent | When creating a coalesced object, set its Creator ID if all the objects have ... (diff) | |
download | opensim-SC-88f01a41305364e0d505964c6743d95d1564530b.zip opensim-SC-88f01a41305364e0d505964c6743d95d1564530b.tar.gz opensim-SC-88f01a41305364e0d505964c6743d95d1564530b.tar.bz2 opensim-SC-88f01a41305364e0d505964c6743d95d1564530b.tar.xz |
When creating a coalesced object, set its permissions to the lowest-common-denominator of all the sub-objects
Diffstat (limited to 'OpenSim/Region')
-rw-r--r-- | OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs index af95577..781cc69 100644 --- a/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs +++ b/OpenSim/Region/CoreModules/Framework/InventoryAccess/InventoryAccessModule.cs | |||
@@ -502,8 +502,17 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
502 | IClientAPI remoteClient) | 502 | IClientAPI remoteClient) |
503 | { | 503 | { |
504 | uint effectivePerms = (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify | PermissionMask.Move | PermissionMask.Export) | 7; | 504 | uint effectivePerms = (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify | PermissionMask.Move | PermissionMask.Export) | 7; |
505 | uint allObjectsNextOwnerPerms = 0x7fffffff; | ||
506 | uint allObjectsEveryOnePerms = 0x7fffffff; | ||
507 | uint allObjectsGroupPerms = 0x7fffffff; | ||
508 | |||
505 | foreach (SceneObjectGroup grp in objsForEffectivePermissions) | 509 | foreach (SceneObjectGroup grp in objsForEffectivePermissions) |
510 | { | ||
506 | effectivePerms &= grp.GetEffectivePermissions(); | 511 | effectivePerms &= grp.GetEffectivePermissions(); |
512 | allObjectsNextOwnerPerms &= grp.RootPart.NextOwnerMask; | ||
513 | allObjectsEveryOnePerms &= grp.RootPart.EveryoneMask; | ||
514 | allObjectsGroupPerms &= grp.RootPart.GroupMask; | ||
515 | } | ||
507 | effectivePerms |= (uint)PermissionMask.Move; | 516 | effectivePerms |= (uint)PermissionMask.Move; |
508 | 517 | ||
509 | //PermissionsUtil.LogPermissions(item.Name, "Before AddPermissions", item.BasePermissions, item.CurrentPermissions, item.NextPermissions); | 518 | //PermissionsUtil.LogPermissions(item.Name, "Before AddPermissions", item.BasePermissions, item.CurrentPermissions, item.NextPermissions); |
@@ -513,11 +522,11 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
513 | uint perms = effectivePerms; | 522 | uint perms = effectivePerms; |
514 | PermissionsUtil.ApplyFoldedPermissions(effectivePerms, ref perms); | 523 | PermissionsUtil.ApplyFoldedPermissions(effectivePerms, ref perms); |
515 | 524 | ||
516 | item.BasePermissions = perms & so.RootPart.NextOwnerMask; | 525 | item.BasePermissions = perms & allObjectsNextOwnerPerms; |
517 | item.CurrentPermissions = item.BasePermissions; | 526 | item.CurrentPermissions = item.BasePermissions; |
518 | item.NextPermissions = perms & so.RootPart.NextOwnerMask; | 527 | item.NextPermissions = perms & allObjectsNextOwnerPerms; |
519 | item.EveryOnePermissions = so.RootPart.EveryoneMask & so.RootPart.NextOwnerMask; | 528 | item.EveryOnePermissions = allObjectsEveryOnePerms & allObjectsNextOwnerPerms; |
520 | item.GroupPermissions = so.RootPart.GroupMask & so.RootPart.NextOwnerMask; | 529 | item.GroupPermissions = allObjectsGroupPerms & allObjectsNextOwnerPerms; |
521 | 530 | ||
522 | // apply next owner perms on rez | 531 | // apply next owner perms on rez |
523 | item.CurrentPermissions |= SceneObjectGroup.SLAM; | 532 | item.CurrentPermissions |= SceneObjectGroup.SLAM; |
@@ -526,9 +535,9 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess | |||
526 | { | 535 | { |
527 | item.BasePermissions = effectivePerms; | 536 | item.BasePermissions = effectivePerms; |
528 | item.CurrentPermissions = effectivePerms; | 537 | item.CurrentPermissions = effectivePerms; |
529 | item.NextPermissions = so.RootPart.NextOwnerMask & effectivePerms; | 538 | item.NextPermissions = allObjectsNextOwnerPerms & effectivePerms; |
530 | item.EveryOnePermissions = so.RootPart.EveryoneMask & effectivePerms; | 539 | item.EveryOnePermissions = allObjectsEveryOnePerms & effectivePerms; |
531 | item.GroupPermissions = so.RootPart.GroupMask & effectivePerms; | 540 | item.GroupPermissions = allObjectsGroupPerms & effectivePerms; |
532 | 541 | ||
533 | item.CurrentPermissions &= | 542 | item.CurrentPermissions &= |
534 | ((uint)PermissionMask.Copy | | 543 | ((uint)PermissionMask.Copy | |