YearsPostScanTask.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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. cancellationToken.ThrowIfCancellationRequested();
  26. try
  27. {
  28. var year = _libraryManager.GetYear(yearNumber);
  29. await year.RefreshMetadata(cancellationToken).ConfigureAwait(false);
  30. }
  31. catch (OperationCanceledException)
  32. {
  33. // Don't clutter the log
  34. throw;
  35. }
  36. catch (Exception ex)
  37. {
  38. _logger.ErrorException("Error refreshing year {0}", ex, yearNumber);
  39. }
  40. numComplete++;
  41. double percent = numComplete;
  42. percent /= count;
  43. percent *= 100;
  44. progress.Report(percent);
  45. yearNumber++;
  46. }
  47. }
  48. }
  49. }