2020-06-14 13:13:29 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.IO;
|
2020-07-16 21:17:37 +00:00
|
|
|
|
using System.IO.Compression;
|
2020-06-14 13:13:29 +00:00
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
2020-06-16 22:21:01 +00:00
|
|
|
|
using Microsoft.AspNetCore.Authorization;
|
2020-06-14 13:13:29 +00:00
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using Wabbajack.Common;
|
2021-09-27 12:42:46 +00:00
|
|
|
|
using Wabbajack.DTOs;
|
|
|
|
|
using Wabbajack.DTOs.JsonConverters;
|
|
|
|
|
using Wabbajack.Paths.IO;
|
2020-06-14 13:13:29 +00:00
|
|
|
|
using Wabbajack.Server.DataLayer;
|
|
|
|
|
using Wabbajack.Server.Services;
|
|
|
|
|
|
|
|
|
|
namespace Wabbajack.BuildServer.Controllers
|
|
|
|
|
{
|
|
|
|
|
[ApiController]
|
|
|
|
|
[Route("/list_definitions")]
|
|
|
|
|
public class ListDefinitions : ControllerBase
|
|
|
|
|
{
|
|
|
|
|
private ILogger<ListDefinitions> _logger;
|
|
|
|
|
private SqlService _sql;
|
|
|
|
|
private DiscordWebHook _discord;
|
2021-09-27 12:42:46 +00:00
|
|
|
|
private readonly AppSettings _settings;
|
|
|
|
|
private readonly DTOSerializer _dtos;
|
2020-06-14 13:13:29 +00:00
|
|
|
|
|
2021-09-27 12:42:46 +00:00
|
|
|
|
public ListDefinitions(ILogger<ListDefinitions> logger, SqlService sql, DiscordWebHook discord, AppSettings settings,
|
|
|
|
|
DTOSerializer dtos)
|
2020-06-14 13:13:29 +00:00
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
_sql = sql;
|
|
|
|
|
_discord = discord;
|
2021-09-27 12:42:46 +00:00
|
|
|
|
_settings = settings;
|
|
|
|
|
_dtos = dtos;
|
2020-06-14 13:13:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[Route("ingest")]
|
2020-06-16 22:21:01 +00:00
|
|
|
|
[Authorize(Roles = "User")]
|
2020-06-14 13:13:29 +00:00
|
|
|
|
[HttpPost]
|
|
|
|
|
public async Task<IActionResult> PostIngest()
|
|
|
|
|
{
|
2021-09-27 12:42:46 +00:00
|
|
|
|
var user = Request.Headers[_settings.MetricsKeyHeader].First();
|
|
|
|
|
var use_gzip = Request.Headers[_settings.CompressedBodyHeader].Any();
|
2020-06-14 13:13:29 +00:00
|
|
|
|
_logger.Log(LogLevel.Information, $"Ingesting Modlist Definition for {user}");
|
2020-07-16 21:17:37 +00:00
|
|
|
|
|
2020-06-14 13:13:29 +00:00
|
|
|
|
var modlistBytes = await Request.Body.ReadAllAsync();
|
2020-07-16 21:17:37 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_logger.LogInformation("Spawning ingestion task");
|
|
|
|
|
var tsk = Task.Run(async () =>
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (use_gzip)
|
|
|
|
|
{
|
|
|
|
|
await using var os = new MemoryStream();
|
|
|
|
|
await using var gZipStream =
|
|
|
|
|
new GZipStream(new MemoryStream(modlistBytes), CompressionMode.Decompress);
|
|
|
|
|
await gZipStream.CopyToAsync(os);
|
|
|
|
|
modlistBytes = os.ToArray();
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-27 12:42:46 +00:00
|
|
|
|
var modlist = _dtos.DeserializeAsync<ModList>(new MemoryStream(modlistBytes));
|
2020-07-16 21:17:37 +00:00
|
|
|
|
|
2021-09-27 12:42:46 +00:00
|
|
|
|
var file = KnownFolders.EntryPoint.Combine("mod_list_definitions")
|
2020-07-16 21:17:37 +00:00
|
|
|
|
.Combine($"{user}_{DateTime.UtcNow.ToFileTimeUtc()}.json");
|
|
|
|
|
file.Parent.CreateDirectory();
|
2021-09-27 12:42:46 +00:00
|
|
|
|
await using var stream = file.Open(FileMode.Create, FileAccess.Write);
|
|
|
|
|
await _dtos.Serialize(modlist, stream);
|
2020-07-16 21:17:37 +00:00
|
|
|
|
_logger.Log(LogLevel.Information, $"Done Ingesting Modlist Definition for {user}");
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Error ingesting uploaded modlist");
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2020-06-14 13:13:29 +00:00
|
|
|
|
return Accepted(0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|