@ -24,7 +24,6 @@ using MediaBrowser.Controller.Providers;
using MediaBrowser.Controller.Resolvers ;
using MediaBrowser.Controller.Resolvers ;
using MediaBrowser.Controller.Session ;
using MediaBrowser.Controller.Session ;
using MediaBrowser.Controller.Sorting ;
using MediaBrowser.Controller.Sorting ;
using MediaBrowser.IsoMounter ;
using MediaBrowser.Model.IO ;
using MediaBrowser.Model.IO ;
using MediaBrowser.Model.Logging ;
using MediaBrowser.Model.Logging ;
using MediaBrowser.Model.MediaInfo ;
using MediaBrowser.Model.MediaInfo ;
@ -36,6 +35,7 @@ using MediaBrowser.Server.Implementations.BdInfo;
using MediaBrowser.Server.Implementations.Configuration ;
using MediaBrowser.Server.Implementations.Configuration ;
using MediaBrowser.Server.Implementations.Drawing ;
using MediaBrowser.Server.Implementations.Drawing ;
using MediaBrowser.Server.Implementations.Dto ;
using MediaBrowser.Server.Implementations.Dto ;
using MediaBrowser.Server.Implementations.EntryPoints ;
using MediaBrowser.Server.Implementations.HttpServer ;
using MediaBrowser.Server.Implementations.HttpServer ;
using MediaBrowser.Server.Implementations.IO ;
using MediaBrowser.Server.Implementations.IO ;
using MediaBrowser.Server.Implementations.Library ;
using MediaBrowser.Server.Implementations.Library ;
@ -46,16 +46,14 @@ using MediaBrowser.Server.Implementations.Providers;
using MediaBrowser.Server.Implementations.ServerManager ;
using MediaBrowser.Server.Implementations.ServerManager ;
using MediaBrowser.Server.Implementations.Session ;
using MediaBrowser.Server.Implementations.Session ;
using MediaBrowser.Server.Implementations.WebSocket ;
using MediaBrowser.Server.Implementations.WebSocket ;
using MediaBrowser.ServerApplication.Implementations ;
using MediaBrowser.ServerApplication.FFMpeg ;
using MediaBrowser.ServerApplication.Native ;
using MediaBrowser.WebDashboard.Api ;
using MediaBrowser.WebDashboard.Api ;
using System ;
using System ;
using System.Collections.Generic ;
using System.Collections.Generic ;
using System.Data.SQLite ;
using System.Data ;
using System.Diagnostics ;
using System.IO ;
using System.IO ;
using System.Linq ;
using System.Linq ;
using System.Net ;
using System.Net.Cache ;
using System.Net.Http ;
using System.Net.Http ;
using System.Reflection ;
using System.Reflection ;
using System.Threading ;
using System.Threading ;
@ -68,8 +66,6 @@ namespace MediaBrowser.ServerApplication
/// </summary>
/// </summary>
public class ApplicationHost : BaseApplicationHost < ServerApplicationPaths > , IServerApplicationHost
public class ApplicationHost : BaseApplicationHost < ServerApplicationPaths > , IServerApplicationHost
{
{
internal const int UdpServerPort = 7359 ;
/// <summary>
/// <summary>
/// Gets the server kernel.
/// Gets the server kernel.
/// </summary>
/// </summary>
@ -142,11 +138,6 @@ namespace MediaBrowser.ServerApplication
/// <value>The provider manager.</value>
/// <value>The provider manager.</value>
private IProviderManager ProviderManager { get ; set ; }
private IProviderManager ProviderManager { get ; set ; }
/// <summary>
/// <summary>
/// Gets or sets the zip client.
/// </summary>
/// <value>The zip client.</value>
private IZipClient ZipClient { get ; set ; }
/// <summary>
/// Gets or sets the HTTP server.
/// Gets or sets the HTTP server.
/// </summary>
/// </summary>
/// <value>The HTTP server.</value>
/// <value>The HTTP server.</value>
@ -161,6 +152,7 @@ namespace MediaBrowser.ServerApplication
private IMediaEncoder MediaEncoder { get ; set ; }
private IMediaEncoder MediaEncoder { get ; set ; }
private IIsoManager IsoManager { get ; set ; }
private IIsoManager IsoManager { get ; set ; }
private ISessionManager SessionManager { get ; set ; }
private ILocalizationManager LocalizationManager { get ; set ; }
private ILocalizationManager LocalizationManager { get ; set ; }
@ -174,14 +166,6 @@ namespace MediaBrowser.ServerApplication
private IItemRepository ItemRepository { get ; set ; }
private IItemRepository ItemRepository { get ; set ; }
private INotificationsRepository NotificationsRepository { get ; set ; }
private INotificationsRepository NotificationsRepository { get ; set ; }
/// <summary>
/// The full path to our startmenu shortcut
/// </summary>
protected override string ProductShortcutPath
{
get { return Path . Combine ( Environment . GetFolderPath ( Environment . SpecialFolder . StartMenu ) , "Media Browser 3" , "Media Browser Server.lnk" ) ; }
}
private Task < IHttpServer > _httpServerCreationTask ;
private Task < IHttpServer > _httpServerCreationTask ;
/// <summary>
/// <summary>
@ -255,8 +239,7 @@ namespace MediaBrowser.ServerApplication
RegisterSingleInstance < IBlurayExaminer > ( ( ) = > new BdInfoExaminer ( ) ) ;
RegisterSingleInstance < IBlurayExaminer > ( ( ) = > new BdInfoExaminer ( ) ) ;
ZipClient = new DotNetZipClient ( ) ;
var mediaEncoderTask = RegisterMediaEncoder ( ) ;
RegisterSingleInstance ( ZipClient ) ;
UserDataRepository = new SqliteUserDataRepository ( ApplicationPaths , JsonSerializer , LogManager ) ;
UserDataRepository = new SqliteUserDataRepository ( ApplicationPaths , JsonSerializer , LogManager ) ;
RegisterSingleInstance ( UserDataRepository ) ;
RegisterSingleInstance ( UserDataRepository ) ;
@ -284,10 +267,8 @@ namespace MediaBrowser.ServerApplication
RegisterSingleInstance < ILibrarySearchEngine > ( ( ) = > new LuceneSearchEngine ( ApplicationPaths , LogManager , LibraryManager ) ) ;
RegisterSingleInstance < ILibrarySearchEngine > ( ( ) = > new LuceneSearchEngine ( ApplicationPaths , LogManager , LibraryManager ) ) ;
await RegisterMediaEncoder ( ) . ConfigureAwait ( false ) ;
SessionManager = new SessionManager ( UserDataRepository , ServerConfigurationManager , Logger , UserRepository ) ;
RegisterSingleInstance < ISessionManager > ( SessionManager ) ;
var clientConnectionManager = new SessionManager ( UserDataRepository , ServerConfigurationManager , Logger , UserRepository ) ;
RegisterSingleInstance < ISessionManager > ( clientConnectionManager ) ;
HttpServer = await _httpServerCreationTask . ConfigureAwait ( false ) ;
HttpServer = await _httpServerCreationTask . ConfigureAwait ( false ) ;
RegisterSingleInstance ( HttpServer , false ) ;
RegisterSingleInstance ( HttpServer , false ) ;
@ -310,7 +291,7 @@ namespace MediaBrowser.ServerApplication
await ConfigureNotificationsRepository ( ) . ConfigureAwait ( false ) ;
await ConfigureNotificationsRepository ( ) . ConfigureAwait ( false ) ;
await Task . WhenAll ( itemsTask , displayPreferencesTask , userdataTask ). ConfigureAwait ( false ) ;
await Task . WhenAll ( itemsTask , displayPreferencesTask , userdataTask , mediaEncoderTask ). ConfigureAwait ( false ) ;
SetKernelProperties ( ) ;
SetKernelProperties ( ) ;
}
}
@ -406,27 +387,14 @@ namespace MediaBrowser.ServerApplication
/// <param name="dbPath">The db path.</param>
/// <param name="dbPath">The db path.</param>
/// <returns>Task{IDbConnection}.</returns>
/// <returns>Task{IDbConnection}.</returns>
/// <exception cref="System.ArgumentNullException">dbPath</exception>
/// <exception cref="System.ArgumentNullException">dbPath</exception>
private static async Task < SQLite Connection> ConnectToDb ( string dbPath )
private static Task < IDb Connection> ConnectToDb ( string dbPath )
{
{
if ( string . IsNullOrEmpty ( dbPath ) )
if ( string . IsNullOrEmpty ( dbPath ) )
{
{
throw new ArgumentNullException ( "dbPath" ) ;
throw new ArgumentNullException ( "dbPath" ) ;
}
}
var connectionstr = new SQLiteConnectionStringBuilder
return Sqlite . OpenDatabase ( dbPath ) ;
{
PageSize = 4096 ,
CacheSize = 4096 ,
SyncMode = SynchronizationModes . Normal ,
DataSource = dbPath ,
JournalMode = SQLiteJournalModeEnum . Wal
} ;
var connection = new SQLiteConnection ( connectionstr . ConnectionString ) ;
await connection . OpenAsync ( ) . ConfigureAwait ( false ) ;
return connection ;
}
}
/// <summary>
/// <summary>
@ -477,6 +445,8 @@ namespace MediaBrowser.ServerApplication
IsoManager . AddParts ( GetExports < IIsoMounter > ( ) ) ;
IsoManager . AddParts ( GetExports < IIsoMounter > ( ) ) ;
SessionManager . AddParts ( GetExports < ISessionRemoteController > ( ) ) ;
ImageProcessor . AddParts ( GetExports < IImageEnhancer > ( ) ) ;
ImageProcessor . AddParts ( GetExports < IImageEnhancer > ( ) ) ;
}
}
@ -527,7 +497,6 @@ namespace MediaBrowser.ServerApplication
{
{
NotifyPendingRestart ( ) ;
NotifyPendingRestart ( ) ;
}
}
}
}
/// <summary>
/// <summary>
@ -544,7 +513,7 @@ namespace MediaBrowser.ServerApplication
Logger . ErrorException ( "Error sending server restart web socket message" , ex ) ;
Logger . ErrorException ( "Error sending server restart web socket message" , ex ) ;
}
}
MainStartu p. Restart ( ) ;
NativeAp p. Restart ( ) ;
}
}
/// <summary>
/// <summary>
@ -568,44 +537,44 @@ namespace MediaBrowser.ServerApplication
/// <returns>IEnumerable{Assembly}.</returns>
/// <returns>IEnumerable{Assembly}.</returns>
protected override IEnumerable < Assembly > GetComposablePartAssemblies ( )
protected override IEnumerable < Assembly > GetComposablePartAssemblies ( )
{
{
var list = Directory . EnumerateFiles ( ApplicationPaths . PluginsPath , "*.dll" , SearchOption . TopDirectoryOnly )
. Select ( LoadAssembly )
. Where ( a = > a ! = null )
. ToList ( ) ;
// Gets all plugin assemblies by first reading all bytes of the .dll and calling Assembly.Load against that
// Gets all plugin assemblies by first reading all bytes of the .dll and calling Assembly.Load against that
// This will prevent the .dll file from getting locked, and allow us to replace it when needed
// This will prevent the .dll file from getting locked, and allow us to replace it when needed
foreach ( var pluginAssembly in Directory
. EnumerateFiles ( ApplicationPaths . PluginsPath , "*.dll" , SearchOption . TopDirectoryOnly )
. Select ( LoadAssembly ) . Where ( a = > a ! = null ) )
{
yield return pluginAssembly ;
}
// Include composable parts in the Api assembly
// Include composable parts in the Api assembly
yield return typeof ( ApiEntryPoint ) . Assembly ;
list . Add ( typeof ( ApiEntryPoint ) . Assembly ) ;
// Include composable parts in the Dashboard assembly
// Include composable parts in the Dashboard assembly
yield return typeof ( DashboardInfo ) . Assembly ;
list . Add ( typeof ( DashboardInfo ) . Assembly ) ;
// Include composable parts in the Model assembly
// Include composable parts in the Model assembly
yield return typeof ( SystemInfo ) . Assembly ;
list . Add ( typeof ( SystemInfo ) . Assembly ) ;
// Include composable parts in the Common assembly
// Include composable parts in the Common assembly
yield return typeof ( IApplicationHost ) . Assembly ;
list . Add ( typeof ( IApplicationHost ) . Assembly ) ;
// Include composable parts in the Controller assembly
// Include composable parts in the Controller assembly
yield return typeof ( Kernel ) . Assembly ;
list . Add ( typeof ( Kernel ) . Assembly ) ;
// Include composable parts in the Providers assembly
// Include composable parts in the Providers assembly
yield return typeof ( ImagesByNameProvider ) . Assembly ;
list . Add ( typeof ( ImagesByNameProvider ) . Assembly ) ;
// Common implementations
// Common implementations
yield return typeof ( TaskManager ) . Assembly ;
list . Add ( typeof ( TaskManager ) . Assembly ) ;
// Server implementations
// Server implementations
yield return typeof ( ServerApplicationPaths ) . Assembly ;
list . Add ( typeof ( ServerApplicationPaths ) . Assembly ) ;
// Pismo
list . AddRange ( Assemblies . GetAssembliesWithParts ( ) ) ;
yield return typeof ( PismoIsoManager ) . Assembly ;
// Include composable parts in the running assembly
// Include composable parts in the running assembly
yield return GetType ( ) . Assembly ;
list . Add ( GetType ( ) . Assembly ) ;
return list ;
}
}
private readonly string _systemId = Environment . MachineName . GetMD5 ( ) . ToString ( ) ;
private readonly string _systemId = Environment . MachineName . GetMD5 ( ) . ToString ( ) ;
@ -664,7 +633,7 @@ namespace MediaBrowser.ServerApplication
Logger . ErrorException ( "Error sending server shutdown web socket message" , ex ) ;
Logger . ErrorException ( "Error sending server shutdown web socket message" , ex ) ;
}
}
MainStartu p. Shutdown ( ) ;
NativeAp p. Shutdown ( ) ;
}
}
/// <summary>
/// <summary>
@ -674,36 +643,16 @@ namespace MediaBrowser.ServerApplication
{
{
Logger . Info ( "Requesting administrative access to authorize http server" ) ;
Logger . Info ( "Requesting administrative access to authorize http server" ) ;
// Create a temp file path to extract the bat file to
try
var tmpFile = Path . Combine ( ConfigurationManager . CommonApplicationPaths . TempDirectory , Guid . NewGuid ( ) + ".bat" ) ;
// Extract the bat file
using ( var stream = Assembly . GetExecutingAssembly ( ) . GetManifestResourceStream ( "MediaBrowser.ServerApplication.RegisterServer.bat" ) )
{
using ( var fileStream = File . Create ( tmpFile ) )
{
{
stream . CopyTo ( fileStream ) ;
ServerAuthorization . AuthorizeServer ( ServerConfigurationManager . Configuration . HttpServerPortNumber ,
}
HttpServerUrlPrefix , ServerConfigurationManager . Configuration . LegacyWebSocketPortNumber ,
UdpServerEntryPoint . PortNumber ,
ConfigurationManager . CommonApplicationPaths . TempDirectory ) ;
}
}
catch ( Exception ex )
var startInfo = new ProcessStartInfo
{
FileName = tmpFile ,
Arguments = string . Format ( "{0} {1} {2} {3}" , ServerConfigurationManager . Configuration . HttpServerPortNumber ,
HttpServerUrlPrefix ,
UdpServerPort ,
ServerConfigurationManager . Configuration . LegacyWebSocketPortNumber ) ,
CreateNoWindow = true ,
WindowStyle = ProcessWindowStyle . Hidden ,
Verb = "runas" ,
ErrorDialog = false
} ;
using ( var process = Process . Start ( startInfo ) )
{
{
process. WaitForExit ( ) ;
Logger . ErrorException ( "Error authorizing server" , ex ) ;
}
}
}
}
@ -713,8 +662,7 @@ namespace MediaBrowser.ServerApplication
/// <param name="cancellationToken">The cancellation token.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <param name="progress">The progress.</param>
/// <param name="progress">The progress.</param>
/// <returns>Task{CheckForUpdateResult}.</returns>
/// <returns>Task{CheckForUpdateResult}.</returns>
public override async Task < CheckForUpdateResult > CheckForApplicationUpdate ( CancellationToken cancellationToken ,
public override async Task < CheckForUpdateResult > CheckForApplicationUpdate ( CancellationToken cancellationToken , IProgress < double > progress )
IProgress < double > progress )
{
{
var availablePackages = await InstallationManager . GetAvailablePackagesWithoutRegistrationInfo ( cancellationToken ) . ConfigureAwait ( false ) ;
var availablePackages = await InstallationManager . GetAvailablePackagesWithoutRegistrationInfo ( cancellationToken ) . ConfigureAwait ( false ) ;
@ -745,11 +693,12 @@ namespace MediaBrowser.ServerApplication
/// <returns>HttpMessageHandler.</returns>
/// <returns>HttpMessageHandler.</returns>
protected override HttpMessageHandler GetHttpMessageHandler ( bool enableHttpCompression )
protected override HttpMessageHandler GetHttpMessageHandler ( bool enableHttpCompression )
{
{
return new WebRequestHandler
return HttpMessageHandlerFactory . GetHttpMessageHandler ( enableHttpCompression ) ;
}
protected override void ConfigureAutoRunAtStartup ( bool autorun )
{
{
CachePolicy = new RequestCachePolicy ( RequestCacheLevel . Revalidate ) ,
Autorun . Configure ( autorun ) ;
AutomaticDecompression = enableHttpCompression ? DecompressionMethods . Deflate : DecompressionMethods . None
} ;
}
}
}
}
}
}