crash log fixes, bug fixes, and more info during failures

This commit is contained in:
Timothy Baldridge 2019-08-04 16:08:03 -06:00
parent 197873ec1d
commit e8f2ad2f16
9 changed files with 129 additions and 6 deletions

View File

@ -13,6 +13,7 @@ namespace Wabbajack.Common
public static string GameFolderFilesDir = "Game Folder Files"; public static string GameFolderFilesDir = "Game Folder Files";
public static string ModPackMagic = "Celebration!, Cheese for Everyone!"; public static string ModPackMagic = "Celebration!, Cheese for Everyone!";
public static string BSACreationDir = "TEMP_BSA_FILES"; public static string BSACreationDir = "TEMP_BSA_FILES";
public static string MegaPrefix = "https://mega.nz/#!";
public static HashSet<string> SupportedArchives = new HashSet<string>() { ".zip", ".rar", ".7z", ".7zip" }; public static HashSet<string> SupportedArchives = new HashSet<string>() { ".zip", ".rar", ".7z", ".7zip" };
public static HashSet<string> SupportedBSAs = new HashSet<string>() { ".bsa", ".ba2" }; public static HashSet<string> SupportedBSAs = new HashSet<string>() { ".bsa", ".ba2" };

View File

@ -3,6 +3,7 @@ using IniParser;
using Newtonsoft.Json; using Newtonsoft.Json;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Diagnostics;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Net.Http; using System.Net.Http;
@ -244,5 +245,28 @@ namespace Wabbajack.Common
return result.Result; return result.Result;
} }
public static string ExceptionToString(this Exception ex)
{
StringBuilder sb = new StringBuilder();
while (ex != null)
{
sb.AppendLine(ex.Message);
var st = new StackTrace(ex, true);
foreach (var frame in st.GetFrames())
{
sb.AppendLine($"{frame.GetFileName()}:{frame.GetMethod().Name}:{frame.GetFileLineNumber()}:{frame.GetFileColumnNumber()}");
}
ex = ex.InnerException;
}
return sb.ToString();
}
public static void CrashDump(Exception e)
{
File.WriteAllText($"{DateTime.Now.ToString("yyyyMMddTHHmmss_crash_log.txt")}", ExceptionToString(e));
}
} }
} }

View File

