Part 2 of fixing inventory for client 1.19.1 (RC), inventory items should now show up.
Most likely still some problems and most like needs some more work (and still a couple of things to finish off).0.6.0-stable
parent
70e55205a1
commit
c04899b60a
|
@ -254,6 +254,66 @@ namespace OpenSim.Framework.Communications.Cache
|
||||||
folderID, remoteClient.Name);
|
folderID, remoteClient.Name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<InventoryItemBase> HandleFetchInventoryDescendentsCAPS(LLUUID agentID, LLUUID folderID, LLUUID ownerID,
|
||||||
|
bool fetchFolders, bool fetchItems, int sortOrder)
|
||||||
|
{
|
||||||
|
// XXX We're not handling sortOrder yet!
|
||||||
|
// with CAPS we are only return items in the folders at the moment
|
||||||
|
// need to find the format that sub folder details are sent in
|
||||||
|
// if (fetchItems)
|
||||||
|
// {
|
||||||
|
InventoryFolderImpl fold = null;
|
||||||
|
if (folderID == libraryRoot.folderID)
|
||||||
|
{
|
||||||
|
return libraryRoot.RequestListOfItems();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((fold = libraryRoot.HasSubFolder(folderID)) != null)
|
||||||
|
{
|
||||||
|
return fold.RequestListOfItems();
|
||||||
|
}
|
||||||
|
|
||||||
|
CachedUserInfo userProfile;
|
||||||
|
if (m_userProfiles.TryGetValue(agentID, out userProfile))
|
||||||
|
{
|
||||||
|
if (userProfile.RootFolder != null)
|
||||||
|
{
|
||||||
|
if (userProfile.RootFolder.folderID == folderID)
|
||||||
|
{
|
||||||
|
return userProfile.RootFolder.RequestListOfItems();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ((fold = userProfile.RootFolder.HasSubFolder(folderID)) != null)
|
||||||
|
{
|
||||||
|
return fold.RequestListOfItems();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_log.ErrorFormat("[INVENTORYCACHE]: Could not find root folder for user {0}", agentID.ToString());
|
||||||
|
|
||||||
|
return new List<InventoryItemBase>(); ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_log.ErrorFormat("[INVENTORYCACHE]: " +
|
||||||
|
"Could not find user profile for {0} for folder {1}",
|
||||||
|
agentID.ToString(), folderID);
|
||||||
|
return new List<InventoryItemBase>();
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we've reached this point then we couldn't find the folder, even though the client thinks
|
||||||
|
// it exists
|
||||||
|
m_log.ErrorFormat("[INVENTORYCACHE]: " +
|
||||||
|
"Could not find folder {0} for user {1}",
|
||||||
|
folderID, agentID.ToString());
|
||||||
|
// }
|
||||||
|
return new List<InventoryItemBase>();
|
||||||
|
}
|
||||||
|
|
||||||
public void HandlePurgeInventoryDescendents(IClientAPI remoteClient, LLUUID folderID)
|
public void HandlePurgeInventoryDescendents(IClientAPI remoteClient, LLUUID folderID)
|
||||||
{
|
{
|
||||||
// m_log.InfoFormat("[INVENTORYCACHE]: Purging folder {0} for {1} uuid {2}",
|
// m_log.InfoFormat("[INVENTORYCACHE]: Purging folder {0} for {1} uuid {2}",
|
||||||
|
|
|
@ -52,6 +52,9 @@ namespace OpenSim.Region.Capabilities
|
||||||
public delegate void TaskScriptUpdatedCallback(LLUUID userID, LLUUID itemID, LLUUID primID,
|
public delegate void TaskScriptUpdatedCallback(LLUUID userID, LLUUID itemID, LLUUID primID,
|
||||||
bool isScriptRunning, byte[] data);
|
bool isScriptRunning, byte[] data);
|
||||||
|
|
||||||
|
public delegate List<InventoryItemBase> FetchInventoryDescendentsCAPS(LLUUID agentID, LLUUID folderID, LLUUID ownerID,
|
||||||
|
bool fetchFolders, bool fetchItems, int sortOrder);
|
||||||
|
|
||||||
public class Caps
|
public class Caps
|
||||||
{
|
{
|
||||||
private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
@ -81,6 +84,9 @@ namespace OpenSim.Region.Capabilities
|
||||||
public NewInventoryItem AddNewInventoryItem = null;
|
public NewInventoryItem AddNewInventoryItem = null;
|
||||||
public ItemUpdatedCallback ItemUpdatedCall = null;
|
public ItemUpdatedCallback ItemUpdatedCall = null;
|
||||||
public TaskScriptUpdatedCallback TaskScriptUpdatedCall = null;
|
public TaskScriptUpdatedCallback TaskScriptUpdatedCall = null;
|
||||||
|
//
|
||||||
|
public FetchInventoryDescendentsCAPS CAPSFetchInventoryDescendents = null;
|
||||||
|
|
||||||
|
|
||||||
public Caps(AssetCache assetCache, BaseHttpServer httpServer, string httpListen, uint httpPort, string capsPath,
|
public Caps(AssetCache assetCache, BaseHttpServer httpServer, string httpListen, uint httpPort, string capsPath,
|
||||||
LLUUID agent, bool dumpAssetsToFile)
|
LLUUID agent, bool dumpAssetsToFile)
|
||||||
|
@ -191,14 +197,56 @@ namespace OpenSim.Region.Capabilities
|
||||||
LLSDInventoryDescendents reply = new LLSDInventoryDescendents();
|
LLSDInventoryDescendents reply = new LLSDInventoryDescendents();
|
||||||
LLSDInventoryFolderContents contents = new LLSDInventoryFolderContents();
|
LLSDInventoryFolderContents contents = new LLSDInventoryFolderContents();
|
||||||
contents.agent___id = m_agentID;
|
contents.agent___id = m_agentID;
|
||||||
contents.owner___id = m_agentID;
|
contents.owner___id = invFetch.owner_id;
|
||||||
contents.folder___id = invFetch.folder_id;
|
contents.folder___id = invFetch.folder_id;
|
||||||
contents.version = 1;
|
contents.version = 1; //FixMe
|
||||||
contents.descendents = 0;
|
contents.descendents = 0;
|
||||||
reply.folders.Array.Add(contents);
|
reply.folders.Array.Add(contents);
|
||||||
|
List<InventoryItemBase> itemList = null;
|
||||||
|
if (CAPSFetchInventoryDescendents != null)
|
||||||
|
{
|
||||||
|
itemList = CAPSFetchInventoryDescendents(m_agentID, invFetch.folder_id, invFetch.owner_id, invFetch.fetch_folders, invFetch.fetch_items, invFetch.sort_order);
|
||||||
|
}
|
||||||
|
if (itemList != null)
|
||||||
|
{
|
||||||
|
foreach (InventoryItemBase invItem in itemList)
|
||||||
|
{
|
||||||
|
contents.items.Array.Add(ConvertInventoryItem(invItem));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
contents.descendents = contents.items.Array.Count;
|
||||||
return reply;
|
return reply;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private LLSDInventoryItem ConvertInventoryItem(InventoryItemBase invItem)
|
||||||
|
{
|
||||||
|
LLSDInventoryItem llsdItem = new LLSDInventoryItem();
|
||||||
|
llsdItem.asset_id = invItem.assetID;
|
||||||
|
llsdItem.created_at = 1000;
|
||||||
|
llsdItem.desc = invItem.inventoryDescription;
|
||||||
|
llsdItem.flags = 0;
|
||||||
|
llsdItem.item_id = invItem.inventoryID;
|
||||||
|
llsdItem.name = invItem.inventoryName;
|
||||||
|
llsdItem.parent_id = invItem.parentFolderID;
|
||||||
|
llsdItem.type = Enum.GetName(typeof(AssetType), invItem.assetType).ToLower();
|
||||||
|
llsdItem.inv_type = Enum.GetName(typeof(InventoryType), invItem.invType).ToLower();
|
||||||
|
llsdItem.permissions = new LLSDPermissions();
|
||||||
|
llsdItem.permissions.creator_id = invItem.creatorsID;
|
||||||
|
llsdItem.permissions.base_mask = (int)invItem.inventoryBasePermissions;
|
||||||
|
llsdItem.permissions.everyone_mask = (int)invItem.inventoryEveryOnePermissions;
|
||||||
|
llsdItem.permissions.group_id = LLUUID.Zero;
|
||||||
|
llsdItem.permissions.group_mask = 0;
|
||||||
|
llsdItem.permissions.is_owner_group = false;
|
||||||
|
llsdItem.permissions.next_owner_mask = (int)invItem.inventoryNextPermissions;
|
||||||
|
llsdItem.permissions.owner_id = m_agentID; // FixMe
|
||||||
|
llsdItem.permissions.owner_mask = (int)invItem.inventoryCurrentPermissions;
|
||||||
|
llsdItem.sale_info = new LLSDSaleInfo();
|
||||||
|
llsdItem.sale_info.sale_price = 10;
|
||||||
|
llsdItem.sale_info.sale_type = "not";
|
||||||
|
|
||||||
|
return llsdItem;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
///
|
///
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -12,7 +12,7 @@ namespace OpenSim.Region.Capabilities
|
||||||
|
|
||||||
public LLUUID asset_id;
|
public LLUUID asset_id;
|
||||||
public LLUUID item_id;
|
public LLUUID item_id;
|
||||||
|
public LLSDPermissions permissions;
|
||||||
public string type;
|
public string type;
|
||||||
public string inv_type;
|
public string inv_type;
|
||||||
public int flags;
|
public int flags;
|
||||||
|
@ -45,19 +45,19 @@ namespace OpenSim.Region.Capabilities
|
||||||
public string sale_type;
|
public string sale_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* [LLSDMap]
|
/* [LLSDMap]
|
||||||
public class LLSDFolderItem
|
public class LLSDFolderItem
|
||||||
{
|
{
|
||||||
public LLUUID folder_id;
|
public LLUUID folder_id;
|
||||||
public LLUUID parent_id;
|
public LLUUID parent_id;
|
||||||
public int type;
|
public int type;
|
||||||
public string name;
|
public string name;
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
[LLSDMap]
|
[LLSDMap]
|
||||||
public class LLSDInventoryDescendents
|
public class LLSDInventoryDescendents
|
||||||
{
|
{
|
||||||
public LLSDArray folders= new LLSDArray();
|
public LLSDArray folders = new LLSDArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
[LLSDMap]
|
[LLSDMap]
|
||||||
|
@ -73,11 +73,11 @@ namespace OpenSim.Region.Capabilities
|
||||||
[LLSDMap]
|
[LLSDMap]
|
||||||
public class LLSDInventoryFolderContents
|
public class LLSDInventoryFolderContents
|
||||||
{
|
{
|
||||||
public LLUUID agent___id;
|
public LLUUID agent___id; // the (three "_") "___" so the serialising knows to change this to a "-"
|
||||||
public int descendents;
|
public int descendents;
|
||||||
public LLUUID folder___id; // the (three "_") "___" so the serialising knows to change this to a "-"
|
public LLUUID folder___id; //as LL can't decide if they are going to use "_" or "-" to separate words in the field names
|
||||||
public LLSDArray items = new LLSDArray();
|
public LLSDArray items = new LLSDArray();
|
||||||
public LLUUID owner___id;
|
public LLUUID owner___id; // and of course we can't have field names with "-" in
|
||||||
public int version;
|
public int version;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1656,6 +1656,7 @@ namespace OpenSim.Region.Environment.Scenes
|
||||||
cap.AddNewInventoryItem = AddInventoryItem;
|
cap.AddNewInventoryItem = AddInventoryItem;
|
||||||
cap.ItemUpdatedCall = CapsUpdateInventoryItemAsset;
|
cap.ItemUpdatedCall = CapsUpdateInventoryItemAsset;
|
||||||
cap.TaskScriptUpdatedCall = CapsUpdateTaskInventoryScriptAsset;
|
cap.TaskScriptUpdatedCall = CapsUpdateTaskInventoryScriptAsset;
|
||||||
|
cap.CAPSFetchInventoryDescendents = CommsManager.UserProfileCacheService.HandleFetchInventoryDescendentsCAPS;
|
||||||
|
|
||||||
if (m_capsHandlers.ContainsKey(agent.AgentID))
|
if (m_capsHandlers.ContainsKey(agent.AgentID))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue