aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Services/UserAccountService/UserAccountService.cs43
1 files changed, 42 insertions, 1 deletions
diff --git a/OpenSim/Services/UserAccountService/UserAccountService.cs b/OpenSim/Services/UserAccountService/UserAccountService.cs
index f6b003a..a22754f 100644
--- a/OpenSim/Services/UserAccountService/UserAccountService.cs
+++ b/OpenSim/Services/UserAccountService/UserAccountService.cs
@@ -640,9 +640,11 @@ namespace OpenSim.Services.UserAccountService
640 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Creating default appearance items for {0}", principalID); 640 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Creating default appearance items for {0}", principalID);
641 641
642 InventoryFolderBase bodyPartsFolder = m_InventoryService.GetFolderForType(principalID, FolderType.BodyPart); 642 InventoryFolderBase bodyPartsFolder = m_InventoryService.GetFolderForType(principalID, FolderType.BodyPart);
643 // Get Current Outfit folder
644 InventoryFolderBase currentOutfitFolder = m_InventoryService.GetFolderForType(principalID, FolderType.CurrentOutfit);
643 645
644 InventoryItemBase eyes = new InventoryItemBase(UUID.Random(), principalID); 646 InventoryItemBase eyes = new InventoryItemBase(UUID.Random(), principalID);
645 eyes.AssetID = new UUID("4bb6fa4d-1cd2-498a-a84c-95c1a0e745a7"); 647 eyes.AssetID = AvatarWearable.DEFAULT_EYES_ASSET;
646 eyes.Name = "Default Eyes"; 648 eyes.Name = "Default Eyes";
647 eyes.CreatorId = principalID.ToString(); 649 eyes.CreatorId = principalID.ToString();
648 eyes.AssetType = (int)AssetType.Bodypart; 650 eyes.AssetType = (int)AssetType.Bodypart;
@@ -655,6 +657,7 @@ namespace OpenSim.Services.UserAccountService
655 eyes.NextPermissions = (uint)PermissionMask.All; 657 eyes.NextPermissions = (uint)PermissionMask.All;
656 eyes.Flags = (uint)WearableType.Eyes; 658 eyes.Flags = (uint)WearableType.Eyes;
657 m_InventoryService.AddItem(eyes); 659 m_InventoryService.AddItem(eyes);
660 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Eyes, eyes.Name, eyes.ID, principalID, currentOutfitFolder.ID);
658 661
659 InventoryItemBase shape = new InventoryItemBase(UUID.Random(), principalID); 662 InventoryItemBase shape = new InventoryItemBase(UUID.Random(), principalID);
660 shape.AssetID = AvatarWearable.DEFAULT_BODY_ASSET; 663 shape.AssetID = AvatarWearable.DEFAULT_BODY_ASSET;
@@ -670,6 +673,7 @@ namespace OpenSim.Services.UserAccountService
670 shape.NextPermissions = (uint)PermissionMask.All; 673 shape.NextPermissions = (uint)PermissionMask.All;
671 shape.Flags = (uint)WearableType.Shape; 674 shape.Flags = (uint)WearableType.Shape;
672 m_InventoryService.AddItem(shape); 675 m_InventoryService.AddItem(shape);
676 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Shape, shape.Name, shape.ID, principalID, currentOutfitFolder.ID);
673 677
674 InventoryItemBase skin = new InventoryItemBase(UUID.Random(), principalID); 678 InventoryItemBase skin = new InventoryItemBase(UUID.Random(), principalID);
675 skin.AssetID = AvatarWearable.DEFAULT_SKIN_ASSET; 679 skin.AssetID = AvatarWearable.DEFAULT_SKIN_ASSET;
@@ -685,6 +689,7 @@ namespace OpenSim.Services.UserAccountService
685 skin.NextPermissions = (uint)PermissionMask.All; 689 skin.NextPermissions = (uint)PermissionMask.All;
686 skin.Flags = (uint)WearableType.Skin; 690 skin.Flags = (uint)WearableType.Skin;
687 m_InventoryService.AddItem(skin); 691 m_InventoryService.AddItem(skin);
692 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Skin, skin.Name, skin.ID, principalID, currentOutfitFolder.ID);
688 693
689 InventoryItemBase hair = new InventoryItemBase(UUID.Random(), principalID); 694 InventoryItemBase hair = new InventoryItemBase(UUID.Random(), principalID);
690 hair.AssetID = AvatarWearable.DEFAULT_HAIR_ASSET; 695 hair.AssetID = AvatarWearable.DEFAULT_HAIR_ASSET;
@@ -700,6 +705,7 @@ namespace OpenSim.Services.UserAccountService
700 hair.NextPermissions = (uint)PermissionMask.All; 705 hair.NextPermissions = (uint)PermissionMask.All;
701 hair.Flags = (uint)WearableType.Hair; 706 hair.Flags = (uint)WearableType.Hair;
702 m_InventoryService.AddItem(hair); 707 m_InventoryService.AddItem(hair);
708 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Hair, hair.Name, hair.ID, principalID, currentOutfitFolder.ID);
703 709
704 InventoryFolderBase clothingFolder = m_InventoryService.GetFolderForType(principalID, FolderType.Clothing); 710 InventoryFolderBase clothingFolder = m_InventoryService.GetFolderForType(principalID, FolderType.Clothing);
705 711
@@ -717,6 +723,7 @@ namespace OpenSim.Services.UserAccountService
717 shirt.NextPermissions = (uint)PermissionMask.All; 723 shirt.NextPermissions = (uint)PermissionMask.All;
718 shirt.Flags = (uint)WearableType.Shirt; 724 shirt.Flags = (uint)WearableType.Shirt;
719 m_InventoryService.AddItem(shirt); 725 m_InventoryService.AddItem(shirt);
726 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Shirt, shirt.Name, shirt.ID, principalID, currentOutfitFolder.ID);
720 727
721 InventoryItemBase pants = new InventoryItemBase(UUID.Random(), principalID); 728 InventoryItemBase pants = new InventoryItemBase(UUID.Random(), principalID);
722 pants.AssetID = AvatarWearable.DEFAULT_PANTS_ASSET; 729 pants.AssetID = AvatarWearable.DEFAULT_PANTS_ASSET;
@@ -732,6 +739,7 @@ namespace OpenSim.Services.UserAccountService
732 pants.NextPermissions = (uint)PermissionMask.All; 739 pants.NextPermissions = (uint)PermissionMask.All;
733 pants.Flags = (uint)WearableType.Pants; 740 pants.Flags = (uint)WearableType.Pants;
734 m_InventoryService.AddItem(pants); 741 m_InventoryService.AddItem(pants);
742 CreateCurrentOutfitLink((int)InventoryType.Wearable, (uint)WearableType.Pants, pants.Name, pants.ID, principalID, currentOutfitFolder.ID);
735 743
736 if (m_AvatarService != null) 744 if (m_AvatarService != null)
737 { 745 {
@@ -815,6 +823,8 @@ namespace OpenSim.Services.UserAccountService
815 { 823 {
816 // Get Clothing folder of receiver 824 // Get Clothing folder of receiver
817 InventoryFolderBase destinationFolder = m_InventoryService.GetFolderForType(destination, FolderType.Clothing); 825 InventoryFolderBase destinationFolder = m_InventoryService.GetFolderForType(destination, FolderType.Clothing);
826 // Get Current Outfit folder
827 InventoryFolderBase currentOutfitFolder = m_InventoryService.GetFolderForType(destination, FolderType.CurrentOutfit);
818 828
819 if (destinationFolder == null) 829 if (destinationFolder == null)
820 throw new Exception("Cannot locate folder(s)"); 830 throw new Exception("Cannot locate folder(s)");
@@ -841,6 +851,7 @@ namespace OpenSim.Services.UserAccountService
841 for (int i = 0; i < wearables.Length; i++) 851 for (int i = 0; i < wearables.Length; i++)
842 { 852 {
843 wearable = wearables[i]; 853 wearable = wearables[i];
854 m_log.DebugFormat("[XXX]: Getting item {0} from avie {1}", wearable[0].ItemID, source);
844 if (wearable[0].ItemID != UUID.Zero) 855 if (wearable[0].ItemID != UUID.Zero)
845 { 856 {
846 // Get inventory item and copy it 857 // Get inventory item and copy it
@@ -878,6 +889,9 @@ namespace OpenSim.Services.UserAccountService
878 AvatarWearable newWearable = new AvatarWearable(); 889 AvatarWearable newWearable = new AvatarWearable();
879 newWearable.Wear(destinationItem.ID, wearable[0].AssetID); 890 newWearable.Wear(destinationItem.ID, wearable[0].AssetID);
880 avatarAppearance.SetWearable(i, newWearable); 891 avatarAppearance.SetWearable(i, newWearable);
892
893 // Add to Current Outfit
894 CreateCurrentOutfitLink((int)InventoryType.Wearable, item.Flags, item.Name, destinationItem.ID, destination, currentOutfitFolder.ID);
881 } 895 }
882 else 896 else
883 { 897 {
@@ -930,6 +944,9 @@ namespace OpenSim.Services.UserAccountService
930 // Attach item 944 // Attach item
931 avatarAppearance.SetAttachment(attachpoint, destinationItem.ID, destinationItem.AssetID); 945 avatarAppearance.SetAttachment(attachpoint, destinationItem.ID, destinationItem.AssetID);
932 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Attached {0}", destinationItem.ID); 946 m_log.DebugFormat("[USER ACCOUNT SERVICE]: Attached {0}", destinationItem.ID);
947
948 // Add to Current Outfit
949 CreateCurrentOutfitLink(destinationItem.InvType, item.Flags, item.Name, destinationItem.ID, destination, currentOutfitFolder.ID);
933 } 950 }
934 else 951 else
935 { 952 {
@@ -939,6 +956,30 @@ namespace OpenSim.Services.UserAccountService
939 } 956 }
940 } 957 }
941 958
959 protected void CreateCurrentOutfitLink(int invType, uint itemType, string name, UUID itemID, UUID userID, UUID currentOutfitFolderUUID)
960 {
961 UUID LinkInvItem = UUID.Random();
962 InventoryItemBase itembase = new InventoryItemBase(LinkInvItem, userID)
963 {
964 AssetID = itemID,
965 AssetType = (int)AssetType.Link,
966 CreatorId = userID.ToString(),
967 InvType = invType,
968 Description = "",
969 //Folder = m_InventoryService.GetFolderForType(userID, FolderType.CurrentOutfit).ID,
970 Folder = currentOutfitFolderUUID,
971 Flags = itemType,
972 Name = name,
973 BasePermissions = (uint)PermissionMask.Copy,
974 CurrentPermissions = (uint)PermissionMask.Copy,
975 EveryOnePermissions = (uint)PermissionMask.Copy,
976 GroupPermissions = (uint)PermissionMask.Copy,
977 NextPermissions = (uint)PermissionMask.Copy
978 };
979
980 m_InventoryService.AddItem(itembase);
981 }
982
942 /// <summary> 983 /// <summary>
943 /// Apply next owner permissions. 984 /// Apply next owner permissions.
944 /// </summary> 985 /// </summary>