DashboardInfoWebSocketListener.cs 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. using MediaBrowser.Common.Net;
  2. using MediaBrowser.Common.ScheduledTasks;
  3. using MediaBrowser.Controller;
  4. using MediaBrowser.Controller.Library;
  5. using MediaBrowser.Model.Logging;
  6. using System.ComponentModel.Composition;
  7. using System.Threading.Tasks;
  8. namespace MediaBrowser.WebDashboard.Api
  9. {
  10. /// <summary>
  11. /// Class DashboardInfoWebSocketListener
  12. /// </summary>
  13. [Export(typeof(IWebSocketListener))]
  14. class DashboardInfoWebSocketListener : BasePeriodicWebSocketListener<DashboardInfo, object>
  15. {
  16. /// <summary>
  17. /// Gets the name.
  18. /// </summary>
  19. /// <value>The name.</value>
  20. protected override string Name
  21. {
  22. get { return "DashboardInfo"; }
  23. }
  24. private readonly IServerApplicationHost _appHost;
  25. /// <summary>
  26. /// Gets or sets the task manager.
  27. /// </summary>
  28. /// <value>The task manager.</value>
  29. private readonly ITaskManager _taskManager;
  30. /// <summary>
  31. /// The _user manager
  32. /// </summary>
  33. private readonly IUserManager _userManager;
  34. private readonly ILibraryManager _libraryManager;
  35. /// <summary>
  36. /// Initializes a new instance of the <see cref="DashboardInfoWebSocketListener" /> class.
  37. /// </summary>
  38. /// <param name="appHost">The app host.</param>
  39. /// <param name="logger">The logger.</param>
  40. /// <param name="taskManager">The task manager.</param>
  41. /// <param name="userManager">The user manager.</param>
  42. /// <param name="libraryManager">The library manager.</param>
  43. public DashboardInfoWebSocketListener(IServerApplicationHost appHost, ILogger logger, ITaskManager taskManager, IUserManager userManager, ILibraryManager libraryManager)
  44. : base(logger)
  45. {
  46. _appHost = appHost;
  47. _taskManager = taskManager;
  48. _userManager = userManager;
  49. _libraryManager = libraryManager;
  50. }
  51. /// <summary>
  52. /// Gets the data to send.
  53. /// </summary>
  54. /// <param name="state">The state.</param>
  55. /// <returns>Task{IEnumerable{TaskInfo}}.</returns>
  56. protected override Task<DashboardInfo> GetDataToSend(object state)
  57. {
  58. return DashboardService.GetDashboardInfo(_appHost, Logger, _taskManager, _userManager, _libraryManager);
  59. }
  60. }
  61. }