ScheduledTasksWebSocketListener.cs 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. using MediaBrowser.Common.Net;
  2. using MediaBrowser.Common.ScheduledTasks;
  3. using MediaBrowser.Model.Logging;
  4. using MediaBrowser.Model.Tasks;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Threading.Tasks;
  8. namespace MediaBrowser.Api.ScheduledTasks
  9. {
  10. /// <summary>
  11. /// Class ScheduledTasksWebSocketListener
  12. /// </summary>
  13. public class ScheduledTasksWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<TaskInfo>, object>
  14. {
  15. /// <summary>
  16. /// Gets or sets the task manager.
  17. /// </summary>
  18. /// <value>The task manager.</value>
  19. private ITaskManager TaskManager { get; set; }
  20. /// <summary>
  21. /// Gets the name.
  22. /// </summary>
  23. /// <value>The name.</value>
  24. protected override string Name
  25. {
  26. get { return "ScheduledTasksInfo"; }
  27. }
  28. /// <summary>
  29. /// Initializes a new instance of the <see cref="ScheduledTasksWebSocketListener" /> class.
  30. /// </summary>
  31. /// <param name="logger">The logger.</param>
  32. /// <param name="taskManager">The task manager.</param>
  33. public ScheduledTasksWebSocketListener(ILogger logger, ITaskManager taskManager)
  34. : base(logger)
  35. {
  36. TaskManager = taskManager;
  37. }
  38. /// <summary>
  39. /// Gets the data to send.
  40. /// </summary>
  41. /// <param name="state">The state.</param>
  42. /// <returns>Task{IEnumerable{TaskInfo}}.</returns>
  43. protected override Task<IEnumerable<TaskInfo>> GetDataToSend(object state)
  44. {
  45. return Task.FromResult(TaskManager.ScheduledTasks.OrderBy(i => i.Name)
  46. .Select(ScheduledTaskHelpers.GetTaskInfo));
  47. }
  48. }
  49. }