Restore CM loking after core extract
parent
2f84f2171f
commit
c9aa420c2d
|
@ -953,80 +953,79 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
InventoryStringBuilder invString = new InventoryStringBuilder(m_part.UUID, UUID.Zero);
|
InventoryStringBuilder invString = new InventoryStringBuilder(m_part.UUID, UUID.Zero);
|
||||||
|
|
||||||
lock (m_items)
|
Items.LockItemsForRead(true);
|
||||||
|
|
||||||
|
if (m_inventorySerial == 0) // No inventory
|
||||||
{
|
{
|
||||||
if (m_inventorySerial == 0) // No inventory
|
client.SendTaskInventory(m_part.UUID, 0, new byte[0]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
client.SendTaskInventory(m_part.UUID, (short)m_inventorySerial,
|
||||||
|
Util.StringToBytes256(m_inventoryFileName));
|
||||||
|
|
||||||
|
if (!changed)
|
||||||
|
{
|
||||||
|
if (m_inventoryFileData.Length > 2)
|
||||||
{
|
{
|
||||||
client.SendTaskInventory(m_part.UUID, 0, new byte[0]);
|
xferManager.AddNewFile(m_inventoryFileName,
|
||||||
return;
|
m_inventoryFileData);
|
||||||
}
|
|
||||||
|
|
||||||
client.SendTaskInventory(m_part.UUID, (short)m_inventorySerial,
|
|
||||||
Util.StringToBytes256(m_inventoryFileName));
|
|
||||||
|
|
||||||
if (!changed)
|
|
||||||
{
|
|
||||||
if (m_inventoryFileData.Length > 2)
|
|
||||||
{
|
|
||||||
xferManager.AddNewFile(m_inventoryFileName,
|
|
||||||
m_inventoryFileData);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool includeAssets = false;
|
|
||||||
if (m_part.ParentGroup.Scene.Permissions.CanEditObjectInventory(m_part.UUID, client.AgentId))
|
|
||||||
includeAssets = true;
|
|
||||||
|
|
||||||
foreach (TaskInventoryItem item in m_items.Values)
|
|
||||||
{
|
|
||||||
UUID ownerID = item.OwnerID;
|
|
||||||
uint everyoneMask = 0;
|
|
||||||
uint baseMask = item.BasePermissions;
|
|
||||||
uint ownerMask = item.CurrentPermissions;
|
|
||||||
uint groupMask = item.GroupPermissions;
|
|
||||||
|
|
||||||
invString.AddItemStart();
|
|
||||||
invString.AddNameValueLine("item_id", item.ItemID.ToString());
|
|
||||||
invString.AddNameValueLine("parent_id", m_part.UUID.ToString());
|
|
||||||
|
|
||||||
invString.AddPermissionsStart();
|
|
||||||
|
|
||||||
invString.AddNameValueLine("base_mask", Utils.UIntToHexString(baseMask));
|
|
||||||
invString.AddNameValueLine("owner_mask", Utils.UIntToHexString(ownerMask));
|
|
||||||
invString.AddNameValueLine("group_mask", Utils.UIntToHexString(groupMask));
|
|
||||||
invString.AddNameValueLine("everyone_mask", Utils.UIntToHexString(everyoneMask));
|
|
||||||
invString.AddNameValueLine("next_owner_mask", Utils.UIntToHexString(item.NextPermissions));
|
|
||||||
|
|
||||||
invString.AddNameValueLine("creator_id", item.CreatorID.ToString());
|
|
||||||
invString.AddNameValueLine("owner_id", ownerID.ToString());
|
|
||||||
|
|
||||||
invString.AddNameValueLine("last_owner_id", item.LastOwnerID.ToString());
|
|
||||||
|
|
||||||
invString.AddNameValueLine("group_id", item.GroupID.ToString());
|
|
||||||
invString.AddSectionEnd();
|
|
||||||
|
|
||||||
if (includeAssets)
|
|
||||||
invString.AddNameValueLine("asset_id", item.AssetID.ToString());
|
|
||||||
else
|
|
||||||
invString.AddNameValueLine("asset_id", UUID.Zero.ToString());
|
|
||||||
invString.AddNameValueLine("type", TaskInventoryItem.Types[item.Type]);
|
|
||||||
invString.AddNameValueLine("inv_type", TaskInventoryItem.InvTypes[item.InvType]);
|
|
||||||
invString.AddNameValueLine("flags", Utils.UIntToHexString(item.Flags));
|
|
||||||
|
|
||||||
invString.AddSaleStart();
|
|
||||||
invString.AddNameValueLine("sale_type", "not");
|
|
||||||
invString.AddNameValueLine("sale_price", "0");
|
|
||||||
invString.AddSectionEnd();
|
|
||||||
|
|
||||||
invString.AddNameValueLine("name", item.Name + "|");
|
|
||||||
invString.AddNameValueLine("desc", item.Description + "|");
|
|
||||||
|
|
||||||
invString.AddNameValueLine("creation_date", item.CreationDate.ToString());
|
|
||||||
invString.AddSectionEnd();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int count = m_items.Count;
|
bool includeAssets = false;
|
||||||
|
if (m_part.ParentGroup.Scene.Permissions.CanEditObjectInventory(m_part.UUID, client.AgentId))
|
||||||
|
includeAssets = true;
|
||||||
|
|
||||||
|
foreach (TaskInventoryItem item in m_items.Values)
|
||||||
|
{
|
||||||
|
UUID ownerID = item.OwnerID;
|
||||||
|
uint everyoneMask = 0;
|
||||||
|
uint baseMask = item.BasePermissions;
|
||||||
|
uint ownerMask = item.CurrentPermissions;
|
||||||
|
uint groupMask = item.GroupPermissions;
|
||||||
|
|
||||||
|
invString.AddItemStart();
|
||||||
|
invString.AddNameValueLine("item_id", item.ItemID.ToString());
|
||||||
|
invString.AddNameValueLine("parent_id", m_part.UUID.ToString());
|
||||||
|
|
||||||
|
invString.AddPermissionsStart();
|
||||||
|
|
||||||
|
invString.AddNameValueLine("base_mask", Utils.UIntToHexString(baseMask));
|
||||||
|
invString.AddNameValueLine("owner_mask", Utils.UIntToHexString(ownerMask));
|
||||||
|
invString.AddNameValueLine("group_mask", Utils.UIntToHexString(groupMask));
|
||||||
|
invString.AddNameValueLine("everyone_mask", Utils.UIntToHexString(everyoneMask));
|
||||||
|
invString.AddNameValueLine("next_owner_mask", Utils.UIntToHexString(item.NextPermissions));
|
||||||
|
|
||||||
|
invString.AddNameValueLine("creator_id", item.CreatorID.ToString());
|
||||||
|
invString.AddNameValueLine("owner_id", ownerID.ToString());
|
||||||
|
|
||||||
|
invString.AddNameValueLine("last_owner_id", item.LastOwnerID.ToString());
|
||||||
|
|
||||||
|
invString.AddNameValueLine("group_id", item.GroupID.ToString());
|
||||||
|
invString.AddSectionEnd();
|
||||||
|
|
||||||
|
if (includeAssets)
|
||||||
|
invString.AddNameValueLine("asset_id", item.AssetID.ToString());
|
||||||
|
else
|
||||||
|
invString.AddNameValueLine("asset_id", UUID.Zero.ToString());
|
||||||
|
invString.AddNameValueLine("type", TaskInventoryItem.Types[item.Type]);
|
||||||
|
invString.AddNameValueLine("inv_type", TaskInventoryItem.InvTypes[item.InvType]);
|
||||||
|
invString.AddNameValueLine("flags", Utils.UIntToHexString(item.Flags));
|
||||||
|
|
||||||
|
invString.AddSaleStart();
|
||||||
|
invString.AddNameValueLine("sale_type", "not");
|
||||||
|
invString.AddNameValueLine("sale_price", "0");
|
||||||
|
invString.AddSectionEnd();
|
||||||
|
|
||||||
|
invString.AddNameValueLine("name", item.Name + "|");
|
||||||
|
invString.AddNameValueLine("desc", item.Description + "|");
|
||||||
|
|
||||||
|
invString.AddNameValueLine("creation_date", item.CreationDate.ToString());
|
||||||
|
invString.AddSectionEnd();
|
||||||
|
}
|
||||||
|
|
||||||
|
Items.LockItemsForRead(false);
|
||||||
|
|
||||||
m_inventoryFileData = Utils.StringToBytes(invString.BuildString);
|
m_inventoryFileData = Utils.StringToBytes(invString.BuildString);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue