Egor Bakanov 2 years ago committed by GitHub
parent a2b792e386
commit 46e9f5ad2e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -37,6 +37,7 @@
- [DMouse10462](https://github.com/DMouse10462) - [DMouse10462](https://github.com/DMouse10462)
- [DrPandemic](https://github.com/DrPandemic) - [DrPandemic](https://github.com/DrPandemic)
- [eglia](https://github.com/eglia) - [eglia](https://github.com/eglia)
- [EgorBakanov](https://github.com/EgorBakanov)
- [EraYaN](https://github.com/EraYaN) - [EraYaN](https://github.com/EraYaN)
- [escabe](https://github.com/escabe) - [escabe](https://github.com/escabe)
- [excelite](https://github.com/excelite) - [excelite](https://github.com/excelite)

@ -1300,8 +1300,15 @@ namespace MediaBrowser.Controller.Entities
/// <summary> /// <summary>
/// Adds the children to list. /// Adds the children to list.
/// </summary> /// </summary>
private void AddChildren(User user, bool includeLinkedChildren, Dictionary<Guid, BaseItem> result, bool recursive, InternalItemsQuery query) private void AddChildren(User user, bool includeLinkedChildren, Dictionary<Guid, BaseItem> result, bool recursive, InternalItemsQuery query, HashSet<Folder> visitedFolders = null)
{ {
// Prevent infinite recursion of nested folders
visitedFolders ??= new HashSet<Folder>();
if (!visitedFolders.Add(this))
{
return;
}
// If Query.AlbumFolders is set, then enforce the format as per the db in that it permits sub-folders in music albums. // If Query.AlbumFolders is set, then enforce the format as per the db in that it permits sub-folders in music albums.
IEnumerable<BaseItem> children = null; IEnumerable<BaseItem> children = null;
if ((query?.DisplayAlbumFolders ?? false) && (this is MusicAlbum)) if ((query?.DisplayAlbumFolders ?? false) && (this is MusicAlbum))
@ -1316,42 +1323,33 @@ namespace MediaBrowser.Controller.Entities
children = GetEligibleChildrenForRecursiveChildren(user); children = GetEligibleChildrenForRecursiveChildren(user);
} }
foreach (var child in children) AddChildrenFromCollection(children, user, includeLinkedChildren, result, recursive, query, visitedFolders);
{
bool? isVisibleToUser = null;
if (query is null || UserViewBuilder.FilterItem(child, query)) if (includeLinkedChildren)
{
isVisibleToUser = child.IsVisible(user);
if (isVisibleToUser.Value)
{ {
result[child.Id] = child; AddChildrenFromCollection(GetLinkedChildren(user), user, includeLinkedChildren, result, recursive, query, visitedFolders);
} }
} }
if (isVisibleToUser ?? child.IsVisible(user)) private void AddChildrenFromCollection(IEnumerable<BaseItem> children, User user, bool includeLinkedChildren, Dictionary<Guid, BaseItem> result, bool recursive, InternalItemsQuery query, HashSet<Folder> visitedFolders)
{ {
if (recursive && child.IsFolder) foreach (var child in children)
{ {
var folder = (Folder)child; if (!child.IsVisible(user))
{
folder.AddChildren(user, includeLinkedChildren, result, true, query); continue;
}
}
} }
if (includeLinkedChildren)
{
foreach (var child in GetLinkedChildren(user))
{
if (query is null || UserViewBuilder.FilterItem(child, query)) if (query is null || UserViewBuilder.FilterItem(child, query))
{
if (child.IsVisible(user))
{ {
result[child.Id] = child; result[child.Id] = child;
} }
}
if (recursive && child.IsFolder)
{
var folder = (Folder)child;
folder.AddChildren(user, includeLinkedChildren, result, true, query, visitedFolders);
} }
} }
} }

Loading…
Cancel
Save