Files
Chatbot-ElDia/ChatbotApi/Constrollers/SystemPromptsController.cs
dmolinari 5c97614e4f HttpOnly Cookies y Filtros Avanzados
1. Seguridad: Cookies HttpOnly
Backend (ChatbotApi):
AuthController.cs
: Ahora setea una cookie HttpOnly, Secure y SameSite=Strict llamada X-Access-Token en lugar de devolver el token en el cuerpo de la respuesta.
AuthController.cs
: Añadido endpoint logout para invalidar la cookie.
Program.cs
: Configurado JwtBearer para leer el token desde la cookie si está presente.
Frontend (chatbot-admin):
apiClient.ts
: Configurado con withCredentials: true para enviar cookies automáticamente. Eliminado el interceptor de localStorage.
Login.tsx
: Eliminado manejo de token manual. Ahora solo comprueba éxito (200 OK).
App.tsx
: Refactorizado para comprobar autenticación mediante una petición a /api/admin/contexto al inicio, en lugar de leer localStorage.
2. Filtros y Búsqueda
Logs (
AdminController.cs
 &
LogsViewer.tsx
):
Implementado filtrado en servidor por Fecha Inicio, Fecha Fin y Búsqueda de texto.
Frontend actualizado con selectores de fecha y barra de búsqueda.
Contexto y Fuentes (
ContextManager.tsx
 &
SourceManager.tsx
):
Añadida barra de búsqueda en el cliente para filtrar rápidamente por nombre, valor o descripción.
2025-12-05 14:03:27 -03:00

131 lines
3.9 KiB
C#

using ChatbotApi.Data.Models;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Caching.Memory;
namespace ChatbotApi.Controllers
{
[Authorize]
[Route("api/[controller]")]
[ApiController]
public class SystemPromptsController : ControllerBase
{
private readonly AppContexto _context;
private readonly IMemoryCache _cache;
private const string CacheKey = "ActiveSystemPrompts";
public SystemPromptsController(AppContexto context, IMemoryCache cache)
{
_context = context;
_cache = cache;
}
// GET: api/SystemPrompts
[HttpGet]
public async Task<ActionResult<IEnumerable<SystemPrompt>>> GetSystemPrompts()
{
return await _context.SystemPrompts.OrderByDescending(p => p.CreatedAt).ToListAsync();
}
// GET: api/SystemPrompts/5
[HttpGet("{id}")]
public async Task<ActionResult<SystemPrompt>> GetSystemPrompt(int id)
{
var systemPrompt = await _context.SystemPrompts.FindAsync(id);
if (systemPrompt == null)
{
return NotFound();
}
return systemPrompt;
}
// PUT: api/SystemPrompts/5
[HttpPut("{id}")]
public async Task<IActionResult> PutSystemPrompt(int id, SystemPrompt systemPrompt)
{
if (id != systemPrompt.Id)
{
return BadRequest();
}
systemPrompt.UpdatedAt = DateTime.UtcNow;
_context.Entry(systemPrompt).State = EntityState.Modified;
try
{
await _context.SaveChangesAsync();
_cache.Remove(CacheKey); // Invalidar caché
}
catch (DbUpdateConcurrencyException)
{
if (!SystemPromptExists(id))
{
return NotFound();
}
else
{
throw;
}
}
return NoContent();
}
// POST: api/SystemPrompts
[HttpPost]
public async Task<ActionResult<SystemPrompt>> PostSystemPrompt(SystemPrompt systemPrompt)
{
systemPrompt.CreatedAt = DateTime.UtcNow;
systemPrompt.UpdatedAt = DateTime.UtcNow;
_context.SystemPrompts.Add(systemPrompt);
await _context.SaveChangesAsync();
_cache.Remove(CacheKey); // Invalidar caché
return CreatedAtAction("GetSystemPrompt", new { id = systemPrompt.Id }, systemPrompt);
}
// DELETE: api/SystemPrompts/5
[HttpDelete("{id}")]
public async Task<IActionResult> DeleteSystemPrompt(int id)
{
var systemPrompt = await _context.SystemPrompts.FindAsync(id);
if (systemPrompt == null)
{
return NotFound();
}
_context.SystemPrompts.Remove(systemPrompt);
await _context.SaveChangesAsync();
_cache.Remove(CacheKey); // Invalidar caché
return NoContent();
}
// POST: api/SystemPrompts/ToggleActive/5
[HttpPost("ToggleActive/{id}")]
public async Task<IActionResult> ToggleActive(int id)
{
var systemPrompt = await _context.SystemPrompts.FindAsync(id);
if (systemPrompt == null)
{
return NotFound();
}
systemPrompt.IsActive = !systemPrompt.IsActive;
systemPrompt.UpdatedAt = DateTime.UtcNow;
await _context.SaveChangesAsync();
_cache.Remove(CacheKey); // Invalidar caché
return Ok(new { IsActive = systemPrompt.IsActive });
}
private bool SystemPromptExists(int id)
{
return _context.SystemPrompts.Any(e => e.Id == id);
}
}
}