@ -353,6 +353,13 @@ namespace Wabbajack
Id = match.ToString() Id = match.ToString()
}; };
} }
else if (general.directURL != null && general.directURL.StartsWith(Consts.MegaPrefix))
{
result = new MEGAArchive()
{
URL = general.directURL
};
}
else if (general.directURL != null && general.directURL.StartsWith("https://www.dropbox.com/")) else if (general.directURL != null && general.directURL.StartsWith("https://www.dropbox.com/"))
{ {
var uri = new UriBuilder((string)general.directURL); var uri = new UriBuilder((string)general.directURL);

View File

@ -1,4 +1,5 @@
using Compression.BSA; using CG.Web.MegaApiClient;
using Compression.BSA;
using SevenZipExtractor; using SevenZipExtractor;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
@ -235,13 +236,27 @@ namespace Wabbajack
Info("Getting Nexus API Key, if a browser appears, please accept"); Info("Getting Nexus API Key, if a browser appears, please accept");
NexusAPIKey = NexusAPI.GetNexusAPIKey(); NexusAPIKey = NexusAPI.GetNexusAPIKey();
var user_status = NexusAPI.GetUserStatus(NexusAPIKey);
if (!user_status.is_premium) {
Info($"Automated installs with Wabbajack requires a premium nexus account. {user_status.name} is not a premium account");
return;
}
DownloadMissingArchives(missing); DownloadMissingArchives(missing);
return;
} }
private void DownloadMissingArchives(List<Archive> missing) private void DownloadMissingArchives(List<Archive> missing)
{ {
missing.PMap(archive => missing.PMap(archive =>
{ {
Info($"Downloading {archive.Name}");
var output_path = Path.Combine(DownloadFolder, archive.Name);
if (output_path.FileExists())
File.Delete(output_path);
switch (archive) { switch (archive) {
case NexusMod a: case NexusMod a:
Info($"Downloading Nexus Archive - {archive.Name} - {a.GameName} - {a.ModID} - {a.FileID}"); Info($"Downloading Nexus Archive - {archive.Name} - {a.GameName} - {a.ModID} - {a.FileID}");
@ -257,6 +272,9 @@ namespace Wabbajack
} }
DownloadURLDirect(archive, url); DownloadURLDirect(archive, url);
break; break;
case MEGAArchive a:
DownloadMegaArchive(a);
break;
case GoogleDriveMod a: case GoogleDriveMod a:
DownloadGoogleDriveArchive(a); DownloadGoogleDriveArchive(a);
break; break;
@ -285,6 +303,19 @@ namespace Wabbajack
DownloadURLDirect(a, confirm.ToString(), client); DownloadURLDirect(a, confirm.ToString(), client);
} }
private void DownloadMegaArchive(MEGAArchive m)
{
var client = new MegaApiClient();
Status("Logging into MEGA (as anonymous)");
client.LoginAnonymous();
var file_link = new Uri(m.URL);
var node = client.GetNodeFromLink(file_link);
Status("Downloading MEGA file: {0}", m.Name);
var output_path = Path.Combine(DownloadFolder, m.Name);
client.DownloadFile(file_link, output_path);
}
private void DownloadGoogleDriveArchive(GoogleDriveMod a) private void DownloadGoogleDriveArchive(GoogleDriveMod a)
{ {
var initial_url = $"https://drive.google.com/uc?id={a.Id}&export=download"; var initial_url = $"https://drive.google.com/uc?id={a.Id}&export=download";
@ -329,7 +360,19 @@ namespace Wabbajack
var response = client.GetSync(url); var response = client.GetSync(url);
var stream = response.Content.ReadAsStreamAsync(); var stream = response.Content.ReadAsStreamAsync();
try
{
stream.Wait(); stream.Wait();
}
catch (Exception ex)
{
};
if (stream.IsFaulted)
{
Info($"While downloading {url} - {Utils.ExceptionToString(stream.Exception)}");
return;
}
string header_var = "1"; string header_var = "1";
if (response.Content.Headers.Contains("Content-Length")) if (response.Content.Headers.Contains("Content-Length"))
@ -338,9 +381,7 @@ namespace Wabbajack
long content_size = header_var != null ? long.Parse(header_var) : 1; long content_size = header_var != null ? long.Parse(header_var) : 1;
var output_path = Path.Combine(DownloadFolder, archive.Name); var output_path = Path.Combine(DownloadFolder, archive.Name);
;
if (output_path.FileExists())
File.Delete(output_path);
using (var webs = stream.Result) using (var webs = stream.Result)
using (var fs = File.OpenWrite(output_path)) using (var fs = File.OpenWrite(output_path))

View File

@ -6,7 +6,7 @@
xmlns:local="clr-namespace:Wabbajack" xmlns:local="clr-namespace:Wabbajack"
mc:Ignorable="d" mc:Ignorable="d"
Title="Wabbajack" Height="700" Width="800" Title="Wabbajack" Height="700" Width="800"
Style="{StaticResource {x:Type Window}}" Icon="square_transparent_icon.ico" WindowStyle="ToolWindow"> Style="{StaticResource {x:Type Window}}" Icon="square_transparent_icon.ico" WindowStyle="ToolWindow" Closing="Window_Closing">
<Grid Margin="16"> <Grid Margin="16">
<Grid.RowDefinitions> <Grid.RowDefinitions>
<RowDefinition Height="Auto"></RowDefinition> <RowDefinition Height="Auto"></RowDefinition>

View File

@ -1,5 +1,6 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.ComponentModel;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Text; using System.Text;
@ -25,6 +26,7 @@ namespace Wabbajack
{ {
public MainWindow() public MainWindow()
{ {
var args = Environment.GetCommandLineArgs(); var args = Environment.GetCommandLineArgs();
bool DebugMode = false; bool DebugMode = false;
string MO2Folder = null, InstallFolder = null, MO2Profile = null; string MO2Folder = null, InstallFolder = null, MO2Profile = null;
@ -40,11 +42,13 @@ namespace Wabbajack
InitializeComponent(); InitializeComponent();
var context = new AppState(Dispatcher, "Building"); var context = new AppState(Dispatcher, "Building");
SetupHandlers(context);
this.DataContext = context; this.DataContext = context;
WorkQueue.Init((id, msg, progress) => context.SetProgress(id, msg, progress), WorkQueue.Init((id, msg, progress) => context.SetProgress(id, msg, progress),
(max, current) => context.SetQueueSize(max, current)); (max, current) => context.SetQueueSize(max, current));
if (DebugMode) if (DebugMode)
{ {
new Thread(() => new Thread(() =>
@ -81,5 +85,23 @@ namespace Wabbajack
} }
} }
private AppState _state;
private void SetupHandlers(AppState state)
{
_state = state;
AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(AppHandler);
}
private void AppHandler(object sender, UnhandledExceptionEventArgs e)
{
_state.LogMsg("Uncaught error:");
_state.LogMsg(Utils.ExceptionToString((Exception)e.ExceptionObject));
}
private void Window_Closing(object sender, CancelEventArgs e)
{
Application.Current.Shutdown();
}
} }
} }

View File

@ -84,5 +84,29 @@ namespace Wabbajack
} }
public class UserStatus
{
public string user_id;
public string key;
public string name;
public bool is_premium;
public bool is_supporter;
public string email;
public string profile_url;
}
public static UserStatus GetUserStatus(string apikey)
{
var url = "https://api.nexusmods.com/v1/users/validate.json";
var client = BaseNexusClient(apikey);
using (var s = client.GetStreamSync(url))
{
return s.FromJSON<UserStatus>();
}
}
} }
} }

