RefreshMediaLibraryTask.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. using MediaBrowser.Common.ScheduledTasks;
  2. using MediaBrowser.Controller.Library;
  3. using MediaBrowser.Model.Tasks;
  4. using MediaBrowser.Server.Implementations.Library;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. namespace MediaBrowser.Server.Implementations.ScheduledTasks
  10. {
  11. /// <summary>
  12. /// Class RefreshMediaLibraryTask
  13. /// </summary>
  14. public class RefreshMediaLibraryTask : IScheduledTask
  15. {
  16. /// <summary>
  17. /// The _library manager
  18. /// </summary>
  19. private readonly ILibraryManager _libraryManager;
  20. /// <summary>
  21. /// Initializes a new instance of the <see cref="RefreshMediaLibraryTask" /> class.
  22. /// </summary>
  23. /// <param name="libraryManager">The library manager.</param>
  24. public RefreshMediaLibraryTask(ILibraryManager libraryManager)
  25. {
  26. _libraryManager = libraryManager;
  27. }
  28. /// <summary>
  29. /// Gets the default triggers.
  30. /// </summary>
  31. /// <returns>IEnumerable{BaseTaskTrigger}.</returns>
  32. public IEnumerable<ITaskTrigger> GetDefaultTriggers()
  33. {
  34. return new ITaskTrigger[] {
  35. new StartupTrigger(),
  36. new SystemEventTrigger{ SystemEvent = SystemEvent.WakeFromSleep},
  37. new IntervalTrigger{ Interval = TimeSpan.FromHours(6)}
  38. };
  39. }
  40. /// <summary>
  41. /// Executes the internal.
  42. /// </summary>
  43. /// <param name="cancellationToken">The cancellation token.</param>
  44. /// <param name="progress">The progress.</param>
  45. /// <returns>Task.</returns>
  46. public Task Execute(CancellationToken cancellationToken, IProgress<double> progress)
  47. {
  48. cancellationToken.ThrowIfCancellationRequested();
  49. progress.Report(0);
  50. return ((LibraryManager)_libraryManager).ValidateMediaLibraryInternal(progress, cancellationToken);
  51. }
  52. /// <summary>
  53. /// Gets the name.
  54. /// </summary>
  55. /// <value>The name.</value>
  56. public string Name
  57. {
  58. get { return "Scan media library"; }
  59. }
  60. /// <summary>
  61. /// Gets the description.
  62. /// </summary>
  63. /// <value>The description.</value>
  64. public string Description
  65. {
  66. get { return "Scans your media library and refreshes metatata based on configuration."; }
  67. }
  68. /// <summary>
  69. /// Gets the category.
  70. /// </summary>
  71. /// <value>The category.</value>
  72. public string Category
  73. {
  74. get
  75. {
  76. return "Library";
  77. }
  78. }
  79. }
  80. }