aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Installer/MainWindow.xaml.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Installer/MainWindow.xaml.cs')
-rw-r--r--MediaBrowser.Installer/MainWindow.xaml.cs40
1 files changed, 37 insertions, 3 deletions
diff --git a/MediaBrowser.Installer/MainWindow.xaml.cs b/MediaBrowser.Installer/MainWindow.xaml.cs
index 1ead1fced..644566325 100644
--- a/MediaBrowser.Installer/MainWindow.xaml.cs
+++ b/MediaBrowser.Installer/MainWindow.xaml.cs
@@ -80,6 +80,20 @@ namespace MediaBrowser.Installer
PackageClass = (PackageVersionClass) Enum.Parse(typeof (PackageVersionClass), ConfigurationManager.AppSettings["class"] ?? "Release");
var cmdArgs = Environment.GetCommandLineArgs();
Archive = cmdArgs.Length > 1 ? cmdArgs[1] : null;
+ var callerId = cmdArgs.Length > 2 ? cmdArgs[2] : null;
+ if (callerId != null)
+ {
+ // Wait for our caller to exit
+ try
+ {
+ var process = Process.GetProcessById(Convert.ToInt32(callerId));
+ process.WaitForExit();
+ }
+ catch (ArgumentException)
+ {
+ // wasn't running
+ }
+ }
switch (product.ToLower())
{
@@ -108,13 +122,15 @@ namespace MediaBrowser.Installer
/// <returns></returns>
protected async Task DoInstall(string archive)
{
- lblStatus.Text = string.Format("Downloading {0}...", FriendlyName);
+ lblStatus.Text = string.Format("Installing {0}...", FriendlyName);
// Determine Package version
var version = await GetPackageVersion();
// Now try and shut down the server if that is what we are installing and it is running
- if (PackageName == "MBServer" && Process.GetProcessesByName("mediabrowser.serverapplication").Length != 0)
+ var procs = Process.GetProcessesByName("mediabrowser.serverapplication");
+ var server = procs.Length > 0 ? procs[0] : null;
+ if (PackageName == "MBServer" && server != null)
{
lblStatus.Text = "Shutting Down Media Browser Server...";
using (var client = new WebClient())
@@ -122,6 +138,14 @@ namespace MediaBrowser.Installer
try
{
client.UploadString("http://localhost:8096/mediabrowser/System/Shutdown", "");
+ try
+ {
+ server.WaitForExit();
+ }
+ catch (ArgumentException)
+ {
+ // already gone
+ }
}
catch (WebException e)
{
@@ -278,7 +302,17 @@ namespace MediaBrowser.Installer
{
// Delete old content of system
var systemDir = Path.Combine(RootPath, "system");
- if (Directory.Exists(systemDir)) Directory.Delete(systemDir, true);
+ if (Directory.Exists(systemDir))
+ {
+ try
+ {
+ Directory.Delete(systemDir, true);
+ }
+ catch
+ {
+ // we tried...
+ }
+ }
// And extract
using (var fileStream = File.OpenRead(archive))