wabbajack/Wabbajack.Server/Services/NonNexusDownloadValidator.cs

89 lines
3.6 KiB
C#
Raw Normal View History

2020-05-13 21:52:34 +00:00
using System;
using System.Linq;
using System.Threading;
2020-05-13 21:52:34 +00:00
using System.Threading.Tasks;
using Microsoft.Extensions.Logging;
using Wabbajack.BuildServer;
using Wabbajack.Common;
2021-09-27 12:42:46 +00:00
using Wabbajack.Downloaders;
using Wabbajack.DTOs.DownloadStates;
2020-05-13 21:52:34 +00:00
using Wabbajack.Server.DataLayer;
using LogLevel = Microsoft.Extensions.Logging.LogLevel;
namespace Wabbajack.Server.Services
{
public class NonNexusDownloadValidator : AbstractService<NonNexusDownloadValidator, int>
{
private SqlService _sql;
2021-09-27 12:42:46 +00:00
private readonly DownloadDispatcher _dispatcher;
private readonly ParallelOptions _parallelOptions;
2020-05-13 21:52:34 +00:00
2021-09-27 12:42:46 +00:00
public NonNexusDownloadValidator(ILogger<NonNexusDownloadValidator> logger, AppSettings settings, SqlService sql,
QuickSync quickSync, DownloadDispatcher dispatcher, ParallelOptions parallelOptions)
: base(logger, settings, quickSync, TimeSpan.FromHours(2))
2020-05-13 21:52:34 +00:00
{
_sql = sql;
2021-09-27 12:42:46 +00:00
_dispatcher = dispatcher;
_parallelOptions = parallelOptions;
2020-05-13 21:52:34 +00:00
}
public override async Task<int> Execute()
{
var archives = await _sql.GetNonNexusModlistArchives();
2020-05-13 22:48:33 +00:00
_logger.Log(LogLevel.Information, $"Validating {archives.Count} non-Nexus archives");
2021-09-27 12:42:46 +00:00
await _dispatcher.PrepareAll(archives.Select(a => a.State));
2021-05-13 19:41:33 +00:00
var random = new Random();
2021-09-27 12:42:46 +00:00
var results = await archives.PMap(_parallelOptions, async archive =>
2020-05-13 21:52:34 +00:00
{
try
{
2021-05-13 19:41:33 +00:00
await Task.Delay(random.Next(1000, 5000));
var token = new CancellationTokenSource();
token.CancelAfter(TimeSpan.FromMinutes(10));
ReportStarting(archive.State.PrimaryKeyString);
2020-05-13 22:48:33 +00:00
bool isValid = false;
switch (archive.State)
{
2021-03-04 12:50:40 +00:00
//case WabbajackCDNDownloader.State _:
2021-02-17 05:46:05 +00:00
//case GoogleDriveDownloader.State _: // Let's try validating Google again 2/10/2021
2021-09-27 12:42:46 +00:00
case GameFileSource _:
2021-05-13 19:41:33 +00:00
isValid = true;
break;
2021-09-27 12:42:46 +00:00
case Manual _:
case ModDB _:
case Http h when h.Url.ToString().StartsWith("https://wabbajack"):
2020-05-13 22:48:33 +00:00
isValid = true;
break;
default:
2021-09-27 12:42:46 +00:00
isValid = await _dispatcher.Verify(archive, token.Token);
2020-05-13 22:48:33 +00:00
break;
}
2020-05-13 21:52:34 +00:00
return (Archive: archive, IsValid: isValid);
}
2020-05-13 22:48:33 +00:00
catch (Exception ex)
2020-05-13 21:52:34 +00:00
{
2020-05-13 22:48:33 +00:00
_logger.Log(LogLevel.Warning, $"Error for {archive.Name} {archive.State.PrimaryKeyString} {ex}");
2020-05-13 21:52:34 +00:00
return (Archive: archive, IsValid: false);
}
finally
{
ReportEnding(archive.State.PrimaryKeyString);
}
2020-05-13 21:52:34 +00:00
2021-09-27 12:42:46 +00:00
}).ToList();
2020-05-13 21:52:34 +00:00
await _sql.UpdateNonNexusModlistArchivesStatus(results);
var failed = results.Count(r => !r.IsValid);
var passed = results.Count() - failed;
2020-05-13 22:48:33 +00:00
foreach(var (archive, _) in results.Where(f => !f.IsValid))
2020-05-13 21:52:34 +00:00
_logger.Log(LogLevel.Warning, $"Validation failed for {archive.Name} from {archive.State.PrimaryKeyString}");
_logger.Log(LogLevel.Information, $"Non-nexus validation completed {failed} out of {passed} failed");
return failed;
}
}
}