UIKernel.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. using MediaBrowser.ApiInteraction;
  2. using MediaBrowser.Common.IO;
  3. using MediaBrowser.Common.Kernel;
  4. using MediaBrowser.Common.Logging;
  5. using MediaBrowser.Model.Connectivity;
  6. using MediaBrowser.Model.Net;
  7. using MediaBrowser.UI.Configuration;
  8. using MediaBrowser.UI.Playback;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.ComponentModel.Composition;
  12. using System.Diagnostics;
  13. using System.IO;
  14. using System.Linq;
  15. using System.Net;
  16. using System.Net.Cache;
  17. using System.Net.Http;
  18. using System.Reflection;
  19. using System.Threading.Tasks;
  20. namespace MediaBrowser.UI.Controller
  21. {
  22. /// <summary>
  23. /// This controls application logic as well as server interaction within the UI.
  24. /// </summary>
  25. public class UIKernel : BaseKernel<UIApplicationConfiguration, UIApplicationPaths>
  26. {
  27. /// <summary>
  28. /// Gets the instance.
  29. /// </summary>
  30. /// <value>The instance.</value>
  31. public static UIKernel Instance { get; private set; }
  32. /// <summary>
  33. /// Gets the API client.
  34. /// </summary>
  35. /// <value>The API client.</value>
  36. public ApiClient ApiClient { get; private set; }
  37. /// <summary>
  38. /// Gets the playback manager.
  39. /// </summary>
  40. /// <value>The playback manager.</value>
  41. public PlaybackManager PlaybackManager { get; private set; }
  42. /// <summary>
  43. /// Initializes a new instance of the <see cref="UIKernel" /> class.
  44. /// </summary>
  45. public UIKernel(IIsoManager isoManager)
  46. : base(isoManager)
  47. {
  48. Instance = this;
  49. }
  50. /// <summary>
  51. /// Gets the media players.
  52. /// </summary>
  53. /// <value>The media players.</value>
  54. [ImportMany(typeof(BaseMediaPlayer))]
  55. public IEnumerable<BaseMediaPlayer> MediaPlayers { get; private set; }
  56. /// <summary>
  57. /// Gets the list of currently loaded themes
  58. /// </summary>
  59. /// <value>The themes.</value>
  60. [ImportMany(typeof(BaseTheme))]
  61. public IEnumerable<BaseTheme> Themes { get; private set; }
  62. /// <summary>
  63. /// Gets the kernel context.
  64. /// </summary>
  65. /// <value>The kernel context.</value>
  66. public override KernelContext KernelContext
  67. {
  68. get { return KernelContext.Ui; }
  69. }
  70. /// <summary>
  71. /// Gets the UDP server port number.
  72. /// </summary>
  73. /// <value>The UDP server port number.</value>
  74. public override int UdpServerPortNumber
  75. {
  76. get { return 7360; }
  77. }
  78. /// <summary>
  79. /// Give the UI a different url prefix so that they can share the same port, in case they are installed on the same machine.
  80. /// </summary>
  81. /// <value>The HTTP server URL prefix.</value>
  82. public override string HttpServerUrlPrefix
  83. {
  84. get
  85. {
  86. return "http://+:" + Configuration.HttpServerPortNumber + "/mediabrowserui/";
  87. }
  88. }
  89. /// <summary>
  90. /// Reload api client and update plugins after loading configuration
  91. /// </summary>
  92. /// <returns>Task.</returns>
  93. protected override async Task OnConfigurationLoaded()
  94. {
  95. ReloadApiClient();
  96. try
  97. {
  98. await new PluginUpdater(Logger).UpdatePlugins().ConfigureAwait(false);
  99. }
  100. catch (HttpException ex)
  101. {
  102. Logger.ErrorException("Error updating plugins from the server", ex);
  103. }
  104. }
  105. /// <summary>
  106. /// Disposes the current ApiClient and creates a new one
  107. /// </summary>
  108. private void ReloadApiClient()
  109. {
  110. DisposeApiClient();
  111. var logger = LogManager.GetLogger("ApiClient");
  112. ApiClient = new ApiClient(logger, new AsyncHttpClient(new WebRequestHandler
  113. {
  114. AutomaticDecompression = DecompressionMethods.Deflate,
  115. CachePolicy = new RequestCachePolicy(RequestCacheLevel.Revalidate)
  116. }))
  117. {
  118. ServerHostName = Configuration.ServerHostName,
  119. ServerApiPort = Configuration.ServerApiPort,
  120. ClientType = ClientType.Pc,
  121. DeviceName = Environment.MachineName,
  122. SerializationFormat = SerializationFormats.Json
  123. };
  124. }
  125. /// <summary>
  126. /// Reloads the internal.
  127. /// </summary>
  128. /// <returns>Task.</returns>
  129. protected override Task ReloadInternal()
  130. {
  131. PlaybackManager = new PlaybackManager(this);
  132. return base.ReloadInternal();
  133. }
  134. /// <summary>
  135. /// Called when [composable parts loaded].
  136. /// </summary>
  137. /// <returns>Task.</returns>
  138. protected override async Task OnComposablePartsLoaded()
  139. {
  140. await base.OnComposablePartsLoaded().ConfigureAwait(false);
  141. // Once plugins have loaded give the api a reference to our protobuf serializer
  142. DataSerializer.DynamicSerializer = ProtobufSerializer.TypeModel;
  143. }
  144. /// <summary>
  145. /// Disposes the current ApiClient
  146. /// </summary>
  147. private void DisposeApiClient()
  148. {
  149. if (ApiClient != null)
  150. {
  151. ApiClient.Dispose();
  152. }
  153. }
  154. /// <summary>
  155. /// Releases unmanaged and - optionally - managed resources.
  156. /// </summary>
  157. /// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
  158. protected override void Dispose(bool dispose)
  159. {
  160. if (dispose)
  161. {
  162. DisposeApiClient();
  163. }
  164. base.Dispose(dispose);
  165. }
  166. }
  167. }