* Send full inventory folder skeleton to standalone client logins rather than just the root child folders

* This may resolve some current problems with non root child folders on standalone installations.
* A fix for the same problem in grid mode will come soon.
0.6.0-stable
Justin Clarke Casey 2008-03-28 19:35:01 +00:00
parent 35dec2e53a
commit 0a47a75b88
12 changed files with 73 additions and 30 deletions

View File

@ -31,6 +31,9 @@ namespace OpenSim.Framework.Communications.Cache
{ {
public class CachedUserInfo public class CachedUserInfo
{ {
private static readonly log4net.ILog m_log
= log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
private readonly CommunicationsManager m_parentCommsManager; private readonly CommunicationsManager m_parentCommsManager;
// Fields // Fields
public InventoryFolderImpl RootFolder = null; public InventoryFolderImpl RootFolder = null;
@ -44,6 +47,8 @@ namespace OpenSim.Framework.Communications.Cache
// Methods // Methods
public void FolderReceive(LLUUID userID, InventoryFolderImpl folderInfo) public void FolderReceive(LLUUID userID, InventoryFolderImpl folderInfo)
{ {
//m_log.DebugFormat("[INVENTORY CACHE]: Received folder {0} {1} for user {2}", folderInfo.name, folderInfo.folderID, userID);
if (userID == UserProfile.UUID) if (userID == UserProfile.UUID)
{ {
if (RootFolder == null) if (RootFolder == null)

View File

@ -72,7 +72,7 @@ namespace OpenSim.Framework.Communications.Cache
} }
else else
{ {
m_log.ErrorFormat("[USERCACHE]: User profile for user {0} not found", userID); m_log.ErrorFormat("[USER CACHE]: User profile for user {0} not found", userID);
} }
} }
} }
@ -244,15 +244,14 @@ namespace OpenSim.Framework.Communications.Cache
} }
else else
{ {
m_log.ErrorFormat("[INVENTORYCACHE]: Could not find root folder for user {0}", remoteClient.Name); m_log.ErrorFormat("[INVENTORY CACHE]: Could not find root folder for user {0}", remoteClient.Name);
return; return;
} }
} }
else else
{ {
m_log.ErrorFormat("[INVENTORYCACHE]: " + m_log.ErrorFormat("[INVENTORY CACHE]: Could not find user profile for {0} for folder {1}",
"Could not find user profile for {0} for folder {1}",
remoteClient.Name, folderID); remoteClient.Name, folderID);
return; return;
@ -260,8 +259,7 @@ namespace OpenSim.Framework.Communications.Cache
// If we've reached this point then we couldn't find the folder, even though the client thinks // If we've reached this point then we couldn't find the folder, even though the client thinks
// it exists // it exists
m_log.ErrorFormat("[INVENTORYCACHE]: " + m_log.ErrorFormat("[INVENTORY CACHE]: Could not find folder {0} for user {1}",
"Could not find folder {0} for user {1}",
folderID, remoteClient.Name); folderID, remoteClient.Name);
} }
@ -303,14 +301,14 @@ namespace OpenSim.Framework.Communications.Cache
} }
else else
{ {
m_log.ErrorFormat("[INVENTORYCACHE]: Could not find root folder for user {0}", agentID.ToString()); m_log.ErrorFormat("[INVENTORY CACHE]: Could not find root folder for user {0}", agentID.ToString());
return new List<InventoryItemBase>(); ; return new List<InventoryItemBase>(); ;
} }
} }
else else
{ {
m_log.ErrorFormat("[INVENTORYCACHE]: " + m_log.ErrorFormat("[INVENTORY CACHE]: " +
"Could not find user profile for {0} for folder {1}", "Could not find user profile for {0} for folder {1}",
agentID.ToString(), folderID); agentID.ToString(), folderID);
return new List<InventoryItemBase>(); return new List<InventoryItemBase>();
@ -318,7 +316,7 @@ namespace OpenSim.Framework.Communications.Cache
// If we've reached this point then we couldn't find the folder, even though the client thinks // If we've reached this point then we couldn't find the folder, even though the client thinks
// it exists // it exists
m_log.ErrorFormat("[INVENTORYCACHE]: " + m_log.ErrorFormat("[INVENTORY CACHE]: " +
"Could not find folder {0} for user {1}", "Could not find folder {0} for user {1}",
folderID, agentID.ToString()); folderID, agentID.ToString());
// } // }

View File

@ -87,6 +87,14 @@ namespace OpenSim.Framework.Communications
/// <param name="userID"></param> /// <param name="userID"></param>
/// <returns></returns> /// <returns></returns>
List<InventoryFolderBase> RequestFirstLevelFolders(LLUUID userID); List<InventoryFolderBase> RequestFirstLevelFolders(LLUUID userID);
/// <summary>
/// Returns a list of all the folders in a given user's inventory.
/// </summary>
/// <param name="userId"></param>
/// <returns>A flat list of the user's inventory folder tree.
/// Null if there is no inventory for this user</returns>
List<InventoryFolderBase> GetInventorySkeleton(LLUUID userId);
/// <summary> /// <summary>
/// Returns the named folder in that users inventory, returns null if folder is not found. /// Returns the named folder in that users inventory, returns null if folder is not found.

View File

@ -108,6 +108,30 @@ namespace OpenSim.Framework.Communications
return inventoryList; return inventoryList;
} }
// See IInventoryServices
public List<InventoryFolderBase> GetInventorySkeleton(LLUUID userId)
{
// m_log.DebugFormat("[AGENT INVENTORY]: Getting inventory skeleton for {0}", userId);
List<InventoryFolderBase> userFolders = new List<InventoryFolderBase>();
InventoryFolderBase rootFolder = RequestRootFolder(userId);
userFolders.Add(rootFolder);
foreach (KeyValuePair<string, IInventoryData> plugin in m_plugins)
{
IList<InventoryFolderBase> folders = plugin.Value.getFolderHierarchy(rootFolder.folderID);
userFolders.AddRange(folders);
}
// foreach (InventoryFolderBase folder in userFolders)
// {
// m_log.DebugFormat("[AGENT INVENTORY]: Got folder {0} {1}", folder.name, folder.folderID);
// }
return userFolders;
}
// See IInventoryServices // See IInventoryServices
public void MoveInventoryFolder(LLUUID userID, InventoryFolderBase folder) public void MoveInventoryFolder(LLUUID userID, InventoryFolderBase folder)

