ApplicationHost.cs 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. using MediaBrowser.Api;
  2. using MediaBrowser.Common;
  3. using MediaBrowser.Common.Configuration;
  4. using MediaBrowser.Common.Constants;
  5. using MediaBrowser.Common.Implementations;
  6. using MediaBrowser.Common.Implementations.HttpServer;
  7. using MediaBrowser.Common.Implementations.Logging;
  8. using MediaBrowser.Common.Implementations.ScheduledTasks;
  9. using MediaBrowser.Common.IO;
  10. using MediaBrowser.Common.Kernel;
  11. using MediaBrowser.Common.Updates;
  12. using MediaBrowser.Controller;
  13. using MediaBrowser.Controller.Configuration;
  14. using MediaBrowser.Controller.Entities;
  15. using MediaBrowser.Controller.Library;
  16. using MediaBrowser.Controller.Resolvers;
  17. using MediaBrowser.Controller.Updates;
  18. using MediaBrowser.IsoMounter;
  19. using MediaBrowser.Model.IO;
  20. using MediaBrowser.Model.Logging;
  21. using MediaBrowser.Model.MediaInfo;
  22. using MediaBrowser.Model.System;
  23. using MediaBrowser.Model.Updates;
  24. using MediaBrowser.Server.Implementations;
  25. using MediaBrowser.Server.Implementations.BdInfo;
  26. using MediaBrowser.Server.Implementations.Configuration;
  27. using MediaBrowser.Server.Implementations.Library;
  28. using MediaBrowser.ServerApplication.Implementations;
  29. using MediaBrowser.WebDashboard.Api;
  30. using System;
  31. using System.Collections.Generic;
  32. using System.IO;
  33. using System.Linq;
  34. using System.Reflection;
  35. using System.Threading;
  36. using System.Threading.Tasks;
  37. namespace MediaBrowser.ServerApplication
  38. {
  39. /// <summary>
  40. /// Class CompositionRoot
  41. /// </summary>
  42. public class ApplicationHost : BaseApplicationHost<ServerApplicationPaths>
  43. {
  44. /// <summary>
  45. /// The _web socket events
  46. /// </summary>
  47. private WebSocketEvents _webSocketEvents;
  48. /// <summary>
  49. /// Gets the server kernel.
  50. /// </summary>
  51. /// <value>The server kernel.</value>
  52. protected Kernel ServerKernel
  53. {
  54. get { return (Kernel)Kernel; }
  55. }
  56. /// <summary>
  57. /// Gets the server configuration manager.
  58. /// </summary>
  59. /// <value>The server configuration manager.</value>
  60. public IServerConfigurationManager ServerConfigurationManager
  61. {
  62. get { return (IServerConfigurationManager)ConfigurationManager; }
  63. }
  64. /// <summary>
  65. /// Gets the kernel.
  66. /// </summary>
  67. /// <returns>IKernel.</returns>
  68. protected override IKernel GetKernel()
  69. {
  70. return new Kernel(this, XmlSerializer, LogManager, ServerConfigurationManager);
  71. }
  72. /// <summary>
  73. /// Gets the name of the log file prefix.
  74. /// </summary>
  75. /// <value>The name of the log file prefix.</value>
  76. protected override string LogFilePrefixName
  77. {
  78. get { return "Server"; }
  79. }
  80. /// <summary>
  81. /// Gets the configuration manager.
  82. /// </summary>
  83. /// <returns>IConfigurationManager.</returns>
  84. protected override IConfigurationManager GetConfigurationManager()
  85. {
  86. return new ServerConfigurationManager(ApplicationPaths, LogManager, XmlSerializer);
  87. }
  88. /// <summary>
  89. /// Registers resources that classes will depend on
  90. /// </summary>
  91. protected override void RegisterResources()
  92. {
  93. base.RegisterResources();
  94. RegisterSingleInstance<IServerApplicationPaths>(ApplicationPaths);
  95. RegisterSingleInstance(ServerKernel);
  96. RegisterSingleInstance(ServerConfigurationManager);
  97. RegisterSingleInstance<IIsoManager>(new PismoIsoManager(Logger));
  98. RegisterSingleInstance<IBlurayExaminer>(new BdInfoExaminer());
  99. RegisterSingleInstance<IZipClient>(new DotNetZipClient());
  100. RegisterSingleInstance(ServerFactory.CreateServer(this, ProtobufSerializer, Logger, "Media Browser", "index.html"), false);
  101. var userManager = new UserManager(ServerKernel, Logger, ServerConfigurationManager);
  102. RegisterSingleInstance<IUserManager>(userManager);
  103. RegisterSingleInstance<ILibraryManager>(new LibraryManager(ServerKernel, Logger, TaskManager, userManager, ServerConfigurationManager));
  104. }
  105. /// <summary>
  106. /// Finds the parts.
  107. /// </summary>
  108. protected override void FindParts()
  109. {
  110. base.FindParts();
  111. Resolve<ILibraryManager>().AddParts(GetExports<IResolverIgnoreRule>(), GetExports<IVirtualFolderCreator>(), GetExports<IItemResolver>(), GetExports<IIntroProvider>());
  112. ServerKernel.InstallationManager = (InstallationManager)CreateInstance(typeof(InstallationManager));
  113. _webSocketEvents = new WebSocketEvents(Resolve<IServerManager>(), Resolve<IKernel>(), Resolve<ILogger>(), Resolve<IUserManager>(), Resolve<ILibraryManager>(), ServerKernel.InstallationManager);
  114. }
  115. /// <summary>
  116. /// Restarts this instance.
  117. /// </summary>
  118. public override void Restart()
  119. {
  120. App.Instance.Restart();
  121. }
  122. /// <summary>
  123. /// Gets or sets a value indicating whether this instance can self update.
  124. /// </summary>
  125. /// <value><c>true</c> if this instance can self update; otherwise, <c>false</c>.</value>
  126. public override bool CanSelfUpdate
  127. {
  128. get { return ConfigurationManager.CommonConfiguration.EnableAutoUpdate; }
  129. }
  130. /// <summary>
  131. /// Checks for update.
  132. /// </summary>
  133. /// <param name="cancellationToken">The cancellation token.</param>
  134. /// <param name="progress">The progress.</param>
  135. /// <returns>Task{CheckForUpdateResult}.</returns>
  136. public async override Task<CheckForUpdateResult> CheckForApplicationUpdate(CancellationToken cancellationToken, IProgress<double> progress)
  137. {
  138. var pkgManager = Resolve<IPackageManager>();
  139. var availablePackages = await pkgManager.GetAvailablePackages(CancellationToken.None).ConfigureAwait(false);
  140. var version = ServerKernel.InstallationManager.GetLatestCompatibleVersion(availablePackages, Constants.MBServerPkgName, ConfigurationManager.CommonConfiguration.SystemUpdateLevel);
  141. return version != null ? new CheckForUpdateResult { AvailableVersion = version.version, IsUpdateAvailable = version.version > ApplicationVersion, Package = version } :
  142. new CheckForUpdateResult { AvailableVersion = ApplicationVersion, IsUpdateAvailable = false };
  143. }
  144. /// <summary>
  145. /// Updates the application.
  146. /// </summary>
  147. /// <param name="package">The package that contains the update</param>
  148. /// <param name="cancellationToken">The cancellation token.</param>
  149. /// <param name="progress">The progress.</param>
  150. /// <returns>Task.</returns>
  151. public override Task UpdateApplication(PackageVersionInfo package, CancellationToken cancellationToken, IProgress<double> progress)
  152. {
  153. var pkgManager = Resolve<IPackageManager>();
  154. return pkgManager.InstallPackage(progress, package, cancellationToken);
  155. }
  156. /// <summary>
  157. /// Gets the composable part assemblies.
  158. /// </summary>
  159. /// <returns>IEnumerable{Assembly}.</returns>
  160. protected override IEnumerable<Assembly> GetComposablePartAssemblies()
  161. {
  162. // Gets all plugin assemblies by first reading all bytes of the .dll and calling Assembly.Load against that
  163. // This will prevent the .dll file from getting locked, and allow us to replace it when needed
  164. foreach (var pluginAssembly in Directory
  165. .EnumerateFiles(ApplicationPaths.PluginsPath, "*.dll", SearchOption.TopDirectoryOnly)
  166. .Select(LoadAssembly).Where(a => a != null))
  167. {
  168. yield return pluginAssembly;
  169. }
  170. // Include composable parts in the Api assembly
  171. yield return typeof(ApiService).Assembly;
  172. // Include composable parts in the Dashboard assembly
  173. yield return typeof(DashboardInfo).Assembly;
  174. // Include composable parts in the Model assembly
  175. yield return typeof(SystemInfo).Assembly;
  176. // Include composable parts in the Common assembly
  177. yield return typeof(IKernel).Assembly;
  178. // Include composable parts in the Controller assembly
  179. yield return typeof(Kernel).Assembly;
  180. // Common implementations
  181. yield return typeof(TaskManager).Assembly;
  182. // Server implementations
  183. yield return typeof(ServerApplicationPaths).Assembly;
  184. // Include composable parts in the running assembly
  185. yield return GetType().Assembly;
  186. }
  187. /// <summary>
  188. /// Shuts down.
  189. /// </summary>
  190. public override void Shutdown()
  191. {
  192. App.Instance.Dispatcher.Invoke(App.Instance.Shutdown);
  193. }
  194. /// <summary>
  195. /// Releases unmanaged and - optionally - managed resources.
  196. /// </summary>
  197. /// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
  198. protected override void Dispose(bool dispose)
  199. {
  200. if (dispose)
  201. {
  202. if (_webSocketEvents != null)
  203. {
  204. _webSocketEvents.Dispose();
  205. }
  206. }
  207. base.Dispose(dispose);
  208. }
  209. }
  210. }