Merge branch 'main' into blocking_fixes

This commit is contained in:
JanuarySnow 2023-07-26 09:59:39 +01:00 committed by GitHub
commit 940bc7b77d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 2 deletions

View File

@ -3,6 +3,9 @@
### Version - TBA
* Fixed some UI issues arising from 3.2.0.0 changes - more informative error text, drive space checking, wiki link button
#### Version - 3.2.0.1 - 7/23/2023
* Code cleanup: re-added some network and diagnostic code missing since 2.5
#### Version - 3.2.0.0 - 7/16/2023
* Fixed issues related to high RAM usage
* The resumable downloads now reserve drive space to write to in advance instead of being managed in system RAM

View File

@ -3,6 +3,7 @@ using System.Collections.Generic;
using System.IO;
using System.IO.Compression;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Net.Http.Json;
using System.Reactive.Subjects;
@ -47,6 +48,7 @@ public class Client
private readonly ILogger<Client> _logger;
private readonly ITokenProvider<WabbajackApiState> _token;
private bool _inited;
public Client(ILogger<Client> logger, HttpClient client, ITokenProvider<WabbajackApiState> token,
@ -60,6 +62,7 @@ public class Client
_dtos = dtos;
_limiter = limiter;
_hashLimiter = hashLimiter;
_inited = false;
}
private async ValueTask<HttpRequestMessage> MakeMessage(HttpMethod method, Uri uri, HttpContent? content = null)
@ -75,11 +78,23 @@ public class Client
return msg;
}
public async Task SendMetric(string action, string subject)
public async Task SendMetric(string action, string subject, bool rebound = true)
{
if (!_inited)
{
_logger.LogInformation("Init Client: {Id}", (await _token.Get())?.MetricsKey);
_inited = true;
}
var msg = await MakeMessage(HttpMethod.Get,
new Uri($"{_configuration.BuildServerUrl}metrics/{action}/{subject}"));
await _client.SendAsync(msg);
var result = await _client.SendAsync(msg);
if (rebound && result.StatusCode is HttpStatusCode.Forbidden or HttpStatusCode.InternalServerError)
{
_logger.LogError("HTTP Error: {Result}", result);
await SendMetric("rebound", "Error", false);
Environment.Exit(0);
}
}
public async Task<ServerAllowList> LoadDownloadAllowList()