View File

@ -43,7 +43,8 @@ namespace OpenSim.Framework.UserManagement
/// </summary> /// </summary>
public abstract class UserManagerBase : IUserService public abstract class UserManagerBase : IUserService
{ {
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);
public UserConfig _config; public UserConfig _config;
private Dictionary<string, IUserData> _plugins = new Dictionary<string, IUserData>(); private Dictionary<string, IUserData> _plugins = new Dictionary<string, IUserData>();

View File

@ -652,12 +652,8 @@ namespace OpenSim.Framework.Data.MSSQL
folders.Add(f); folders.Add(f);
} }
/// <summary> // See IInventoryData
/// Returns all child folders in the hierarchy from the parent folder and down public List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
/// </summary>
/// <param name="parentID">The folder to get subfolders for</param>
/// <returns>A list of inventory folders</returns>
protected List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
{ {
List<InventoryFolderBase> folders = new List<InventoryFolderBase>(); List<InventoryFolderBase> folders = new List<InventoryFolderBase>();
getInventoryFolders(ref folders, parentID); getInventoryFolders(ref folders, parentID);

View File

@ -573,12 +573,8 @@ namespace OpenSim.Framework.Data.MySQL
folders.Add(f); folders.Add(f);
} }
/// <summary> // See IInventoryData
/// Returns all child folders in the hierarchy from the parent folder and down public List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
/// </summary>
/// <param name="parentID">The folder to get subfolders for</param>
/// <returns>A list of inventory folders</returns>
protected List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
{ {
List<InventoryFolderBase> folders = new List<InventoryFolderBase>(); List<InventoryFolderBase> folders = new List<InventoryFolderBase>();
getInventoryFolders(ref folders, parentID); getInventoryFolders(ref folders, parentID);

View File

@ -319,12 +319,8 @@ namespace OpenSim.Framework.Data.SQLite
return folders; return folders;
} }
/// <summary> // See IInventoryData
/// Returns all child folders in the hierarchy from the parent folder and down public List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
/// </summary>
/// <param name="parentID">The folder to get subfolders for</param>
/// <returns>A list of inventory folders</returns>
protected List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID)
{ {
List<InventoryFolderBase> folders = new List<InventoryFolderBase>(); List<InventoryFolderBase> folders = new List<InventoryFolderBase>();
getInventoryFolders(ref folders, Util.ToRawUuidString(parentID)); getInventoryFolders(ref folders, Util.ToRawUuidString(parentID));

View File

@ -165,6 +165,14 @@ namespace OpenSim.Framework
/// </summary> /// </summary>
/// <returns>A string containing the plugin version</returns> /// <returns>A string containing the plugin version</returns>
string getVersion(); string getVersion();
/// <summary>
/// Returns all child folders in the hierarchy from the parent folder and down.
/// Does not return the parent folder itself.
/// </summary>
/// <param name="parentID">The folder to get subfolders for</param>
/// <returns>A list of inventory folders</returns>
List<InventoryFolderBase> getFolderHierarchy(LLUUID parentID);
/// <summary> /// <summary>
/// Returns a list of inventory items contained within the specified folder /// Returns a list of inventory items contained within the specified folder

View File

@ -42,7 +42,9 @@ namespace OpenSim.Region.Communications.Local
public override void RequestInventoryForUser(LLUUID userID, InventoryFolderInfo folderCallBack, public override void RequestInventoryForUser(LLUUID userID, InventoryFolderInfo folderCallBack,
InventoryItemInfo itemCallBack) InventoryItemInfo itemCallBack)
{ {
List<InventoryFolderBase> folders = RequestFirstLevelFolders(userID); //List<InventoryFolderBase> folders = RequestFirstLevelFolders(userID);
List<InventoryFolderBase> folders = GetInventorySkeleton(userID);
InventoryFolderImpl rootFolder = null; InventoryFolderImpl rootFolder = null;
//need to make sure we send root folder first //need to make sure we send root folder first

View File

@ -215,7 +215,8 @@ namespace OpenSim.Region.Communications.Local
// See LoginService // See LoginService
protected override InventoryData GetInventorySkeleton(LLUUID userID) protected override InventoryData GetInventorySkeleton(LLUUID userID)
{ {
List<InventoryFolderBase> folders = m_Parent.InventoryService.RequestFirstLevelFolders(userID); List<InventoryFolderBase> folders = m_Parent.InventoryService.GetInventorySkeleton(userID);
//List<InventoryFolderBase> folders = m_Parent.InventoryService.RequestFirstLevelFolders(userID);
if (folders.Count > 0) if (folders.Count > 0)
{ {
LLUUID rootID = LLUUID.Zero; LLUUID rootID = LLUUID.Zero;

View File

@ -216,6 +216,14 @@ namespace OpenSim.Region.Communications.OGS1
public void CreateNewUserInventory(LLUUID user) public void CreateNewUserInventory(LLUUID user)
{ {
} }
// See IInventoryServices
public List<InventoryFolderBase> GetInventorySkeleton(LLUUID userId)
{
m_log.ErrorFormat("[OGS1 INVENTORY SERVICE]: The GetInventorySkeleton() method here should never be called!");
return new List<InventoryFolderBase>();
}
public List<InventoryFolderBase> RequestFirstLevelFolders(LLUUID userID) public List<InventoryFolderBase> RequestFirstLevelFolders(LLUUID userID)
{ {