mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
db3b441d19
* When IPS4 (e.g. LL) sites based on CEF fail to validate, they no longer hang the app * If a IPS4 CEF site throws a 503, or 400 error, retry * Clean out the cookies during IPS4 CEF downloads so that they don't cause 400 errors * Limit the number of connections to IPS4 sites to 20 per minute (one per 6 seconds) * If a site *does* timeout, throw a log of the CEF state into `CEFStates` for easier debugging by the WJ team * Wrote a new CLI utility to stress test the Verification routines. * Ignore files that have `\Edit Scripts\Export\` in their path
116 lines
3.2 KiB
C#
116 lines
3.2 KiB
C#
using System;
|
|
using System.Linq;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using System.Windows;
|
|
using CefSharp;
|
|
using CefSharp.OffScreen;
|
|
using Wabbajack.Common;
|
|
using Wabbajack.Lib.LibCefHelpers;
|
|
|
|
namespace Wabbajack.Lib.WebAutomation
|
|
{
|
|
public class Driver : IDisposable
|
|
{
|
|
private IWebBrowser _browser;
|
|
private CefSharpWrapper _driver;
|
|
|
|
public Driver()
|
|
{
|
|
|
|
_browser = new ChromiumWebBrowser();
|
|
|
|
_driver = new CefSharpWrapper(_browser);
|
|
}
|
|
public static async Task<Driver> Create()
|
|
{
|
|
var driver = new Driver();
|
|
await driver._driver.WaitForInitialized();
|
|
return driver;
|
|
}
|
|
|
|
public async Task<Uri?> NavigateTo(Uri uri, CancellationToken? token = null)
|
|
{
|
|
try
|
|
{
|
|
await _driver.NavigateTo(uri, token);
|
|
return await GetLocation();
|
|
}
|
|
catch (TaskCanceledException ex)
|
|
{
|
|
await DumpState(uri, ex);
|
|
throw;
|
|
}
|
|
}
|
|
|
|
private async Task DumpState(Uri uri, Exception ex)
|
|
{
|
|
var file = AbsolutePath.EntryPoint.Combine("CEFStates", DateTime.UtcNow.ToFileTimeUtc().ToString())
|
|
.WithExtension(new Extension(".html"));
|
|
file.Parent.CreateDirectory();
|
|
var source = await GetSourceAsync();
|
|
var cookies = await Helpers.GetCookies();
|
|
var cookiesString = string.Join('\n', cookies.Select(c => c.Name + " - " + c.Value));
|
|
await file.WriteAllTextAsync(uri + "\n " + source + "\n" + ex + "\n" + cookiesString);
|
|
}
|
|
|
|
public async Task<long> NavigateToAndDownload(Uri uri, AbsolutePath absolutePath, bool quickMode = false, CancellationToken? token = null)
|
|
{
|
|
try
|
|
{
|
|
return await _driver.NavigateToAndDownload(uri, absolutePath, quickMode: quickMode, token: token);
|
|
}
|
|
catch (TaskCanceledException ex) {
|
|
await DumpState(uri, ex);
|
|
throw;
|
|
}
|
|
}
|
|
|
|
public async ValueTask<Uri?> GetLocation()
|
|
{
|
|
try
|
|
{
|
|
return new Uri(_browser.Address);
|
|
}
|
|
catch (UriFormatException)
|
|
{
|
|
return null;
|
|
}
|
|
}
|
|
|
|
public async ValueTask<string> GetSourceAsync()
|
|
{
|
|
return await _browser.GetSourceAsync();
|
|
}
|
|
|
|
public Action<Uri?> DownloadHandler {
|
|
set => _driver.DownloadHandler = value;
|
|
}
|
|
|
|
public Task<string> GetAttr(string selector, string attr)
|
|
{
|
|
return _driver.EvaluateJavaScript($"document.querySelector(\"{selector}\").{attr}");
|
|
}
|
|
|
|
public Task<string> EvalJavascript(string js)
|
|
{
|
|
return _driver.EvaluateJavaScript(js);
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
_browser.Dispose();
|
|
}
|
|
|
|
public static void ClearCache()
|
|
{
|
|
Helpers.ClearCookies();
|
|
}
|
|
|
|
public async Task DeleteCookiesWhere(Func<Helpers.Cookie, bool> filter)
|
|
{
|
|
await Helpers.DeleteCookiesWhere(filter);
|
|
}
|
|
}
|
|
}
|