Move uninstall to add/remove programs. Also fix continuation errors when problem downloading package.
This commit is contained in:
parent
6470c62c50
commit
9e5c8f9721
|
@ -9,6 +9,7 @@ using System.Windows;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Ionic.Zip;
|
using Ionic.Zip;
|
||||||
using MediaBrowser.Installer.Code;
|
using MediaBrowser.Installer.Code;
|
||||||
|
using Microsoft.Win32;
|
||||||
using ServiceStack.Text;
|
using ServiceStack.Text;
|
||||||
|
|
||||||
namespace MediaBrowser.Installer
|
namespace MediaBrowser.Installer
|
||||||
|
@ -19,7 +20,8 @@ namespace MediaBrowser.Installer
|
||||||
public partial class MainWindow : Window
|
public partial class MainWindow : Window
|
||||||
{
|
{
|
||||||
protected PackageVersionClass PackageClass = PackageVersionClass.Release;
|
protected PackageVersionClass PackageClass = PackageVersionClass.Release;
|
||||||
protected Version PackageVersion = new Version(4,0,0,0);
|
protected Version RequestedVersion = new Version(4,0,0,0);
|
||||||
|
protected Version ActualVersion;
|
||||||
protected string PackageName = "MBServer";
|
protected string PackageName = "MBServer";
|
||||||
protected string RootSuffix = "-Server";
|
protected string RootSuffix = "-Server";
|
||||||
protected string TargetExe = "MediaBrowser.ServerApplication.exe";
|
protected string TargetExe = "MediaBrowser.ServerApplication.exe";
|
||||||
|
@ -92,7 +94,7 @@ namespace MediaBrowser.Installer
|
||||||
|
|
||||||
var product = args.GetValueOrDefault("product", null) ?? ConfigurationManager.AppSettings["product"] ?? "server";
|
var product = args.GetValueOrDefault("product", null) ?? ConfigurationManager.AppSettings["product"] ?? "server";
|
||||||
PackageClass = (PackageVersionClass) Enum.Parse(typeof (PackageVersionClass), args.GetValueOrDefault("class", null) ?? ConfigurationManager.AppSettings["class"] ?? "Release");
|
PackageClass = (PackageVersionClass) Enum.Parse(typeof (PackageVersionClass), args.GetValueOrDefault("class", null) ?? ConfigurationManager.AppSettings["class"] ?? "Release");
|
||||||
PackageVersion = new Version(args.GetValueOrDefault("version", "4.0"));
|
RequestedVersion = new Version(args.GetValueOrDefault("version", "4.0"));
|
||||||
|
|
||||||
var callerId = args.GetValueOrDefault("caller", null);
|
var callerId = args.GetValueOrDefault("caller", null);
|
||||||
if (callerId != null)
|
if (callerId != null)
|
||||||
|
@ -140,6 +142,7 @@ namespace MediaBrowser.Installer
|
||||||
|
|
||||||
// Determine Package version
|
// Determine Package version
|
||||||
var version = await GetPackageVersion();
|
var version = await GetPackageVersion();
|
||||||
|
ActualVersion = version.version;
|
||||||
|
|
||||||
// Now try and shut down the server if that is what we are installing and it is running
|
// Now try and shut down the server if that is what we are installing and it is running
|
||||||
var procs = Process.GetProcessesByName("mediabrowser.serverapplication");
|
var procs = Process.GetProcessesByName("mediabrowser.serverapplication");
|
||||||
|
@ -202,6 +205,7 @@ namespace MediaBrowser.Installer
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
SystemClose("Error Downloading Package - " + e.GetType().FullName + "\n\n" + e.Message);
|
SystemClose("Error Downloading Package - " + e.GetType().FullName + "\n\n" + e.Message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -224,11 +228,13 @@ namespace MediaBrowser.Installer
|
||||||
{
|
{
|
||||||
|
|
||||||
SystemClose("Error Removing Archive - " + e.GetType().FullName + "\n\n" + e.Message);
|
SystemClose("Error Removing Archive - " + e.GetType().FullName + "\n\n" + e.Message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
SystemClose("Error Extracting - " + e.GetType().FullName + "\n\n" + e.Message);
|
SystemClose("Error Extracting - " + e.GetType().FullName + "\n\n" + e.Message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create shortcut
|
// Create shortcut
|
||||||
|
@ -240,6 +246,7 @@ namespace MediaBrowser.Installer
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
SystemClose("Error Creating Shortcut - "+e.GetType().FullName+"\n\n"+e.Message);
|
SystemClose("Error Creating Shortcut - "+e.GetType().FullName+"\n\n"+e.Message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// And run
|
// And run
|
||||||
|
@ -250,6 +257,7 @@ namespace MediaBrowser.Installer
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
SystemClose("Error Executing - "+fullPath+ " "+e.GetType().FullName+"\n\n"+e.Message);
|
SystemClose("Error Executing - "+fullPath+ " "+e.GetType().FullName+"\n\n"+e.Message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
SystemClose();
|
SystemClose();
|
||||||
|
@ -264,7 +272,7 @@ namespace MediaBrowser.Installer
|
||||||
var json = await MainClient.DownloadStringTaskAsync("http://www.mb3admin.com/admin/service/package/retrieveAll?name=" + PackageName);
|
var json = await MainClient.DownloadStringTaskAsync("http://www.mb3admin.com/admin/service/package/retrieveAll?name=" + PackageName);
|
||||||
var packages = JsonSerializer.DeserializeFromString<List<PackageInfo>>(json);
|
var packages = JsonSerializer.DeserializeFromString<List<PackageInfo>>(json);
|
||||||
|
|
||||||
var version = packages[0].versions.Where(v => v.classification <= PackageClass).OrderByDescending(v => v.version).FirstOrDefault(v => v.version <= PackageVersion);
|
var version = packages[0].versions.Where(v => v.classification <= PackageClass).OrderByDescending(v => v.version).FirstOrDefault(v => v.version <= RequestedVersion);
|
||||||
if (version == null)
|
if (version == null)
|
||||||
{
|
{
|
||||||
SystemClose("Could not locate download package. Aborting.");
|
SystemClose("Could not locate download package. Aborting.");
|
||||||
|
@ -373,12 +381,66 @@ namespace MediaBrowser.Installer
|
||||||
dashboard.Save();
|
dashboard.Save();
|
||||||
|
|
||||||
}
|
}
|
||||||
var uninstall = new ShellShortcut(Path.Combine(startMenu, "Uninstall " + FriendlyName + ".lnk"))
|
CreateUninstaller(Path.Combine(Path.GetDirectoryName(targetExe) ?? "", "MediaBrowser.Uninstaller.exe")+ " "+ (PackageName == "MBServer" ? "server" : "mbt"), targetExe);
|
||||||
{Path = Path.Combine(Path.GetDirectoryName(targetExe), "MediaBrowser.Uninstaller.exe"), Arguments = (PackageName == "MBServer" ? "server" : "mbt"), Description = "Uninstall " + FriendlyName};
|
|
||||||
uninstall.Save();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Create uninstall entry in add/remove
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="uninstallPath"></param>
|
||||||
|
/// <param name="targetExe"></param>
|
||||||
|
private void CreateUninstaller(string uninstallPath, string targetExe)
|
||||||
|
{
|
||||||
|
using (var parent = Registry.LocalMachine.OpenSubKey(
|
||||||
|
@"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall", true))
|
||||||
|
{
|
||||||
|
if (parent == null)
|
||||||
|
{
|
||||||
|
MessageBox.Show("Uninstall registry key not found.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
RegistryKey key = null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
const string guidText = "{4E76DB4E-1BB9-4A7B-860C-7940779CF7A0}";
|
||||||
|
key = parent.OpenSubKey(guidText, true) ??
|
||||||
|
parent.CreateSubKey(guidText);
|
||||||
|
|
||||||
|
if (key == null)
|
||||||
|
{
|
||||||
|
MessageBox.Show(String.Format("Unable to create uninstaller entry'{0}\\{1}'", @"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall", guidText));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
key.SetValue("DisplayName", FriendlyName);
|
||||||
|
key.SetValue("ApplicationVersion", ActualVersion);
|
||||||
|
key.SetValue("Publisher", "Media Browser Team");
|
||||||
|
key.SetValue("DisplayIcon", targetExe);
|
||||||
|
key.SetValue("DisplayVersion", ActualVersion.ToString(2));
|
||||||
|
key.SetValue("URLInfoAbout", "http://www.mediabrowser3.com");
|
||||||
|
key.SetValue("Contact", "http://community.mediabrowser.tv");
|
||||||
|
key.SetValue("InstallDate", DateTime.Now.ToString("yyyyMMdd"));
|
||||||
|
key.SetValue("UninstallString", uninstallPath);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (key != null)
|
||||||
|
{
|
||||||
|
key.Close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
MessageBox.Show("An error occurred writing uninstall information to the registry.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Prepare a temporary location to download to
|
/// Prepare a temporary location to download to
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Reflection;
|
using Microsoft.Win32;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
@ -195,13 +195,43 @@ namespace MediaBrowser.Uninstaller.Execute
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Remove reference to us
|
||||||
|
RemoveUninstall();
|
||||||
|
|
||||||
// and done
|
// and done
|
||||||
lblHeading.Content = string.Format("Media Browser {0} Uninstalled.", Product);
|
lblHeading.Content = string.Format("Media Browser {0} Uninstalled.", Product);
|
||||||
btnUninstall.Visibility = Visibility.Hidden;
|
btnUninstall.Visibility = Visibility.Hidden;
|
||||||
btnFinished.Visibility = Visibility.Visible;
|
btnFinished.Visibility = Visibility.Visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void RemoveShortcut(string path)
|
private void RemoveUninstall()
|
||||||
|
{
|
||||||
|
|
||||||
|
using (var parent = Registry.LocalMachine.OpenSubKey(
|
||||||
|
@"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall", true))
|
||||||
|
{
|
||||||
|
if (parent == null)
|
||||||
|
{
|
||||||
|
MessageBox.Show("Uninstall registry key not found.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
const string guidText = "{4E76DB4E-1BB9-4A7B-860C-7940779CF7A0}";
|
||||||
|
parent.DeleteSubKey(guidText,false);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
throw new Exception(
|
||||||
|
"An error occurred removing uninstall information from the registry.",
|
||||||
|
ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static
|
||||||
|
void RemoveShortcut(string path)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -34,6 +34,11 @@
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<StartupObject />
|
<StartupObject />
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
<PropertyGroup>
|
||||||
|
<ApplicationIcon>
|
||||||
|
</ApplicationIcon>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup />
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
|
|
Loading…
Reference in New Issue
Block a user