mirror of
https://github.com/Cleanuparr/Cleanuparr.git
synced 2026-01-15 09:19:01 -05:00
143 lines
4.0 KiB
C#
143 lines
4.0 KiB
C#
using Data;
|
|
using Data.Models.Events;
|
|
using Data.Enums;
|
|
using Infrastructure.Events;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace Executable.Controllers;
|
|
|
|
[ApiController]
|
|
[Route("api/[controller]")]
|
|
public class EventsController : ControllerBase
|
|
{
|
|
private readonly DataContext _context;
|
|
|
|
public EventsController(DataContext context)
|
|
{
|
|
_context = context;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets recent events
|
|
/// </summary>
|
|
[HttpGet]
|
|
public async Task<ActionResult<List<AppEvent>>> GetEvents(
|
|
[FromQuery] int count = 100,
|
|
[FromQuery] string? severity = null,
|
|
[FromQuery] string? eventType = null)
|
|
{
|
|
var query = _context.Events.AsQueryable();
|
|
|
|
// Apply filters
|
|
if (!string.IsNullOrWhiteSpace(severity))
|
|
{
|
|
if (Enum.TryParse<EventSeverity>(severity, true, out var severityEnum))
|
|
query = query.Where(e => e.Severity == severityEnum);
|
|
}
|
|
|
|
if (!string.IsNullOrWhiteSpace(eventType))
|
|
{
|
|
if (Enum.TryParse<EventType>(eventType, true, out var eventTypeEnum))
|
|
query = query.Where(e => e.EventType == eventTypeEnum);
|
|
}
|
|
|
|
// Order and limit
|
|
var events = await query
|
|
.OrderByDescending(e => e.Timestamp)
|
|
.Take(Math.Min(count, 1000)) // Cap at 1000
|
|
.ToListAsync();
|
|
|
|
return Ok(events);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets a specific event by ID
|
|
/// </summary>
|
|
[HttpGet("{id}")]
|
|
public async Task<ActionResult<AppEvent>> GetEvent(Guid id)
|
|
{
|
|
var eventEntity = await _context.Events.FindAsync(id);
|
|
|
|
if (eventEntity == null)
|
|
return NotFound();
|
|
|
|
return Ok(eventEntity);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets events by tracking ID
|
|
/// </summary>
|
|
[HttpGet("tracking/{trackingId}")]
|
|
public async Task<ActionResult<List<AppEvent>>> GetEventsByTracking(Guid trackingId)
|
|
{
|
|
var events = await _context.Events
|
|
.Where(e => e.TrackingId == trackingId)
|
|
.OrderBy(e => e.Timestamp)
|
|
.ToListAsync();
|
|
|
|
return Ok(events);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets event statistics
|
|
/// </summary>
|
|
[HttpGet("stats")]
|
|
public async Task<ActionResult<object>> GetEventStats()
|
|
{
|
|
var stats = new
|
|
{
|
|
TotalEvents = await _context.Events.CountAsync(),
|
|
EventsBySeverity = await _context.Events
|
|
.GroupBy(e => e.Severity)
|
|
.Select(g => new { Severity = g.Key.ToString(), Count = g.Count() })
|
|
.ToListAsync(),
|
|
EventsByType = await _context.Events
|
|
.GroupBy(e => e.EventType)
|
|
.Select(g => new { EventType = g.Key.ToString(), Count = g.Count() })
|
|
.OrderByDescending(x => x.Count)
|
|
.Take(10)
|
|
.ToListAsync(),
|
|
RecentEventsCount = await _context.Events
|
|
.Where(e => e.Timestamp > DateTime.UtcNow.AddHours(-24))
|
|
.CountAsync()
|
|
};
|
|
|
|
return Ok(stats);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Manually triggers cleanup of old events
|
|
/// </summary>
|
|
[HttpPost("cleanup")]
|
|
public async Task<ActionResult<object>> CleanupOldEvents([FromQuery] int retentionDays = 30)
|
|
{
|
|
var cutoffDate = DateTime.UtcNow.AddDays(-retentionDays);
|
|
|
|
await _context.Events
|
|
.Where(e => e.Timestamp < cutoffDate)
|
|
.ExecuteDeleteAsync();
|
|
|
|
return Ok();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets unique event types
|
|
/// </summary>
|
|
[HttpGet("types")]
|
|
public async Task<ActionResult<List<string>>> GetEventTypes()
|
|
{
|
|
var types = Enum.GetNames(typeof(EventType)).ToList();
|
|
return Ok(types);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets unique severities
|
|
/// </summary>
|
|
[HttpGet("severities")]
|
|
public async Task<ActionResult<List<string>>> GetSeverities()
|
|
{
|
|
var severities = Enum.GetNames(typeof(EventSeverity)).ToList();
|
|
return Ok(severities);
|
|
}
|
|
} |