2016-04-23 20:03:49 -07:00
|
|
|
|
using System;
|
2014-11-09 11:24:57 -07:00
|
|
|
|
using System.Collections.Generic;
|
2016-04-23 20:03:49 -07:00
|
|
|
|
using System.Diagnostics;
|
2016-04-03 10:34:52 -07:00
|
|
|
|
using System.IO;
|
2014-11-09 11:24:57 -07:00
|
|
|
|
using System.Reflection;
|
2016-12-22 16:53:57 -07:00
|
|
|
|
using System.Runtime.InteropServices.ComTypes;
|
2016-11-10 22:23:15 -07:00
|
|
|
|
using Emby.Server.Core;
|
2016-11-18 14:06:00 -07:00
|
|
|
|
using Emby.Server.Implementations;
|
2016-11-13 14:04:21 -07:00
|
|
|
|
using Emby.Server.Implementations.EntryPoints;
|
2016-11-18 14:06:00 -07:00
|
|
|
|
using Emby.Server.Implementations.FFMpeg;
|
2016-10-25 12:02:04 -07:00
|
|
|
|
using MediaBrowser.Model.IO;
|
2016-11-12 21:33:51 -07:00
|
|
|
|
using MediaBrowser.Model.Logging;
|
|
|
|
|
using MediaBrowser.Model.System;
|
|
|
|
|
using MediaBrowser.ServerApplication.Native;
|
2014-11-09 11:24:57 -07:00
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
namespace MediaBrowser.ServerApplication
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
public class WindowsAppHost : ApplicationHost
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
public WindowsAppHost(ServerApplicationPaths applicationPaths, ILogManager logManager, StartupOptions options, IFileSystem fileSystem, IPowerManagement powerManagement, string releaseAssetFilename, IEnvironmentInfo environmentInfo, MediaBrowser.Controller.Drawing.IImageEncoder imageEncoder, ISystemEvents systemEvents, IMemoryStreamFactory memoryStreamFactory, MediaBrowser.Common.Net.INetworkManager networkManager, Action<string, string> certificateGenerator, Func<string> defaultUsernameFactory)
|
|
|
|
|
: base(applicationPaths, logManager, options, fileSystem, powerManagement, releaseAssetFilename, environmentInfo, imageEncoder, systemEvents, memoryStreamFactory, networkManager, certificateGenerator, defaultUsernameFactory)
|
2015-01-12 20:46:44 -07:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
public override bool IsRunningAsService
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
get { return MainStartup.IsRunningAsService; }
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override FFMpegInstallInfo GetFfmpegInstallInfo()
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
var info = new FFMpegInstallInfo();
|
2014-11-09 11:24:57 -07:00
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
info.FFMpegFilename = "ffmpeg.exe";
|
|
|
|
|
info.FFProbeFilename = "ffprobe.exe";
|
2016-11-13 20:44:54 -07:00
|
|
|
|
info.Version = "20160410";
|
|
|
|
|
info.ArchiveType = "7z";
|
|
|
|
|
info.DownloadUrls = GetDownloadUrls();
|
2015-10-03 11:13:53 -07:00
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
return info;
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-13 20:44:54 -07:00
|
|
|
|
private string[] GetDownloadUrls()
|
|
|
|
|
{
|
|
|
|
|
switch (EnvironmentInfo.SystemArchitecture)
|
|
|
|
|
{
|
|
|
|
|
case Architecture.X64:
|
|
|
|
|
return new[]
|
|
|
|
|
{
|
|
|
|
|
"https://github.com/MediaBrowser/Emby.Resources/raw/master/ffmpeg/windows/ffmpeg-20160410-win64.7z"
|
|
|
|
|
};
|
|
|
|
|
case Architecture.X86:
|
|
|
|
|
return new[]
|
|
|
|
|
{
|
|
|
|
|
"https://github.com/MediaBrowser/Emby.Resources/raw/master/ffmpeg/windows/ffmpeg-20160410-win32.7z"
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new string[] { };
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override void RestartInternal()
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
MainStartup.Restart();
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override List<Assembly> GetAssembliesWithPartsInternal()
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
var list = new List<Assembly>();
|
2014-11-09 11:24:57 -07:00
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
if (!Environment.Is64BitProcess)
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
//list.Add(typeof(PismoIsoManager).Assembly);
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
2016-11-12 21:33:51 -07:00
|
|
|
|
|
|
|
|
|
list.Add(GetType().Assembly);
|
|
|
|
|
|
|
|
|
|
return list;
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override void ShutdownInternal()
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
MainStartup.Shutdown();
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-13 14:04:21 -07:00
|
|
|
|
protected override void AuthorizeServer()
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-11-13 14:04:21 -07:00
|
|
|
|
ServerAuthorization.AuthorizeServer(UdpServerEntryPoint.PortNumber,
|
|
|
|
|
ServerConfigurationManager.Configuration.HttpServerPortNumber,
|
|
|
|
|
ServerConfigurationManager.Configuration.HttpsPortNumber,
|
|
|
|
|
MainStartup.ApplicationPath,
|
|
|
|
|
ConfigurationManager.CommonApplicationPaths.TempDirectory);
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override void ConfigureAutoRunInternal(bool autorun)
|
2014-11-09 11:24:57 -07:00
|
|
|
|
{
|
2016-04-03 10:34:52 -07:00
|
|
|
|
var startupPath = System.Environment.GetFolderPath(System.Environment.SpecialFolder.Startup);
|
2016-11-13 20:44:54 -07:00
|
|
|
|
|
2016-12-22 16:53:57 -07:00
|
|
|
|
if (autorun && !MainStartup.IsRunningAsService)
|
2016-04-03 10:34:52 -07:00
|
|
|
|
{
|
|
|
|
|
//Copy our shortut into the startup folder for this user
|
2016-12-22 16:53:57 -07:00
|
|
|
|
var targetPath = Path.Combine(startupPath, "Emby Server.lnk");
|
|
|
|
|
|
|
|
|
|
IShellLinkW link = (IShellLinkW)new ShellLink();
|
|
|
|
|
|
|
|
|
|
var appPath = Process.GetCurrentProcess().MainModule.FileName;
|
|
|
|
|
|
|
|
|
|
// setup shortcut information
|
|
|
|
|
link.SetDescription(Name);
|
|
|
|
|
link.SetPath(appPath);
|
|
|
|
|
link.SetWorkingDirectory(Path.GetDirectoryName(appPath));
|
|
|
|
|
|
|
|
|
|
// save it
|
|
|
|
|
IPersistFile file = (IPersistFile)link;
|
2016-12-23 01:50:32 -07:00
|
|
|
|
file.Save(targetPath, true);
|
2016-04-03 10:34:52 -07:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//Remove our shortcut from the startup folder for this user
|
2016-12-22 16:53:57 -07:00
|
|
|
|
FileSystemManager.DeleteFile(Path.Combine(startupPath, "Emby Server.lnk"));
|
2016-04-03 10:34:52 -07:00
|
|
|
|
}
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-18 22:52:49 -07:00
|
|
|
|
protected override bool SupportsDualModeSockets
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
protected override void EnableLoopbackInternal(string appName)
|
2016-09-03 10:16:36 -07:00
|
|
|
|
{
|
|
|
|
|
LoopUtil.Run(appName);
|
|
|
|
|
}
|
2016-09-05 22:02:05 -07:00
|
|
|
|
|
2016-11-12 21:33:51 -07:00
|
|
|
|
public override bool SupportsRunningAsService
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override bool CanSelfRestart
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return MainStartup.CanSelfRestart;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override bool SupportsAutoRunAtStartup
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override bool CanSelfUpdate
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return MainStartup.CanSelfUpdate;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-05 22:02:05 -07:00
|
|
|
|
public bool PortsRequireAuthorization(string applicationPath)
|
|
|
|
|
{
|
|
|
|
|
var appNameSrch = Path.GetFileName(applicationPath);
|
|
|
|
|
|
|
|
|
|
var startInfo = new ProcessStartInfo
|
|
|
|
|
{
|
|
|
|
|
FileName = "netsh",
|
|
|
|
|
|
|
|
|
|
Arguments = "advfirewall firewall show rule \"" + appNameSrch + "\"",
|
|
|
|
|
|
|
|
|
|
CreateNoWindow = true,
|
|
|
|
|
UseShellExecute = false,
|
|
|
|
|
WindowStyle = ProcessWindowStyle.Hidden,
|
|
|
|
|
ErrorDialog = false,
|
|
|
|
|
RedirectStandardOutput = true
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
using (var process = Process.Start(startInfo))
|
|
|
|
|
{
|
|
|
|
|
process.Start();
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var data = process.StandardOutput.ReadToEnd() ?? string.Empty;
|
|
|
|
|
|
|
|
|
|
if (data.IndexOf("Block", StringComparison.OrdinalIgnoreCase) != -1)
|
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
Logger.Info("Found potential windows firewall rule blocking Emby Server: " + data);
|
2016-09-05 22:02:05 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//var parts = data.Split('\n');
|
|
|
|
|
|
|
|
|
|
//return parts.Length > 4;
|
2016-09-05 23:50:07 -07:00
|
|
|
|
//return Confirm();
|
2016-09-05 22:02:05 -07:00
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
Logger.ErrorException("Error querying windows firewall", ex);
|
2016-09-05 22:02:05 -07:00
|
|
|
|
|
|
|
|
|
// Hate having to do this
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
process.Kill();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex1)
|
|
|
|
|
{
|
2016-11-12 21:33:51 -07:00
|
|
|
|
Logger.ErrorException("Error killing process", ex1);
|
2016-09-05 22:02:05 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-11-12 21:33:51 -07:00
|
|
|
|
|
2014-11-09 11:24:57 -07:00
|
|
|
|
}
|
2016-11-12 21:33:51 -07:00
|
|
|
|
}
|