aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs')
-rw-r--r--Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs115
1 files changed, 110 insertions, 5 deletions
diff --git a/Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs b/Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs
index bc204b788..64967350e 100644
--- a/Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs
+++ b/Emby.Server.Implementations/Library/Validators/CollectionPostScanTask.cs
@@ -1,9 +1,14 @@
using System;
+using System.Linq;
using System.Threading;
using System.Threading.Tasks;
+using System.Collections.Generic;
using MediaBrowser.Controller.Collections;
+using MediaBrowser.Controller.Entities;
+using MediaBrowser.Controller.Entities.Movies;
using MediaBrowser.Controller.Library;
-using MediaBrowser.Controller.Persistence;
+using MediaBrowser.Model.Querying;
+using Jellyfin.Data.Enums;
using Microsoft.Extensions.Logging;
namespace Emby.Server.Implementations.Library.Validators
@@ -17,8 +22,16 @@ namespace Emby.Server.Implementations.Library.Validators
/// The _library manager.
/// </summary>
private readonly ILibraryManager _libraryManager;
+
+ /// <summary>
+ /// The collection manager.
+ /// </summary>
private readonly ICollectionManager _collectionManager;
- private readonly ILogger<CollectionValidator> _logger;
+
+ /// <summary>
+ /// The logger.
+ /// </summary>
+ private readonly ILogger<CollectionPostScanTask> _logger;
/// <summary>
/// Initializes a new instance of the <see cref="CollectionPostScanTask" /> class.
@@ -28,7 +41,7 @@ namespace Emby.Server.Implementations.Library.Validators
/// <param name="logger">The logger.</param>
public CollectionPostScanTask(
ILibraryManager libraryManager,
- ILogger<CollectionValidator> logger,
+ ILogger<CollectionPostScanTask> logger,
ICollectionManager collectionManager)
{
_libraryManager = libraryManager;
@@ -42,9 +55,101 @@ namespace Emby.Server.Implementations.Library.Validators
/// <param name="progress">The progress.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task.</returns>
- public Task Run(IProgress<double> progress, CancellationToken cancellationToken)
+ public async Task Run(IProgress<double> progress, CancellationToken cancellationToken)
{
- return new CollectionValidator(_libraryManager, _collectionManager, _logger).Run(progress, cancellationToken);
+
+ var movies = _libraryManager.GetItemList(new InternalItemsQuery
+ {
+ IncludeItemTypes = new[] { nameof(Movie) },
+ IsVirtualItem = false,
+ OrderBy = new List<ValueTuple<string, SortOrder>>
+ {
+ new ValueTuple<string, SortOrder>(ItemSortBy.SortName, SortOrder.Ascending)
+ },
+ Recursive = true
+ });
+
+ var boxSets = _libraryManager.GetItemList(new InternalItemsQuery
+ {
+ IncludeItemTypes = new[] { nameof(BoxSet) },
+ CollapseBoxSetItems = false,
+ Recursive = true
+ });
+
+ var numComplete = 0;
+ var count = movies.Count;
+
+ var collectionNameMoviesMap = new Dictionary<string, List<Movie>>();
+ foreach (var m in movies)
+ {
+ var movie = m as Movie;
+ if (movie != null && movie.CollectionName != null)
+ {
+ var movieList = new List<Movie>();
+ if (collectionNameMoviesMap.TryGetValue(movie.CollectionName, out movieList))
+ {
+ if (!movieList.Any(m => m.Id == movie.Id))
+ {
+ movieList.Add(movie);
+ collectionNameMoviesMap[movie.CollectionName] = movieList;
+ }
+ }
+ else
+ {
+ collectionNameMoviesMap[movie.CollectionName] = new List<Movie> { movie };
+ }
+
+ }
+
+ numComplete++;
+ double percent = numComplete;
+ percent /= count * 2;
+ percent *= 100;
+
+ progress.Report(percent);
+ }
+
+ foreach (var pair in collectionNameMoviesMap)
+ {
+ try
+ {
+ var collectionName = pair.Key;
+ var movieList = pair.Value;
+
+ var boxSet = boxSets.FirstOrDefault(b => b != null ? b.Name == collectionName : false) as BoxSet;
+ if (boxSet == null)
+ {
+ // won't automatically create collection if only one movie in it
+ if (movieList.Count >= 2)
+ {
+ boxSet = await _collectionManager.CreateCollectionAsync(new CollectionCreationOptions
+ {
+ Name = collectionName,
+ IsLocked = true
+ });
+
+ await _collectionManager.AddToCollectionAsync(boxSet.Id, movieList.Select(m => m.Id));
+ }
+ }
+ else
+ {
+ await _collectionManager.AddToCollectionAsync(boxSet.Id, movieList.Select(m => m.Id));
+ }
+
+ numComplete++;
+ double percent = numComplete;
+ percent /= count * 2;
+ percent *= 100;
+
+ progress.Report(percent);
+ }
+ catch (Exception ex)
+ {
+ _logger.LogError(ex, "Error refreshing {0}, {1}", pair.Key, pair.Value.ToString());
+ }
+ }
+
+ progress.Report(100);
}
}
}