StudiosValidator.cs 2.4 KB

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