This commit is contained in:
LukePulverenti 2013-02-27 18:47:13 -05:00
commit 4435e83e69

View File

@ -30,6 +30,8 @@ namespace MediaBrowser.Installer
protected string TempLocation = Path.Combine(Path.GetTempPath(), "MediaBrowser"); protected string TempLocation = Path.Combine(Path.GetTempPath(), "MediaBrowser");
protected WebClient MainClient = new WebClient();
public MainWindow() public MainWindow()
{ {
GetArgs(); GetArgs();
@ -48,6 +50,15 @@ namespace MediaBrowser.Installer
{ {
e.Cancel = true; e.Cancel = true;
} }
if (MainClient.IsBusy)
{
MainClient.CancelAsync();
while (MainClient.IsBusy)
{
// wait to finish
}
}
MainClient.Dispose();
ClearTempLocation(TempLocation); ClearTempLocation(TempLocation);
base.OnClosing(e); base.OnClosing(e);
} }
@ -129,6 +140,8 @@ namespace MediaBrowser.Installer
dlAnimation.StopAnimation(); dlAnimation.StopAnimation();
prgProgress.Visibility = btnCancel.Visibility = Visibility.Hidden; prgProgress.Visibility = btnCancel.Visibility = Visibility.Hidden;
if (archive == null) return; //we canceled or had an error that was already reported
// Extract // Extract
lblStatus.Content = "Extracting Package..."; lblStatus.Content = "Extracting Package...";
try try
@ -167,28 +180,25 @@ namespace MediaBrowser.Installer
protected async Task<PackageVersionInfo> GetPackageVersion() protected async Task<PackageVersionInfo> GetPackageVersion()
{ {
using (var client = new WebClient()) try
{ {
try // get the package information for the server
{ var json = await MainClient.DownloadStringTaskAsync("http://www.mb3admin.com/admin/service/package/retrieveAll?name=" + PackageName);
// get the package information for the server var packages = JsonSerializer.DeserializeFromString<List<PackageInfo>>(json);
var json = await client.DownloadStringTaskAsync("http://www.mb3admin.com/admin/service/package/retrieveAll?name=" + PackageName);
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 <= PackageVersion);
if (version == null) if (version == null)
{
SystemClose("Could not locate download package. Aborting.");
return null;
}
return version;
}
catch (Exception e)
{ {
SystemClose(e.GetType().FullName + "\n\n" + e.Message); SystemClose("Could not locate download package. Aborting.");
return null;
} }
return version;
} }
catch (Exception e)
{
SystemClose(e.GetType().FullName + "\n\n" + e.Message);
}
return null; return null;
} }
@ -198,23 +208,32 @@ namespace MediaBrowser.Installer
/// <returns>The fully qualified name of the downloaded package</returns> /// <returns>The fully qualified name of the downloaded package</returns>
protected async Task<string> DownloadPackage(PackageVersionInfo version) protected async Task<string> DownloadPackage(PackageVersionInfo version)
{ {
using (var client = new WebClient()) try
{ {
var archiveFile = Path.Combine(PrepareTempLocation(), version.targetFilename);
// setup download progress and download the package
MainClient.DownloadProgressChanged += DownloadProgressChanged;
try try
{ {
var archiveFile = Path.Combine(PrepareTempLocation(), version.targetFilename); await MainClient.DownloadFileTaskAsync(version.sourceUrl, archiveFile);
// setup download progress and download the package
client.DownloadProgressChanged += DownloadProgressChanged;
await client.DownloadFileTaskAsync(version.sourceUrl, archiveFile);
return archiveFile;
} }
catch (Exception e) catch (WebException e)
{ {
SystemClose(e.GetType().FullName + "\n\n" + e.Message); if (e.Status == WebExceptionStatus.RequestCanceled)
{
return null;
}
throw;
} }
return archiveFile;
} }
return ""; catch (Exception e)
{
SystemClose(e.GetType().FullName + "\n\n" + e.Message);
}
return "";
} }