aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework/Scenes
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Framework/Scenes')
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.Inventory.cs5
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.Inventory.cs5
2 files changed, 8 insertions, 2 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs b/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
index 000944f..9772b35 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
@@ -433,7 +433,7 @@ namespace OpenSim.Region.Framework.Scenes
433// m_log.DebugFormat("[XXX]: B: {0} O: {1} E: {2}", itemUpd.BasePermissions, itemUpd.CurrentPermissions, itemUpd.EveryOnePermissions); 433// m_log.DebugFormat("[XXX]: B: {0} O: {1} E: {2}", itemUpd.BasePermissions, itemUpd.CurrentPermissions, itemUpd.EveryOnePermissions);
434 const uint permALLandExport = (uint)(PermissionMask.All | PermissionMask.Export); 434 const uint permALLandExport = (uint)(PermissionMask.All | PermissionMask.Export);
435 // If the user is not the creator or doesn't have "E" in both "B" and "O", deny setting export 435 // If the user is not the creator or doesn't have "E" in both "B" and "O", deny setting export
436 if (item.CreatorIdAsUuid != item.Owner && 436 if (item.CreatorIdAsUuid != item.Owner ||
437 ((item.BasePermissions & permALLandExport) != permALLandExport || 437 ((item.BasePermissions & permALLandExport) != permALLandExport ||
438 (item.CurrentPermissions & (uint)PermissionMask.Export) == 0)) 438 (item.CurrentPermissions & (uint)PermissionMask.Export) == 0))
439 denyExportChange = true; 439 denyExportChange = true;
@@ -451,10 +451,12 @@ namespace OpenSim.Region.Framework.Scenes
451 { 451 {
452 itemUpd.NextPermissions = (uint)(PermissionMask.All); 452 itemUpd.NextPermissions = (uint)(PermissionMask.All);
453 itemUpd.EveryOnePermissions |= (uint)PermissionMask.Export; 453 itemUpd.EveryOnePermissions |= (uint)PermissionMask.Export;
454 sendUpdate = true;
454 } 455 }
455 else 456 else
456 { 457 {
457 itemUpd.EveryOnePermissions &= ~(uint)PermissionMask.Export; 458 itemUpd.EveryOnePermissions &= ~(uint)PermissionMask.Export;
459 sendUpdate = true;
458 } 460 }
459 } 461 }
460 else 462 else
@@ -464,6 +466,7 @@ namespace OpenSim.Region.Framework.Scenes
464 { 466 {
465// m_log.DebugFormat("[XXX]: Force full perm"); 467// m_log.DebugFormat("[XXX]: Force full perm");
466 itemUpd.NextPermissions = (uint)(PermissionMask.All); 468 itemUpd.NextPermissions = (uint)(PermissionMask.All);
469 sendUpdate = true;
467 } 470 }
468 } 471 }
469 472
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.Inventory.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.Inventory.cs
index 98617d1..68d80f0 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.Inventory.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.Inventory.cs
@@ -258,7 +258,8 @@ namespace OpenSim.Region.Framework.Scenes
258 uint perms=(uint)(PermissionMask.Modify | 258 uint perms=(uint)(PermissionMask.Modify |
259 PermissionMask.Copy | 259 PermissionMask.Copy |
260 PermissionMask.Move | 260 PermissionMask.Move |
261 PermissionMask.Transfer) | 7; 261 PermissionMask.Transfer |
262 PermissionMask.Export ) | 7;
262 263
263 uint ownerMask = 0x7fffffff; 264 uint ownerMask = 0x7fffffff;
264 265
@@ -281,6 +282,8 @@ namespace OpenSim.Region.Framework.Scenes
281 perms &= ~(uint)PermissionMask.Copy; 282 perms &= ~(uint)PermissionMask.Copy;
282 if ((ownerMask & (uint)PermissionMask.Transfer) == 0) 283 if ((ownerMask & (uint)PermissionMask.Transfer) == 0)
283 perms &= ~(uint)PermissionMask.Transfer; 284 perms &= ~(uint)PermissionMask.Transfer;
285 if ((ownerMask & (uint)PermissionMask.Export) == 0)
286 perms &= ~(uint)PermissionMask.Export;
284 287
285 // If root prim permissions are applied here, this would screw 288 // If root prim permissions are applied here, this would screw
286 // with in-inventory manipulation of the next owner perms 289 // with in-inventory manipulation of the next owner perms