YearsPostScanTask.cs 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. using MediaBrowser.Controller.Library;
  2. using MediaBrowser.Model.Logging;
  3. using System;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. namespace Emby.Server.Implementations.Library.Validators
  7. {
  8. public class YearsPostScanTask : ILibraryPostScanTask
  9. {
  10. private readonly ILibraryManager _libraryManager;
  11. private readonly ILogger _logger;
  12. public YearsPostScanTask(ILibraryManager libraryManager, ILogger logger)
  13. {
  14. _libraryManager = libraryManager;
  15. _logger = logger;
  16. }
  17. public async Task Run(IProgress<double> progress, CancellationToken cancellationToken)
  18. {
  19. var yearNumber = 1900;
  20. var maxYear = DateTime.UtcNow.Year + 3;
  21. var count = maxYear - yearNumber + 1;
  22. var numComplete = 0;
  23. while (yearNumber < maxYear)
  24. {
  25. try
  26. {
  27. var year = _libraryManager.GetYear(yearNumber);
  28. await year.RefreshMetadata(cancellationToken).ConfigureAwait(false);
  29. }
  30. catch (OperationCanceledException)
  31. {
  32. // Don't clutter the log
  33. break;
  34. }
  35. catch (Exception ex)
  36. {
  37. _logger.ErrorException("Error refreshing year {0}", ex, yearNumber);
  38. }
  39. numComplete++;
  40. double percent = numComplete;
  41. percent /= count;
  42. percent *= 100;
  43. progress.Report(percent);
  44. yearNumber++;
  45. }
  46. }
  47. }
  48. }