diff --git a/OpenSim/Region/Environment/Modules/World/Permissions/PermissionsModule.cs b/OpenSim/Region/Environment/Modules/World/Permissions/PermissionsModule.cs
index b6b7d4a651..394690c06f 100644
--- a/OpenSim/Region/Environment/Modules/World/Permissions/PermissionsModule.cs
+++ b/OpenSim/Region/Environment/Modules/World/Permissions/PermissionsModule.cs
@@ -184,12 +184,11 @@ namespace OpenSim.Region.Environment.Modules.World.Permissions
m_scene.ExternalChecks.addCheckCanLinkObject(CanLinkObject); //NOT YET IMPLEMENTED
m_scene.ExternalChecks.addCheckCanDelinkObject(CanDelinkObject); //NOT YET IMPLEMENTED
m_scene.ExternalChecks.addCheckCanBuyLand(CanBuyLand); //NOT YET IMPLEMENTED
- m_scene.ExternalChecks.addCheckCanCopyInventory(CanCopyInventory); //NOT YET IMPLEMENTED
- m_scene.ExternalChecks.addCheckCanDeleteInventory(CanDeleteInventory); //NOT YET IMPLEMENTED
- m_scene.ExternalChecks.addCheckCanCreateInventory(CanCreateInventory); //NOT YET IMPLEMENTED
+ m_scene.ExternalChecks.addCheckCanCopyObjectInventory(CanCopyObjectInventory); //NOT YET IMPLEMENTED
+ m_scene.ExternalChecks.addCheckCanDeleteObjectInventory(CanDeleteObjectInventory); //NOT YET IMPLEMENTED
+ m_scene.ExternalChecks.addCheckCanCreateObjectInventory(CanCreateObjectInventory); //NOT YET IMPLEMENTED
m_scene.ExternalChecks.addCheckCanTeleport(CanTeleport); //NOT YET IMPLEMENTED
-
//Register Debug Commands
Command bypassCommand = new Command("bypass", CommandIntentions.COMMAND_HAZARDOUS, InterfaceBypassPermissions, "Force the permissions a specific way to test permissions");
bypassCommand.AddArgument("enable_bypass_perms", "true to enable bypassing all perms", "Boolean");
@@ -1202,7 +1201,7 @@ namespace OpenSim.Region.Environment.Modules.World.Permissions
return true;
}
- public bool CanCopyInventory(UUID itemID, UUID objectID, UUID userID)
+ public bool CanCopyObjectInventory(UUID itemID, UUID objectID, UUID userID)
{
DebugPermissionInformation(MethodInfo.GetCurrentMethod().Name);
if (m_bypassPermissions) return m_bypassPermissionsValue;
@@ -1210,7 +1209,7 @@ namespace OpenSim.Region.Environment.Modules.World.Permissions
return true;
}
- public bool CanDeleteInventory(UUID itemID, UUID objectID, UUID userID)
+ public bool CanDeleteObjectInventory(UUID itemID, UUID objectID, UUID userID)
{
DebugPermissionInformation(MethodInfo.GetCurrentMethod().Name);
if (m_bypassPermissions) return m_bypassPermissionsValue;
@@ -1227,7 +1226,7 @@ namespace OpenSim.Region.Environment.Modules.World.Permissions
///
///
///
- public bool CanCreateInventory(int invType, UUID objectID, UUID userID)
+ public bool CanCreateObjectInventory(int invType, UUID objectID, UUID userID)
{
m_log.Debug("[PERMISSIONS]: CanCreateInventory called");
diff --git a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
index 19c9d08eff..d47e0681ea 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
@@ -1387,7 +1387,8 @@ namespace OpenSim.Region.Environment.Scenes
if ((part.OwnerMask & (uint)PermissionMask.Modify) == 0)
return;
- if (!ExternalChecks.ExternalChecksCanCreateInventory(itemBase.InvType, part.UUID, remoteClient.AgentId))
+ if (!ExternalChecks.ExternalChecksCanCreateObjectInventory(
+ itemBase.InvType, part.UUID, remoteClient.AgentId))
return;
AssetBase asset = CreateAsset(itemBase.Name, itemBase.Description, (sbyte)itemBase.AssetType, Encoding.ASCII.GetBytes("default\n{\n state_entry()\n {\n llSay(0, \"Script running\");\n }\n}"));
diff --git a/OpenSim/Region/Environment/Scenes/SceneExternalChecks.cs b/OpenSim/Region/Environment/Scenes/SceneExternalChecks.cs
index c5bbcddf33..0e018e8c4a 100644
--- a/OpenSim/Region/Environment/Scenes/SceneExternalChecks.cs
+++ b/OpenSim/Region/Environment/Scenes/SceneExternalChecks.cs
@@ -1070,51 +1070,63 @@ namespace OpenSim.Region.Environment.Scenes
#endregion
- public delegate bool CanCreateInventory(int invType, UUID objectID, UUID userID);
- private List CanCreateInventoryCheckFunctions = new List();
+ public delegate bool CanCreateObjectInventory(int invType, UUID objectID, UUID userID);
+ private List CanCreateObjectInventoryCheckFunctions
+ = new List();
- public void addCheckCanCreateInventory(CanCreateInventory delegateFunc)
+
+ public void addCheckCanCreateObjectInventory(CanCreateObjectInventory delegateFunc)
{
- if (!CanCreateInventoryCheckFunctions.Contains(delegateFunc))
- CanCreateInventoryCheckFunctions.Add(delegateFunc);
+ if (!CanCreateObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanCreateObjectInventoryCheckFunctions.Add(delegateFunc);
}
- public void removeCheckCanCreateInventory(CanCreateInventory delegateFunc)
+ public void removeCheckCanCreateObjectInventory(CanCreateObjectInventory delegateFunc)
{
- if (CanCreateInventoryCheckFunctions.Contains(delegateFunc))
- CanCreateInventoryCheckFunctions.Remove(delegateFunc);
+ if (CanCreateObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanCreateObjectInventoryCheckFunctions.Remove(delegateFunc);
}
- public bool ExternalChecksCanCreateInventory(int invType, UUID objectID, UUID userID)
+ ///
+ /// Check whether the specified user is allowed to directly create the given inventory type in a prim's
+ /// inventory (e.g. the New Script button in the 1.21 Linden Lab client). This permission check does not
+ /// apply to existing items that are being dragged in to that prim's inventory.
+ ///
+ ///
+ ///
+ ///
+ ///
+ public bool ExternalChecksCanCreateObjectInventory(int invType, UUID objectID, UUID userID)
{
- foreach (CanCreateInventory check in CanCreateInventoryCheckFunctions)
+ foreach (CanCreateObjectInventory check in CanCreateObjectInventoryCheckFunctions)
{
if (check(invType, objectID, userID) == false)
{
return false;
}
}
+
return true;
}
- public delegate bool CanCopyInventory(UUID itemID, UUID objectID, UUID userID);
- private List CanCopyInventoryCheckFunctions = new List();
+ public delegate bool CanCopyObjectInventory(UUID itemID, UUID objectID, UUID userID);
+ private List CanCopyObjectInventoryCheckFunctions = new List();
- public void addCheckCanCopyInventory(CanCopyInventory delegateFunc)
+ public void addCheckCanCopyObjectInventory(CanCopyObjectInventory delegateFunc)
{
- if (!CanCopyInventoryCheckFunctions.Contains(delegateFunc))
- CanCopyInventoryCheckFunctions.Add(delegateFunc);
+ if (!CanCopyObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanCopyObjectInventoryCheckFunctions.Add(delegateFunc);
}
- public void removeCheckCanCopyInventory(CanCopyInventory delegateFunc)
+ public void removeCheckCanCopyObjectInventory(CanCopyObjectInventory delegateFunc)
{
- if (CanCopyInventoryCheckFunctions.Contains(delegateFunc))
- CanCopyInventoryCheckFunctions.Remove(delegateFunc);
+ if (CanCopyObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanCopyObjectInventoryCheckFunctions.Remove(delegateFunc);
}
-
- public bool ExternalChecksCanCopyInventory(UUID itemID, UUID objectID, UUID userID)
+
+ public bool ExternalChecksCanCopyObjectInventory(UUID itemID, UUID objectID, UUID userID)
{
- foreach (CanCopyInventory check in CanCopyInventoryCheckFunctions)
+ foreach (CanCopyObjectInventory check in CanCopyObjectInventoryCheckFunctions)
{
if (check(itemID, objectID, userID) == false)
{
@@ -1124,30 +1136,32 @@ namespace OpenSim.Region.Environment.Scenes
return true;
}
- public delegate bool CanDeleteInventory(UUID itemID, UUID objectID, UUID userID);
- private List CanDeleteInventoryCheckFunctions = new List();
+ public delegate bool CanDeleteObjectInventory(UUID itemID, UUID objectID, UUID userID);
+ private List CanDeleteObjectInventoryCheckFunctions
+ = new List();
- public void addCheckCanDeleteInventory(CanDeleteInventory delegateFunc)
+ public void addCheckCanDeleteObjectInventory(CanDeleteObjectInventory delegateFunc)
{
- if (!CanDeleteInventoryCheckFunctions.Contains(delegateFunc))
- CanDeleteInventoryCheckFunctions.Add(delegateFunc);
+ if (!CanDeleteObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanDeleteObjectInventoryCheckFunctions.Add(delegateFunc);
}
- public void removeCheckCanDeleteInventory(CanDeleteInventory delegateFunc)
+ public void removeCheckCanDeleteObjectInventory(CanDeleteObjectInventory delegateFunc)
{
- if (CanDeleteInventoryCheckFunctions.Contains(delegateFunc))
- CanDeleteInventoryCheckFunctions.Remove(delegateFunc);
+ if (CanDeleteObjectInventoryCheckFunctions.Contains(delegateFunc))
+ CanDeleteObjectInventoryCheckFunctions.Remove(delegateFunc);
}
- public bool ExternalChecksCanDeleteInventory(UUID itemID, UUID objectID, UUID userID)
+ public bool ExternalChecksCanDeleteObjectInventory(UUID itemID, UUID objectID, UUID userID)
{
- foreach (CanDeleteInventory check in CanDeleteInventoryCheckFunctions)
+ foreach (CanDeleteObjectInventory check in CanDeleteObjectInventoryCheckFunctions)
{
if (check(itemID, objectID, userID) == false)
{
return false;
}
}
+
return true;
}