aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorCharles Krinke2008-06-26 02:46:29 +0000
committerCharles Krinke2008-06-26 02:46:29 +0000
commit1cd6b71b60d093b451ba03881ee31efd3eb29a50 (patch)
tree71e51114e772d9d9121a449a684e9c7f8a8e5a16
parentMinor refactoring of POS. Adds a Util.Clamp(x, min, max) function. (diff)
downloadopensim-SC-1cd6b71b60d093b451ba03881ee31efd3eb29a50.zip
opensim-SC-1cd6b71b60d093b451ba03881ee31efd3eb29a50.tar.gz
opensim-SC-1cd6b71b60d093b451ba03881ee31efd3eb29a50.tar.bz2
opensim-SC-1cd6b71b60d093b451ba03881ee31efd3eb29a50.tar.xz
Mantis#1594. Thank you, Melanie for a patch that:
Fixes: - Wearable icon and name sreset to default on copy/paste - Cache is not updated when renaming/moving folders - Partial refactor to make inventory less dependen on AssetBase having a "Name" field - Add llGiveInventoryList() function
-rw-r--r--OpenSim/Framework/Communications/Cache/CachedUserInfo.cs11
-rw-r--r--OpenSim/Region/Environment/Scenes/Scene.Inventory.cs142
-rw-r--r--OpenSim/Region/ScriptEngine/Common/LSL_BuiltIn_Commands.cs37
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs38
4 files changed, 176 insertions, 52 deletions
diff --git a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
index d010bd5..3127bd6 100644
--- a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
+++ b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
@@ -380,6 +380,13 @@ namespace OpenSim.Framework.Communications.Cache
380 baseFolder.Version = RootFolder.Version; 380 baseFolder.Version = RootFolder.Version;
381 381
382 m_commsManager.InventoryService.UpdateFolder(baseFolder); 382 m_commsManager.InventoryService.UpdateFolder(baseFolder);
383
384 InventoryFolderImpl folder=RootFolder.FindFolder(folderID);
385 if(folder != null)
386 {
387 folder.Name = name;
388 folder.ParentID = parentID;
389 }
383 } 390 }
384 else 391 else
385 { 392 {
@@ -416,6 +423,10 @@ namespace OpenSim.Framework.Communications.Cache
416 423
417 m_commsManager.InventoryService.MoveFolder(baseFolder); 424 m_commsManager.InventoryService.MoveFolder(baseFolder);
418 425
426 InventoryFolderImpl folder=RootFolder.FindFolder(folderID);
427 if(folder != null)
428 folder.ParentID = parentID;
429
419 return true; 430 return true;
420 } 431 }
421 else 432 else
diff --git a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
index b076855..05c0a28 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
@@ -88,61 +88,52 @@ namespace OpenSim.Region.Environment.Scenes
88 } 88 }
89 } 89 }
90 90
91 /// <summary> 91 public void AddInventoryItem(LLUUID AgentID, InventoryItemBase item)
92 /// Add an inventory item to an avatar's inventory.
93 /// </summary>
94 /// <param name="remoteClient">The remote client controlling the avatar</param>
95 /// <param name="item">The item. This structure contains all the item metadata, including the folder
96 /// in which the item is to be placed.</param>
97 public void AddInventoryItem(IClientAPI remoteClient, InventoryItemBase item)
98 { 92 {
99 CachedUserInfo userInfo 93 CachedUserInfo userInfo
100 = CommsManager.UserProfileCacheService.GetUserDetails(remoteClient.AgentId); 94 = CommsManager.UserProfileCacheService.GetUserDetails(AgentID);
101 95
102 if (userInfo != null) 96 if (userInfo != null)
103 { 97 {
104 userInfo.AddItem(item); 98 userInfo.AddItem(item);
105 remoteClient.SendInventoryItemCreateUpdate(item);
106 99
107 int userlevel = 0; 100 int userlevel = 0;
108 if (ExternalChecks.ExternalChecksCanBeGodLike(remoteClient.AgentId)) 101 if (ExternalChecks.ExternalChecksCanBeGodLike(AgentID))
109 { 102 {
110 userlevel = 1; 103 userlevel = 1;
111 } 104 }
112 if (m_regInfo.MasterAvatarAssignedUUID == remoteClient.AgentId) 105 if (m_regInfo.MasterAvatarAssignedUUID == AgentID)
113 { 106 {
114 userlevel = 2; 107 userlevel = 2;
115 } 108 }
116 EventManager.TriggerOnNewInventoryItemUploadComplete(remoteClient.AgentId, item.AssetID, item.Name, userlevel); 109 EventManager.TriggerOnNewInventoryItemUploadComplete(AgentID, item.AssetID, item.Name, userlevel);
117 } 110 }
118 else 111 else
119 { 112 {
120 m_log.ErrorFormat( 113 m_log.ErrorFormat(
121 "[AGENT INVENTORY]: Agent {0} {1} was not found for add of item {2} {3}", 114 "[AGENT INVENTORY]: Agent {1} was not found for add of item {2} {3}",
122 remoteClient.Name, remoteClient.AgentId, item.Name, item.ID); 115 AgentID, item.Name, item.ID);
123 116
124 return; 117 return;
125 } 118 }
126 } 119 }
127 120
128 /// <summary> 121 /// <summary>
129 /// <see>AddInventoryItem(LLUUID, InventoryItemBase)</see> 122 /// Add an inventory item to an avatar's inventory.
130 /// </summary> 123 /// </summary>
131 /// <param name="avatarId">The ID of the avatar</param> 124 /// <param name="remoteClient">The remote client controlling the avatar</param>
132 /// <param name="item">The item. This structure contains all the item metadata, including the folder 125 /// <param name="item">The item. This structure contains all the item metadata, including the folder
133 /// in which the item is to be placed.</param> 126 /// in which the item is to be placed.</param>
134 public void AddInventoryItem(LLUUID avatarId, InventoryItemBase item) 127 public void AddInventoryItem(IClientAPI remoteClient, InventoryItemBase item)
135 { 128 {
136 ScenePresence avatar; 129 CachedUserInfo userInfo
130 = CommsManager.UserProfileCacheService.GetUserDetails(remoteClient.AgentId);
137 131
138 if (!TryGetAvatar(avatarId, out avatar)) 132 if (userInfo != null)
139 { 133 {
140 m_log.ErrorFormat( 134 AddInventoryItem(remoteClient.AgentId, item);
141 "[AGENT INVENTORY]: Could not find avatar {0} to add inventory item", avatarId); 135 remoteClient.SendInventoryItemCreateUpdate(item);
142 return;
143 } 136 }
144
145 AddInventoryItem(avatar.ControllingClient, item);
146 } 137 }
147 138
148 /// <summary> 139 /// <summary>
@@ -517,13 +508,13 @@ namespace OpenSim.Region.Environment.Scenes
517 if (remoteClient.AgentId == oldAgentID) 508 if (remoteClient.AgentId == oldAgentID)
518 { 509 {
519 CreateNewInventoryItem( 510 CreateNewInventoryItem(
520 remoteClient, newFolderID, callbackID, asset, (sbyte)item.InvType, 511 remoteClient, newFolderID, item.Name, item.Flags, callbackID, asset, (sbyte)item.InvType,
521 item.BasePermissions, item.CurrentPermissions, item.EveryOnePermissions, item.NextPermissions); 512 item.BasePermissions, item.CurrentPermissions, item.EveryOnePermissions, item.NextPermissions);
522 } 513 }
523 else 514 else
524 { 515 {
525 CreateNewInventoryItem( 516 CreateNewInventoryItem(
526 remoteClient, newFolderID, callbackID, asset, (sbyte)item.InvType, 517 remoteClient, newFolderID, item.Name, item.Flags, callbackID, asset, (sbyte)item.InvType,
527 item.NextPermissions, item.NextPermissions, item.EveryOnePermissions & item.NextPermissions, item.NextPermissions); 518 item.NextPermissions, item.NextPermissions, item.EveryOnePermissions & item.NextPermissions, item.NextPermissions);
528 } 519 }
529 } 520 }
@@ -619,11 +610,11 @@ namespace OpenSim.Region.Environment.Scenes
619 /// <param name="asset"></param> 610 /// <param name="asset"></param>
620 /// <param name="invType"></param> 611 /// <param name="invType"></param>
621 /// <param name="nextOwnerMask"></param> 612 /// <param name="nextOwnerMask"></param>
622 private void CreateNewInventoryItem(IClientAPI remoteClient, LLUUID folderID, uint callbackID, 613 private void CreateNewInventoryItem(IClientAPI remoteClient, LLUUID folderID, string name, uint flags, uint callbackID,
623 AssetBase asset, sbyte invType, uint nextOwnerMask) 614 AssetBase asset, sbyte invType, uint nextOwnerMask)
624 { 615 {
625 CreateNewInventoryItem( 616 CreateNewInventoryItem(
626 remoteClient, folderID, callbackID, asset, invType, 617 remoteClient, folderID, name, flags, callbackID, asset, invType,
627 (uint)PermissionMask.All, (uint)PermissionMask.All, 0, nextOwnerMask); 618 (uint)PermissionMask.All, (uint)PermissionMask.All, 0, nextOwnerMask);
628 } 619 }
629 620
@@ -637,7 +628,7 @@ namespace OpenSim.Region.Environment.Scenes
637 /// <param name="invType"></param> 628 /// <param name="invType"></param>
638 /// <param name="nextOwnerMask"></param> 629 /// <param name="nextOwnerMask"></param>
639 private void CreateNewInventoryItem( 630 private void CreateNewInventoryItem(
640 IClientAPI remoteClient, LLUUID folderID, uint callbackID, AssetBase asset, sbyte invType, 631 IClientAPI remoteClient, LLUUID folderID, string name, uint flags, uint callbackID, AssetBase asset, sbyte invType,
641 uint baseMask, uint currentMask, uint everyoneMask, uint nextOwnerMask) 632 uint baseMask, uint currentMask, uint everyoneMask, uint nextOwnerMask)
642 { 633 {
643 CachedUserInfo userInfo 634 CachedUserInfo userInfo
@@ -651,7 +642,8 @@ namespace OpenSim.Region.Environment.Scenes
651 item.ID = LLUUID.Random(); 642 item.ID = LLUUID.Random();
652 item.AssetID = asset.FullID; 643 item.AssetID = asset.FullID;
653 item.Description = asset.Description; 644 item.Description = asset.Description;
654 item.Name = asset.Name; 645 item.Name = name;
646 item.Flags = flags;
655 item.AssetType = asset.Type; 647 item.AssetType = asset.Type;
656 item.InvType = invType; 648 item.InvType = invType;
657 item.Folder = folderID; 649 item.Folder = folderID;
@@ -715,7 +707,7 @@ namespace OpenSim.Region.Environment.Scenes
715 AssetBase asset = CreateAsset(name, description, assetType, data); 707 AssetBase asset = CreateAsset(name, description, assetType, data);
716 AssetCache.AddAsset(asset); 708 AssetCache.AddAsset(asset);
717 709
718 CreateNewInventoryItem(remoteClient, folderID, callbackID, asset, invType, nextOwnerMask); 710 CreateNewInventoryItem(remoteClient, folderID, asset.Name, 0, callbackID, asset, invType, nextOwnerMask);
719 } 711 }
720 else 712 else
721 { 713 {
@@ -864,38 +856,29 @@ namespace OpenSim.Region.Environment.Scenes
864 } 856 }
865 } 857 }
866 858
867 /// <summary> 859 private InventoryItemBase CreateAgentInventoryItemFromTask(LLUUID destAgent, SceneObjectPart part, LLUUID itemId)
868 /// Move the given item in the given prim to a folder in the client's inventory
869 /// </summary>
870 /// <param name="remoteClient"></param>
871 /// <param name="folderID"></param>
872 /// <param name="part"></param>
873 /// <param name="itemID"></param>
874 public void MoveTaskInventoryItem(IClientAPI remoteClient, LLUUID folderId, SceneObjectPart part, LLUUID itemId)
875 { 860 {
876
877 TaskInventoryItem taskItem = part.GetInventoryItem(itemId); 861 TaskInventoryItem taskItem = part.GetInventoryItem(itemId);
878 862
879 if (null == taskItem) 863 if (null == taskItem)
880 { 864 {
881 // Console already notified of error in GetInventoryItem 865 // Console already notified of error in GetInventoryItem
882 return; 866 return null;
883 } 867 }
884 868
885 InventoryItemBase agentItem = new InventoryItemBase(); 869 InventoryItemBase agentItem = new InventoryItemBase();
886 870
887 agentItem.ID = LLUUID.Random(); 871 agentItem.ID = LLUUID.Random();
888 agentItem.Creator = taskItem.CreatorID; 872 agentItem.Creator = taskItem.CreatorID;
889 agentItem.Owner = remoteClient.AgentId; 873 agentItem.Owner = destAgent;
890 agentItem.AssetID = taskItem.AssetID; 874 agentItem.AssetID = taskItem.AssetID;
891 agentItem.Description = taskItem.Description; 875 agentItem.Description = taskItem.Description;
892 agentItem.Name = taskItem.Name; 876 agentItem.Name = taskItem.Name;
893 agentItem.AssetType = taskItem.Type; 877 agentItem.AssetType = taskItem.Type;
894 agentItem.InvType = taskItem.InvType; 878 agentItem.InvType = taskItem.InvType;
895 agentItem.Folder = folderId;
896 agentItem.Flags = taskItem.Flags; 879 agentItem.Flags = taskItem.Flags;
897 880
898 if ((remoteClient.AgentId != taskItem.OwnerID) && ExternalChecks.ExternalChecksPropagatePermissions()) 881 if ((destAgent != taskItem.OwnerID) && ExternalChecks.ExternalChecksPropagatePermissions())
899 { 882 {
900 agentItem.BasePermissions = taskItem.NextOwnerMask; 883 agentItem.BasePermissions = taskItem.NextOwnerMask;
901 agentItem.CurrentPermissions = taskItem.NextOwnerMask; 884 agentItem.CurrentPermissions = taskItem.NextOwnerMask;
@@ -910,13 +893,29 @@ namespace OpenSim.Region.Environment.Scenes
910 agentItem.EveryOnePermissions = taskItem.EveryoneMask; 893 agentItem.EveryOnePermissions = taskItem.EveryoneMask;
911 } 894 }
912 895
913 AddInventoryItem(remoteClient, agentItem);
914 if (!ExternalChecks.ExternalChecksBypassPermissions()) 896 if (!ExternalChecks.ExternalChecksBypassPermissions())
915 { 897 {
916 if ((taskItem.OwnerMask & (uint)PermissionMask.Copy) == 0) 898 if ((taskItem.OwnerMask & (uint)PermissionMask.Copy) == 0)
917 part.RemoveInventoryItem(itemId); 899 part.RemoveInventoryItem(itemId);
918 } 900 }
919 901
902 return agentItem;
903 }
904
905 /// <summary>
906 /// Move the given item in the given prim to a folder in the client's inventory
907 /// </summary>
908 /// <param name="remoteClient"></param>
909 /// <param name="folderID"></param>
910 /// <param name="part"></param>
911 /// <param name="itemID"></param>
912 public void MoveTaskInventoryItem(IClientAPI remoteClient, LLUUID folderId, SceneObjectPart part, LLUUID itemId)
913 {
914
915 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(remoteClient.AgentId, part, itemId);
916
917 agentItem.Folder = folderId;
918 AddInventoryItem(remoteClient, agentItem);
920 } 919 }
921 920
922 /// <summary> 921 /// <summary>
@@ -964,14 +963,22 @@ namespace OpenSim.Region.Environment.Scenes
964 963
965 if (TryGetAvatar(avatarId, out avatar)) 964 if (TryGetAvatar(avatarId, out avatar))
966 { 965 {
967 MoveTaskInventoryItem(avatar.ControllingClient, folderId, part, itemId); 966 MoveTaskInventoryItem(avatar.ControllingClient, folderId, part, itemId);
968 } 967 }
969 else 968 else
970 { 969 {
971 m_log.ErrorFormat( 970 CachedUserInfo profile = CommsManager.UserProfileCacheService.GetUserDetails(avatarId);
972 "[PRIM INVENTORY]: " + 971 if(profile == null || profile.RootFolder == null)
973 "Avatar {0} cannot be found to update its prim item asset", 972 {
974 avatarId); 973 m_log.ErrorFormat(
974 "[PRIM INVENTORY]: " +
975 "Avatar {0} cannot be found to add item",
976 avatarId);
977 }
978 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(avatarId, part, itemId);
979 agentItem.Folder = folderId;
980
981 AddInventoryItem(avatarId, agentItem);
975 } 982 }
976 } 983 }
977 984
@@ -1047,6 +1054,41 @@ namespace OpenSim.Region.Environment.Scenes
1047 1054
1048 } 1055 }
1049 1056
1057 public void MoveTaskInventoryItems(LLUUID destID, string category, SceneObjectPart host, List<LLUUID> items)
1058 {
1059 CachedUserInfo profile = CommsManager.UserProfileCacheService.GetUserDetails(destID);
1060 if(profile == null || profile.RootFolder == null)
1061 {
1062 m_log.ErrorFormat(
1063 "[PRIM INVENTORY]: " +
1064 "Avatar {0} cannot be found to add items",
1065 destID);
1066 return;
1067 }
1068
1069 LLUUID newFolderID = LLUUID.Random();
1070
1071 profile.CreateFolder(category, newFolderID, 0xffff, profile.RootFolder.ID);
1072
1073 foreach (LLUUID itemID in items)
1074 {
1075 InventoryItemBase agentItem = CreateAgentInventoryItemFromTask(destID, host, itemID);
1076 agentItem.Folder = newFolderID;
1077
1078 AddInventoryItem(destID, agentItem);
1079 }
1080
1081 ScenePresence avatar;
1082
1083 if (TryGetAvatar(destID, out avatar))
1084 {
1085 profile.SendInventoryDecendents(avatar.ControllingClient,
1086 profile.RootFolder.ID, true, false);
1087 profile.SendInventoryDecendents(avatar.ControllingClient,
1088 newFolderID, false, true);
1089 }
1090 }
1091
1050 /// <summary> 1092 /// <summary>
1051 /// Update an item in a prim (task) inventory. 1093 /// Update an item in a prim (task) inventory.
1052 /// This method does not handle scripts, <see>RezScript(IClientAPI, LLUUID, unit)</see> 1094 /// This method does not handle scripts, <see>RezScript(IClientAPI, LLUUID, unit)</see>
diff --git a/OpenSim/Region/ScriptEngine/Common/LSL_BuiltIn_Commands.cs b/OpenSim/Region/ScriptEngine/Common/LSL_BuiltIn_Commands.cs
index a9d1309..366b20c 100644
--- a/OpenSim/Region/ScriptEngine/Common/LSL_BuiltIn_Commands.cs
+++ b/OpenSim/Region/ScriptEngine/Common/LSL_BuiltIn_Commands.cs
@@ -4374,10 +4374,45 @@ namespace OpenSim.Region.ScriptEngine.Common
4374 NotImplemented("llGroundRepel"); 4374 NotImplemented("llGroundRepel");
4375 } 4375 }
4376 4376
4377 private LLUUID GetTaskInventoryItem(string name)
4378 {
4379 foreach (KeyValuePair<LLUUID, TaskInventoryItem> inv in m_host.TaskInventory)
4380 {
4381 if(inv.Value.Name == name)
4382 return inv.Key;
4383 }
4384 return LLUUID.Zero;
4385 }
4386
4377 public void llGiveInventoryList(string destination, string category, LSL_Types.list inventory) 4387 public void llGiveInventoryList(string destination, string category, LSL_Types.list inventory)
4378 { 4388 {
4379 m_host.AddScriptLPS(1); 4389 m_host.AddScriptLPS(1);
4380 NotImplemented("llGiveInventoryList"); 4390
4391 LLUUID destID;
4392 if(!LLUUID.TryParse(destination, out destID))
4393 return;
4394
4395 List<LLUUID> itemList = new List<LLUUID>();
4396
4397 foreach (Object item in inventory.Data)
4398 {
4399 LLUUID itemID;
4400 if(LLUUID.TryParse(item.ToString(), out itemID))
4401 {
4402 itemList.Add(itemID);
4403 }
4404 else
4405 {
4406 itemID = GetTaskInventoryItem(item.ToString());
4407 if(itemID != LLUUID.Zero)
4408 itemList.Add(itemID);
4409 }
4410 }
4411
4412 if(itemList.Count == 0)
4413 return;
4414
4415 m_ScriptEngine.World.MoveTaskInventoryItems(destID, category, m_host, itemList);
4381 } 4416 }
4382 4417
4383 public void llSetVehicleType(int type) 4418 public void llSetVehicleType(int type)
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index 57c1e02..1d4a72e 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -36,6 +36,7 @@ using Axiom.Math;
36using libsecondlife; 36using libsecondlife;
37using OpenSim; 37using OpenSim;
38using OpenSim.Framework; 38using OpenSim.Framework;
39using OpenSim.Framework.Communications.Cache;
39using OpenSim.Region.Environment; 40using OpenSim.Region.Environment;
40using OpenSim.Region.Environment.Interfaces; 41using OpenSim.Region.Environment.Interfaces;
41using OpenSim.Region.Environment.Modules.Avatar.Currency.SampleMoney; 42using OpenSim.Region.Environment.Modules.Avatar.Currency.SampleMoney;
@@ -4226,10 +4227,45 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
4226 NotImplemented("llGroundRepel"); 4227 NotImplemented("llGroundRepel");
4227 } 4228 }
4228 4229
4230 private LLUUID GetTaskInventoryItem(string name)
4231 {
4232 foreach (KeyValuePair<LLUUID, TaskInventoryItem> inv in m_host.TaskInventory)
4233 {
4234 if(inv.Value.Name == name)
4235 return inv.Key;
4236 }
4237 return LLUUID.Zero;
4238 }
4239
4229 public void llGiveInventoryList(string destination, string category, LSL_Types.list inventory) 4240 public void llGiveInventoryList(string destination, string category, LSL_Types.list inventory)
4230 { 4241 {
4231 m_host.AddScriptLPS(1); 4242 m_host.AddScriptLPS(1);
4232 NotImplemented("llGiveInventoryList"); 4243
4244 LLUUID destID;
4245 if(!LLUUID.TryParse(destination, out destID))
4246 return;
4247
4248 List<LLUUID> itemList = new List<LLUUID>();
4249
4250 foreach (Object item in inventory.Data)
4251 {
4252 LLUUID itemID;
4253 if(LLUUID.TryParse(item.ToString(), out itemID))
4254 {
4255 itemList.Add(itemID);
4256 }
4257 else
4258 {
4259 itemID = GetTaskInventoryItem(item.ToString());
4260 if(itemID != LLUUID.Zero)
4261 itemList.Add(itemID);
4262 }
4263 }
4264
4265 if(itemList.Count == 0)
4266 return;
4267
4268 m_ScriptEngine.World.MoveTaskInventoryItems(destID, category, m_host, itemList);
4233 } 4269 }
4234 4270
4235 public void llSetVehicleType(int type) 4271 public void llSetVehicleType(int type)