using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Reflection; using System.Security.Claims; using System.Text; using System.Threading.Tasks; using FluentFTP; using FluentFTP.Helpers; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; using Nettle; using Wabbajack.Common; using Wabbajack.Lib.GitHub; using Wabbajack.Lib.ModListRegistry; using Wabbajack.Server.DataLayer; using Wabbajack.Server.Services; namespace Wabbajack.BuildServer.Controllers { [Authorize(Roles="Author")] [Route("/author_controls")] public class AuthorControls : ControllerBase { private ILogger _logger; private SqlService _sql; private readonly QuickSync _quickSync; public AuthorControls(ILogger logger, SqlService sql, QuickSync quickSync) { _logger = logger; _sql = sql; _quickSync = quickSync; } [Route("login/{authorKey}")] [AllowAnonymous] public async Task Login(string authorKey) { Response.Cookies.Append(ApiKeyAuthenticationHandler.ApiKeyHeaderName, authorKey); return Redirect($"{Consts.WabbajackBuildServerUri}author_controls/home"); } [Route("lists")] [HttpGet] public async Task AuthorLists() { var user = User.FindFirstValue(ClaimTypes.Name); List lists = new(); var client = await Client.Get(); foreach (var file in Enum.GetValues()) { lists.AddRange((await client.GetData(file)).Lists.Where(l => l.Maintainers.Contains(user)) .Select(lst => lst.Links.MachineURL)); } return Ok(lists); } [Route("lists/download_metadata")] [HttpPost] public async Task PostDownloadMetadata() { var user = User.FindFirstValue(ClaimTypes.Name); var data = (await Request.Body.ReadAllTextAsync()).FromJsonString(); var client = await Client.Get(); try { await client.UpdateList(user, data); await _quickSync.Notify(); } catch (Exception ex) { _logger.LogError(ex, "During posting of download_metadata"); return BadRequest(ex); } return Ok(data); } private static async Task HomePageTemplate(object o) { var data = await AbsolutePath.EntryPoint.Combine(@"Controllers\Templates\AuthorControls.html") .ReadAllTextAsync(); var func = NettleEngine.GetCompiler().Compile(data); return func(o); } [Route("home")] [Authorize("")] public async Task HomePage() { var user = User.FindFirstValue(ClaimTypes.Name); var files = (await _sql.AllAuthoredFiles()) .Where(af => af.Author == user) .Select(af => new { Size = af.Size.FileSizeToString(), OriginalSize = af.Size, Name = af.OriginalFileName, MangledName = af.MungedName, UploadedDate = af.LastTouched }) .OrderBy(f => f.Name) .ThenBy(f => f.UploadedDate) .ToList(); var result = HomePageTemplate(new { User = user, TotalUsage = files.Select(f => f.OriginalSize).Sum().ToFileSizeString(), WabbajackFiles = files.Where(f => f.Name.EndsWith(Consts.ModListExtensionString)), OtherFiles = files.Where(f => !f.Name.EndsWith(Consts.ModListExtensionString)) }); return new ContentResult { ContentType = "text/html", StatusCode = (int)HttpStatusCode.OK, Content = await result}; } } }