aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.Inventory.cs130
1 files changed, 95 insertions, 35 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs b/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
index 64da5f6..3c3d077 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.Inventory.cs
@@ -46,7 +46,7 @@ namespace OpenSim.Region.Framework.Scenes
46{ 46{
47 public partial class Scene 47 public partial class Scene
48 { 48 {
49 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 49 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
50 private static readonly string LogHeader = "[SCENE INVENTORY]"; 50 private static readonly string LogHeader = "[SCENE INVENTORY]";
51 51
52 /// <summary> 52 /// <summary>
@@ -541,9 +541,9 @@ namespace OpenSim.Region.Framework.Scenes
541 /// <param name="recipientClient"></param> 541 /// <param name="recipientClient"></param>
542 /// <param name="senderId">ID of the sender of the item</param> 542 /// <param name="senderId">ID of the sender of the item</param>
543 /// <param name="itemId"></param> 543 /// <param name="itemId"></param>
544 public virtual void GiveInventoryItem(IClientAPI recipientClient, UUID senderId, UUID itemId) 544 public virtual void GiveInventoryItem(IClientAPI recipientClient, UUID senderId, UUID itemId, out string message)
545 { 545 {
546 InventoryItemBase itemCopy = GiveInventoryItem(recipientClient.AgentId, senderId, itemId); 546 InventoryItemBase itemCopy = GiveInventoryItem(recipientClient.AgentId, senderId, itemId, out message);
547 547
548 if (itemCopy != null) 548 if (itemCopy != null)
549 recipientClient.SendBulkUpdateInventory(itemCopy); 549 recipientClient.SendBulkUpdateInventory(itemCopy);
@@ -556,9 +556,9 @@ namespace OpenSim.Region.Framework.Scenes
556 /// <param name="senderId">ID of the sender of the item</param> 556 /// <param name="senderId">ID of the sender of the item</param>
557 /// <param name="itemId"></param> 557 /// <param name="itemId"></param>
558 /// <returns>The inventory item copy given, null if the give was unsuccessful</returns> 558 /// <returns>The inventory item copy given, null if the give was unsuccessful</returns>
559 public virtual InventoryItemBase GiveInventoryItem(UUID recipient, UUID senderId, UUID itemId) 559 public virtual InventoryItemBase GiveInventoryItem(UUID recipient, UUID senderId, UUID itemId, out string message)
560 { 560 {
561 return GiveInventoryItem(recipient, senderId, itemId, UUID.Zero); 561 return GiveInventoryItem(recipient, senderId, itemId, UUID.Zero, out message);
562 } 562 }
563 563
564 /// <summary> 564 /// <summary>
@@ -575,12 +575,15 @@ namespace OpenSim.Region.Framework.Scenes
575 /// The inventory item copy given, null if the give was unsuccessful 575 /// The inventory item copy given, null if the give was unsuccessful
576 /// </returns> 576 /// </returns>
577 public virtual InventoryItemBase GiveInventoryItem( 577 public virtual InventoryItemBase GiveInventoryItem(
578 UUID recipient, UUID senderId, UUID itemId, UUID recipientFolderId) 578 UUID recipient, UUID senderId, UUID itemId, UUID recipientFolderId, out string message)
579 { 579 {
580 //Console.WriteLine("Scene.Inventory.cs: GiveInventoryItem"); 580 //Console.WriteLine("Scene.Inventory.cs: GiveInventoryItem");
581 581
582 if (!Permissions.CanTransferUserInventory(itemId, senderId, recipient)) 582 if (!Permissions.CanTransferUserInventory(itemId, senderId, recipient))
583 {
584 message = "Not allowed to transfer this item.";
583 return null; 585 return null;
586 }
584 587
585 InventoryItemBase item = new InventoryItemBase(itemId, senderId); 588 InventoryItemBase item = new InventoryItemBase(itemId, senderId);
586 item = InventoryService.GetItem(item); 589 item = InventoryService.GetItem(item);
@@ -589,6 +592,7 @@ namespace OpenSim.Region.Framework.Scenes
589 { 592 {
590 m_log.WarnFormat( 593 m_log.WarnFormat(
591 "[AGENT INVENTORY]: Failed to find item {0} sent by {1} to {2}", itemId, senderId, recipient); 594 "[AGENT INVENTORY]: Failed to find item {0} sent by {1} to {2}", itemId, senderId, recipient);
595 message = string.Format("Item not found: {0}.", itemId);
592 return null; 596 return null;
593 } 597 }
594 598
@@ -597,6 +601,7 @@ namespace OpenSim.Region.Framework.Scenes
597 m_log.WarnFormat( 601 m_log.WarnFormat(
598 "[AGENT INVENTORY]: Attempt to send item {0} {1} to {2} failed because sender {3} did not match item owner {4}", 602 "[AGENT INVENTORY]: Attempt to send item {0} {1} to {2} failed because sender {3} did not match item owner {4}",
599 item.Name, item.ID, recipient, senderId, item.Owner); 603 item.Name, item.ID, recipient, senderId, item.Owner);
604 message = "Sender did not match item owner.";
600 return null; 605 return null;
601 } 606 }
602 607
@@ -607,7 +612,10 @@ namespace OpenSim.Region.Framework.Scenes
607 if (!Permissions.BypassPermissions()) 612 if (!Permissions.BypassPermissions())
608 { 613 {
609 if ((item.CurrentPermissions & (uint)PermissionMask.Transfer) == 0) 614 if ((item.CurrentPermissions & (uint)PermissionMask.Transfer) == 0)
615 {
616 message = "Item doesn't have the Transfer permission.";
610 return null; 617 return null;
618 }
611 } 619 }
612 620
613 // Insert a copy of the item into the recipient 621 // Insert a copy of the item into the recipient
@@ -743,9 +751,14 @@ namespace OpenSim.Region.Framework.Scenes
743 InventoryFolderBase root = InventoryService.GetRootFolder(recipient); 751 InventoryFolderBase root = InventoryService.GetRootFolder(recipient);
744 752
745 if (root != null) 753 if (root != null)
754 {
746 itemCopy.Folder = root.ID; 755 itemCopy.Folder = root.ID;
756 }
747 else 757 else
748 return null; // No destination 758 {
759 message = "Can't find a folder to add the item to.";
760 return null;
761 }
749 } 762 }
750 } 763 }
751 764
@@ -770,6 +783,7 @@ namespace OpenSim.Region.Framework.Scenes
770 } 783 }
771 } 784 }
772 785
786 message = null;
773 return itemCopy; 787 return itemCopy;
774 } 788 }
775 789
@@ -787,7 +801,7 @@ namespace OpenSim.Region.Framework.Scenes
787 /// <returns> 801 /// <returns>
788 /// The inventory folder copy given, null if the copy was unsuccessful 802 /// The inventory folder copy given, null if the copy was unsuccessful
789 /// </returns> 803 /// </returns>
790 public virtual InventoryFolderBase GiveInventoryFolder( 804 public virtual InventoryFolderBase GiveInventoryFolder(IClientAPI client,
791 UUID recipientId, UUID senderId, UUID folderId, UUID recipientParentFolderId) 805 UUID recipientId, UUID senderId, UUID folderId, UUID recipientParentFolderId)
792 { 806 {
793 //// Retrieve the folder from the sender 807 //// Retrieve the folder from the sender
@@ -822,13 +836,18 @@ namespace OpenSim.Region.Framework.Scenes
822 InventoryCollection contents = InventoryService.GetFolderContent(senderId, folderId); 836 InventoryCollection contents = InventoryService.GetFolderContent(senderId, folderId);
823 foreach (InventoryFolderBase childFolder in contents.Folders) 837 foreach (InventoryFolderBase childFolder in contents.Folders)
824 { 838 {
825 GiveInventoryFolder(recipientId, senderId, childFolder.ID, newFolder.ID); 839 GiveInventoryFolder(client, recipientId, senderId, childFolder.ID, newFolder.ID);
826 } 840 }
827 841
828 // Give all the items 842 // Give all the items
829 foreach (InventoryItemBase item in contents.Items) 843 foreach (InventoryItemBase item in contents.Items)
830 { 844 {
831 GiveInventoryItem(recipientId, senderId, item.ID, newFolder.ID); 845 string message;
846 if (GiveInventoryItem(recipientId, senderId, item.ID, newFolder.ID, out message) == null)
847 {
848 if (client != null)
849 client.SendAgentAlertMessage(message, false);
850 }
832 } 851 }
833 852
834 return newFolder; 853 return newFolder;
@@ -1155,11 +1174,19 @@ namespace OpenSim.Region.Framework.Scenes
1155 1174
1156 InventoryFolderBase destFolder = InventoryService.GetFolderForType(remoteClient.AgentId, AssetType.TrashFolder); 1175 InventoryFolderBase destFolder = InventoryService.GetFolderForType(remoteClient.AgentId, AssetType.TrashFolder);
1157 1176
1158 // Move the item to trash. If this is a copiable item, only 1177 // Move the item to trash. If this is a copyable item, only
1159 // a copy will be moved and we will still need to delete 1178 // a copy will be moved and we will still need to delete
1160 // the item from the prim. If it was no copy, is will be 1179 // the item from the prim. If it was no copy, it will be
1161 // deleted by this method. 1180 // deleted by this method.
1162 MoveTaskInventoryItem(remoteClient, destFolder.ID, part, itemID); 1181 string message;
1182 InventoryItemBase item2 = MoveTaskInventoryItem(remoteClient, destFolder.ID, part, itemID, out message);
1183
1184 if (item2 == null)
1185 {
1186 m_log.WarnFormat("[SCENE INVENTORY]: RemoveTaskInventory of item {0} failed: {1}", itemID, message);
1187 remoteClient.SendAgentAlertMessage(message, false);
1188 return;
1189 }
1163 1190
1164 if (group.GetInventoryItem(localID, itemID) != null) 1191 if (group.GetInventoryItem(localID, itemID) != null)
1165 { 1192 {
@@ -1171,11 +1198,16 @@ namespace OpenSim.Region.Framework.Scenes
1171 1198
1172 group.RemoveInventoryItem(localID, itemID); 1199 group.RemoveInventoryItem(localID, itemID);
1173 } 1200 }
1201
1174 part.SendPropertiesToClient(remoteClient); 1202 part.SendPropertiesToClient(remoteClient);
1175 } 1203 }
1176 } 1204 }
1177 1205
1178 private InventoryItemBase CreateAgentInventoryItemFromTask(UUID destAgent, SceneObjectPart part, UUID itemId) 1206
1207 /// <summary>
1208 /// Creates (in memory only) a user inventory item that will contain a copy of a task inventory item.
1209 /// </summary>
1210 private InventoryItemBase CreateAgentInventoryItemFromTask(UUID destAgent, SceneObjectPart part, UUID itemId, out string message)
1179 { 1211 {
1180 TaskInventoryItem taskItem = part.Inventory.GetInventoryItem(itemId); 1212 TaskInventoryItem taskItem = part.Inventory.GetInventoryItem(itemId);
1181 1213
@@ -1186,12 +1218,13 @@ namespace OpenSim.Region.Framework.Scenes
1186 + " inventory item from a prim's inventory item " 1218 + " inventory item from a prim's inventory item "
1187 + " but the required item does not exist in the prim's inventory", 1219 + " but the required item does not exist in the prim's inventory",
1188 itemId, part.Name, part.UUID); 1220 itemId, part.Name, part.UUID);
1189 1221 message = "Item not found: " + itemId;
1190 return null; 1222 return null;
1191 } 1223 }
1192 1224
1193 if ((destAgent != taskItem.OwnerID) && ((taskItem.CurrentPermissions & (uint)PermissionMask.Transfer) == 0)) 1225 if ((destAgent != taskItem.OwnerID) && ((taskItem.CurrentPermissions & (uint)PermissionMask.Transfer) == 0))
1194 { 1226 {
1227 message = "Item doesn't have the Transfer permission.";
1195 return null; 1228 return null;
1196 } 1229 }
1197 1230
@@ -1237,11 +1270,24 @@ namespace OpenSim.Region.Framework.Scenes
1237 agentItem.GroupPermissions = taskItem.GroupPermissions; 1270 agentItem.GroupPermissions = taskItem.GroupPermissions;
1238 } 1271 }
1239 1272
1273 message = null;
1274 return agentItem;
1275 }
1276
1277 /// <summary>
1278 /// If the task item is not-copyable then remove it from the prim.
1279 /// </summary>
1280 private void RemoveNonCopyTaskItemFromPrim(SceneObjectPart part, UUID itemId)
1281 {
1282 TaskInventoryItem taskItem = part.Inventory.GetInventoryItem(itemId);
1283 if (taskItem == null)
1284 return;
1285
1240 if (!Permissions.BypassPermissions()) 1286 if (!Permissions.BypassPermissions())
1241 { 1287 {
1242 if ((taskItem.CurrentPermissions & (uint)PermissionMask.Copy) == 0) 1288 if ((taskItem.CurrentPermissions & (uint)PermissionMask.Copy) == 0)
1243 { 1289 {
1244 if (taskItem.Type == 10) 1290 if (taskItem.Type == (int)AssetType.LSLText)
1245 { 1291 {
1246 part.RemoveScriptEvents(itemId); 1292 part.RemoveScriptEvents(itemId);
1247 EventManager.TriggerRemoveScript(part.LocalId, itemId); 1293 EventManager.TriggerRemoveScript(part.LocalId, itemId);
@@ -1250,8 +1296,6 @@ namespace OpenSim.Region.Framework.Scenes
1250 part.Inventory.RemoveInventoryItem(itemId); 1296 part.Inventory.RemoveInventoryItem(itemId);
1251 } 1297 }
1252 } 1298 }
1253
1254 return agentItem;
1255 } 1299 }
1256 1300
1257 /// <summary> 1301 /// <summary>
@@ -1261,19 +1305,22 @@ namespace OpenSim.Region.Framework.Scenes
1261 /// <param name="folderID"></param> 1305 /// <param name="folderID"></param>
1262 /// <param name="part"></param> 1306 /// <param name="part"></param>
1263 /// <param name="itemID"></param> 1307 /// <param name="itemID"></param>
1264 public InventoryItemBase MoveTaskInventoryItem(IClientAPI remoteClient, UUID folderId, SceneObjectPart part, UUID itemId) 1308 public InventoryItemBase MoveTaskInventoryItem(IClientAPI remoteClient, UUID folderId, SceneObjectPart part, UUID itemId, out string message)
1265 { 1309 {
1266 m_log.DebugFormat( 1310 m_log.DebugFormat(
1267 "[PRIM INVENTORY]: Adding item {0} from {1} to folder {2} for {3}", 1311 "[PRIM INVENTORY]: Adding item {0} from {1} to folder {2} for {3}",
1268 itemId, part.Name, folderId, remoteClient.Name); 1312 itemId, part.Name, folderId, remoteClient.Name);
1269 1313
1270 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(remoteClient.AgentId, part, itemId); 1314 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(remoteClient.AgentId, part, itemId, out message);
1271
1272 if (agentItem == null) 1315 if (agentItem == null)
1273 return null; 1316 return null;
1274 1317
1275 agentItem.Folder = folderId; 1318 agentItem.Folder = folderId;
1276 AddInventoryItem(remoteClient, agentItem); 1319 AddInventoryItem(remoteClient, agentItem);
1320
1321 RemoveNonCopyTaskItemFromPrim(part, itemId);
1322
1323 message = null;
1277 return agentItem; 1324 return agentItem;
1278 } 1325 }
1279 1326
@@ -1324,7 +1371,11 @@ namespace OpenSim.Region.Framework.Scenes
1324 return; 1371 return;
1325 } 1372 }
1326 1373
1327 MoveTaskInventoryItem(remoteClient, folderId, part, itemId); 1374 string message;
1375 InventoryItemBase item = MoveTaskInventoryItem(remoteClient, folderId, part, itemId, out message);
1376
1377 if (item == null)
1378 remoteClient.SendAgentAlertMessage(message, false);
1328 } 1379 }
1329 1380
1330 /// <summary> 1381 /// <summary>
@@ -1338,17 +1389,17 @@ namespace OpenSim.Region.Framework.Scenes
1338 /// </param> 1389 /// </param>
1339 /// <param name="part"></param> 1390 /// <param name="part"></param>
1340 /// <param name="itemID"></param> 1391 /// <param name="itemID"></param>
1341 public InventoryItemBase MoveTaskInventoryItem(UUID avatarId, UUID folderId, SceneObjectPart part, UUID itemId) 1392 public InventoryItemBase MoveTaskInventoryItem(UUID avatarId, UUID folderId, SceneObjectPart part, UUID itemId, out string message)
1342 { 1393 {
1343 ScenePresence avatar; 1394 ScenePresence avatar;
1344 1395
1345 if (TryGetScenePresence(avatarId, out avatar)) 1396 if (TryGetScenePresence(avatarId, out avatar))
1346 { 1397 {
1347 return MoveTaskInventoryItem(avatar.ControllingClient, folderId, part, itemId); 1398 return MoveTaskInventoryItem(avatar.ControllingClient, folderId, part, itemId, out message);
1348 } 1399 }
1349 else 1400 else
1350 { 1401 {
1351 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(avatarId, part, itemId); 1402 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(avatarId, part, itemId, out message);
1352 1403
1353 if (agentItem == null) 1404 if (agentItem == null)
1354 return null; 1405 return null;
@@ -1357,6 +1408,8 @@ namespace OpenSim.Region.Framework.Scenes
1357 1408
1358 AddInventoryItem(agentItem); 1409 AddInventoryItem(agentItem);
1359 1410
1411 RemoveNonCopyTaskItemFromPrim(part, itemId);
1412
1360 return agentItem; 1413 return agentItem;
1361 } 1414 }
1362 } 1415 }
@@ -1462,6 +1515,11 @@ namespace OpenSim.Region.Framework.Scenes
1462 1515
1463 public UUID MoveTaskInventoryItems(UUID destID, string category, SceneObjectPart host, List<UUID> items) 1516 public UUID MoveTaskInventoryItems(UUID destID, string category, SceneObjectPart host, List<UUID> items)
1464 { 1517 {
1518 ScenePresence avatar;
1519 IClientAPI remoteClient = null;
1520 if (TryGetScenePresence(destID, out avatar))
1521 remoteClient = avatar.ControllingClient;
1522
1465 InventoryFolderBase rootFolder = InventoryService.GetRootFolder(destID); 1523 InventoryFolderBase rootFolder = InventoryService.GetRootFolder(destID);
1466 1524
1467 UUID newFolderID = UUID.Random(); 1525 UUID newFolderID = UUID.Random();
@@ -1471,26 +1529,28 @@ namespace OpenSim.Region.Framework.Scenes
1471 1529
1472 foreach (UUID itemID in items) 1530 foreach (UUID itemID in items)
1473 { 1531 {
1474 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(destID, host, itemID); 1532 string message;
1533 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(destID, host, itemID, out message);
1475 1534
1476 if (agentItem != null) 1535 if (agentItem != null)
1477 { 1536 {
1478 agentItem.Folder = newFolderID; 1537 agentItem.Folder = newFolderID;
1479 1538
1480 AddInventoryItem(agentItem); 1539 AddInventoryItem(agentItem);
1540
1541 RemoveNonCopyTaskItemFromPrim(host, itemID);
1542 }
1543 else
1544 {
1545 if (remoteClient != null)
1546 remoteClient.SendAgentAlertMessage(message, false);
1481 } 1547 }
1482 } 1548 }
1483 1549
1484 ScenePresence avatar = null; 1550 if (remoteClient != null)
1485 if (TryGetScenePresence(destID, out avatar))
1486 { 1551 {
1487 //profile.SendInventoryDecendents(avatar.ControllingClient, 1552 SendInventoryUpdate(remoteClient, rootFolder, true, false);
1488 // profile.RootFolder.ID, true, false); 1553 SendInventoryUpdate(remoteClient, newFolder, false, true);
1489 //profile.SendInventoryDecendents(avatar.ControllingClient,
1490 // newFolderID, false, true);
1491
1492 SendInventoryUpdate(avatar.ControllingClient, rootFolder, true, false);
1493 SendInventoryUpdate(avatar.ControllingClient, newFolder, false, true);
1494 } 1554 }
1495 1555
1496 return newFolderID; 1556 return newFolderID;