View File

@ -70,6 +70,9 @@
<Reference Include="Costura, Version=4.0.0.0, Culture=neutral, PublicKeyToken=9919ef960d84173d, processorArchitecture=MSIL"> <Reference Include="Costura, Version=4.0.0.0, Culture=neutral, PublicKeyToken=9919ef960d84173d, processorArchitecture=MSIL">
<HintPath>..\packages\Costura.Fody.4.0.0\lib\net40\Costura.dll</HintPath> <HintPath>..\packages\Costura.Fody.4.0.0\lib\net40\Costura.dll</HintPath>
</Reference> </Reference>
<Reference Include="MegaApiClient, Version=1.7.1.495, Culture=neutral, PublicKeyToken=0480d311efbeb4e2, processorArchitecture=MSIL">
<HintPath>..\packages\MegaApiClient.1.7.1\lib\net46\MegaApiClient.dll</HintPath>
</Reference>
<Reference Include="Newtonsoft.Json, Version=12.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL"> <Reference Include="Newtonsoft.Json, Version=12.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
<HintPath>..\packages\Newtonsoft.Json.12.0.2\lib\net45\Newtonsoft.Json.dll</HintPath> <HintPath>..\packages\Newtonsoft.Json.12.0.2\lib\net45\Newtonsoft.Json.dll</HintPath>
</Reference> </Reference>

View File

@ -2,6 +2,7 @@
<packages> <packages>
<package id="Costura.Fody" version="4.0.0" targetFramework="net472" /> <package id="Costura.Fody" version="4.0.0" targetFramework="net472" />
<package id="Fody" version="5.1.1" targetFramework="net472" developmentDependency="true" /> <package id="Fody" version="5.1.1" targetFramework="net472" developmentDependency="true" />
<package id="MegaApiClient" version="1.7.1" targetFramework="net472" />
<package id="Newtonsoft.Json" version="12.0.2" targetFramework="net472" /> <package id="Newtonsoft.Json" version="12.0.2" targetFramework="net472" />
<package id="Ookii.Dialogs.Wpf" version="1.1.0" targetFramework="net472" /> <package id="Ookii.Dialogs.Wpf" version="1.1.0" targetFramework="net472" />
<package id="SharpCompress" version="0.23.0" targetFramework="net472" /> <package id="SharpCompress" version="0.23.0" targetFramework="net472" />