using System; using System.Linq; using System.Threading.Tasks; using Cleanuparr.Api.Features.General.Contracts.Requests; using Cleanuparr.Persistence; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Logging; namespace Cleanuparr.Api.Features.General.Controllers; [ApiController] [Route("api/configuration")] [Authorize] public sealed class GeneralConfigController : ControllerBase { private readonly ILogger _logger; private readonly DataContext _dataContext; public GeneralConfigController( ILogger logger, DataContext dataContext) { _logger = logger; _dataContext = dataContext; } [HttpGet("general")] public async Task GetGeneralConfig() { await DataContext.Lock.WaitAsync(); try { var config = await _dataContext.GeneralConfigs .AsNoTracking() .FirstAsync(); return Ok(config); } finally { DataContext.Lock.Release(); } } [HttpPut("general")] public async Task UpdateGeneralConfig( [FromBody] UpdateGeneralConfigRequest request, [FromServices] EventsContext eventsContext) { await DataContext.Lock.WaitAsync(); try { var config = await _dataContext.GeneralConfigs .FirstAsync(); bool wasDryRun = config.DryRun; request.ApplyTo(config, HttpContext.RequestServices, _logger); await _dataContext.SaveChangesAsync(); if (wasDryRun && !config.DryRun) { var deletedStrikes = await eventsContext.Strikes.ExecuteDeleteAsync(); var deletedItems = await eventsContext.DownloadItems .Where(d => !d.Strikes.Any()) .ExecuteDeleteAsync(); _logger.LogWarning( "Dry run disabled — purged all strikes: {Strikes} strikes, {Items} download items removed", deletedStrikes, deletedItems); } return Ok(new { Message = "General configuration updated successfully" }); } catch (Exception ex) { _logger.LogError(ex, "Failed to save General configuration"); throw; } finally { DataContext.Lock.Release(); } } [HttpPost("strikes/purge")] public async Task PurgeAllStrikes( [FromServices] EventsContext eventsContext) { var deletedStrikes = await eventsContext.Strikes.ExecuteDeleteAsync(); var deletedItems = await eventsContext.DownloadItems .Where(d => !d.Strikes.Any()) .ExecuteDeleteAsync(); _logger.LogWarning("Purged all strikes: {strikes} strikes, {items} download items removed", deletedStrikes, deletedItems); return Ok(new { DeletedStrikes = deletedStrikes, DeletedItems = deletedItems }); } }