GenresValidator.cs 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. using MediaBrowser.Controller.Entities;
  2. using MediaBrowser.Controller.Entities.Audio;
  3. using MediaBrowser.Controller.Library;
  4. using MediaBrowser.Model.Logging;
  5. using System;
  6. using System.Linq;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. namespace MediaBrowser.Server.Implementations.Library.Validators
  10. {
  11. class GenresValidator
  12. {
  13. /// <summary>
  14. /// The _library manager
  15. /// </summary>
  16. private readonly ILibraryManager _libraryManager;
  17. /// <summary>
  18. /// The _logger
  19. /// </summary>
  20. private readonly ILogger _logger;
  21. public GenresValidator(ILibraryManager libraryManager, ILogger logger)
  22. {
  23. _libraryManager = libraryManager;
  24. _logger = logger;
  25. }
  26. /// <summary>
  27. /// Runs the specified progress.
  28. /// </summary>
  29. /// <param name="progress">The progress.</param>
  30. /// <param name="cancellationToken">The cancellation token.</param>
  31. /// <returns>Task.</returns>
  32. public async Task Run(IProgress<double> progress, CancellationToken cancellationToken)
  33. {
  34. var items = _libraryManager.RootFolder.GetRecursiveChildren(i => !(i is IHasMusicGenres) && !(i is Game))
  35. .SelectMany(i => i.Genres)
  36. .DistinctNames()
  37. .ToList();
  38. var numComplete = 0;
  39. var count = items.Count;
  40. foreach (var name in items)
  41. {
  42. try
  43. {
  44. var itemByName = _libraryManager.GetGenre(name);
  45. await itemByName.RefreshMetadata(cancellationToken).ConfigureAwait(false);
  46. }
  47. catch (OperationCanceledException)
  48. {
  49. // Don't clutter the log
  50. break;
  51. }
  52. catch (Exception ex)
  53. {
  54. _logger.ErrorException("Error refreshing {0}", ex, name);
  55. }
  56. numComplete++;
  57. double percent = numComplete;
  58. percent /= count;
  59. percent *= 100;
  60. progress.Report(percent);
  61. }
  62. progress.Report(100);
  63. }
  64. }
  65. }