aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Services/UserAccountService/UserAccountService.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Services/UserAccountService/UserAccountService.cs')
-rw-r--r--OpenSim/Services/UserAccountService/UserAccountService.cs48
1 files changed, 31 insertions, 17 deletions
diff --git a/OpenSim/Services/UserAccountService/UserAccountService.cs b/OpenSim/Services/UserAccountService/UserAccountService.cs
index 95c9e57..880517c 100644
--- a/OpenSim/Services/UserAccountService/UserAccountService.cs
+++ b/OpenSim/Services/UserAccountService/UserAccountService.cs
@@ -825,7 +825,6 @@ namespace OpenSim.Services.UserAccountService
825 return; 825 return;
826 } 826 }
827 827
828
829 try 828 try
830 { 829 {
831 CopyWearablesAndAttachments(destinationAgent, modelAccount.PrincipalID, modelAppearance); 830 CopyWearablesAndAttachments(destinationAgent, modelAccount.PrincipalID, modelAppearance);
@@ -849,19 +848,24 @@ namespace OpenSim.Services.UserAccountService
849 /// </summary> 848 /// </summary>
850 private void CopyWearablesAndAttachments(UUID destination, UUID source, AvatarAppearance avatarAppearance) 849 private void CopyWearablesAndAttachments(UUID destination, UUID source, AvatarAppearance avatarAppearance)
851 { 850 {
851
852 AvatarWearable[] wearables = avatarAppearance.Wearables;
853 if(wearables.Length == 0)
854 throw new Exception("Model does not have wearables");
855
852 // Get Clothing folder of receiver 856 // Get Clothing folder of receiver
853 InventoryFolderBase destinationFolder = m_InventoryService.GetFolderForType(destination, FolderType.Clothing); 857 InventoryFolderBase destinationFolder = m_InventoryService.GetFolderForType(destination, FolderType.Clothing);
854 // Get Current Outfit folder
855 InventoryFolderBase currentOutfitFolder = m_InventoryService.GetFolderForType(destination, FolderType.CurrentOutfit);
856 858
857 if (destinationFolder == null) 859 if (destinationFolder == null)
858 throw new Exception("Cannot locate folder(s)"); 860 throw new Exception("Cannot locate new clothing folder(s)");
859 861
860 // Missing destination folder? This should *never* be the case 862 // Get Current Outfit folder
863 InventoryFolderBase currentOutfitFolder = m_InventoryService.GetFolderForType(destination, FolderType.CurrentOutfit);
864
865 // wrong destination folder type? create new
861 if (destinationFolder.Type != (short)FolderType.Clothing) 866 if (destinationFolder.Type != (short)FolderType.Clothing)
862 { 867 {
863 destinationFolder = new InventoryFolderBase(); 868 destinationFolder = new InventoryFolderBase();
864
865 destinationFolder.ID = UUID.Random(); 869 destinationFolder.ID = UUID.Random();
866 destinationFolder.Name = "Clothing"; 870 destinationFolder.Name = "Clothing";
867 destinationFolder.Owner = destination; 871 destinationFolder.Owner = destination;
@@ -869,21 +873,31 @@ namespace OpenSim.Services.UserAccountService
869 destinationFolder.ParentID = m_InventoryService.GetRootFolder(destination).ID; 873 destinationFolder.ParentID = m_InventoryService.GetRootFolder(destination).ID;
870 destinationFolder.Version = 1; 874 destinationFolder.Version = 1;
871 m_InventoryService.AddFolder(destinationFolder); // store base record 875 m_InventoryService.AddFolder(destinationFolder); // store base record
872 m_log.ErrorFormat("[USER ACCOUNT SERVICE]: Created folder for destination {0}", source); 876 m_log.ErrorFormat("[USER ACCOUNT SERVICE]: Created folder for destination {0} Clothing", source);
873 } 877 }
874 878
875 // Wearables 879 // Wearables
876 AvatarWearable[] wearables = avatarAppearance.Wearables; 880 AvatarWearable basewearable;
877 AvatarWearable wearable; 881 AvatarWearable newbasewearable;
882 WearableItem wearable;
878 883
884 // copy wearables creating new inventory entries
885 // converting from v1.0 wearables to v2.0
879 for (int i = 0; i < wearables.Length; i++) 886 for (int i = 0; i < wearables.Length; i++)
880 { 887 {
881 wearable = wearables[i]; 888 basewearable = wearables[i];
882 if (wearable[0].ItemID != UUID.Zero) 889 if(basewearable == null || basewearable.Count == 0)
890 continue;
891
892 newbasewearable = new AvatarWearable();
893 int j = basewearable.Count - 1;
894
895 wearable = basewearable[j];
896 if (wearable.ItemID != UUID.Zero)
883 { 897 {
884 m_log.DebugFormat("[XXX]: Getting item {0} from avie {1}", wearable[0].ItemID, source); 898 m_log.DebugFormat("[XXX]: Getting item {0} from avie {1}", wearable.ItemID, source);
885 // Get inventory item and copy it 899 // Get inventory item and copy it
886 InventoryItemBase item = m_InventoryService.GetItem(source, wearable[0].ItemID); 900 InventoryItemBase item = m_InventoryService.GetItem(source, wearable.ItemID);
887 901
888 if(item != null && item.AssetType == (int)AssetType.Link) 902 if(item != null && item.AssetType == (int)AssetType.Link)
889 { 903 {
@@ -922,22 +936,22 @@ namespace OpenSim.Services.UserAccountService
922 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Added item {0} to folder {1}", destinationItem.ID, destinationFolder.ID); 936 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Added item {0} to folder {1}", destinationItem.ID, destinationFolder.ID);
923 937
924 // Wear item 938 // Wear item
925 AvatarWearable newWearable = new AvatarWearable(); 939 newbasewearable.Add(destinationItem.ID,wearable.AssetID);
926 newWearable.Wear(destinationItem.ID, wearable[0].AssetID);
927 avatarAppearance.SetWearable(i, newWearable);
928 940
929 // Add to Current Outfit 941 // Add to Current Outfit
930 CreateCurrentOutfitLink((int)InventoryType.Wearable, item.Flags, item.Name, destinationItem.ID, destination, currentOutfitFolder.ID); 942 CreateCurrentOutfitLink((int)InventoryType.Wearable, item.Flags, item.Name, destinationItem.ID, destination, currentOutfitFolder.ID);
931 } 943 }
932 else 944 else
933 { 945 {
934 m_log.WarnFormat("[USER ACCOUNT SERVICE]: Error transferring {0} to folder {1}", wearable[0].ItemID, destinationFolder.ID); 946 m_log.WarnFormat("[USER ACCOUNT SERVICE]: Error transferring {0} to folder {1}", wearable.ItemID, destinationFolder.ID);
935 } 947 }
936 } 948 }
949 avatarAppearance.SetWearable(i, newbasewearable);
937 } 950 }
938 951
939 // Attachments 952 // Attachments
940 List<AvatarAttachment> attachments = avatarAppearance.GetAttachments(); 953 List<AvatarAttachment> attachments = avatarAppearance.GetAttachments();
954 avatarAppearance.ClearAttachments();
941 955
942 foreach (AvatarAttachment attachment in attachments) 956 foreach (AvatarAttachment attachment in attachments)
943 { 957 {