Files
Antifraude.Net/Antifraude.Net/SwaggerAntifraude/Controllers/NOMINATRABAJADORCABECERAController.cs
2026-04-23 14:52:56 +02:00

87 lines
3.2 KiB
C#

using bdAntifraude.db;
using bdAntifraude.dbcontext;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Serialize.Linq.Serializers;
using System.Linq.Expressions;
namespace SwaggerAntifraude.Controllers
{
[ApiController]
[Route("api/[controller]")]
public class NOMINATRABAJADORCABECERAController : GenericoController<NOMINATRABAJADORCABECERA, int>
{
public NOMINATRABAJADORCABECERAController()
: base()
{
}
[Authorize(Policy = "LecturaPolicy")]
[HttpGet("{id}")]
public override IActionResult GetById(int id)
{
try
{
using (var context = tsGestionAntifraude.NuevoContexto(SoloLectura: true, UseLazyLoadingProxies: false))
{
//var dbSet = context.Set<VIDA_ADMINISTRATIVA>();
var entities = context.NOMINATRABAJADORCABECERA
.Include(x => x.IDPERSONANavigation)
.AsNoTracking()
.FirstOrDefault(v => v.IDNOMINATRABAJADOR == id);
if (entities == null)
return NotFound();
return Ok(entities);
}
}
catch (Exception ex)
{
return StatusCode(500, $"Error interno del servidor: {ex.Message}");
}
}
[Authorize(Policy = "LecturaPolicy")]
[HttpPost("filtrar")] // Cambié a POST ya que estás usando [FromBody]
public override async Task<IActionResult> Filtrar([FromBody] ExpressionWrapper request)
{
try
{
using (var context = tsGestionAntifraude.NuevoContexto(SoloLectura: true, UseLazyLoadingProxies: false))
{
// Crear el deserializador
var serializer = new ExpressionSerializer(new Serialize.Linq.Serializers.JsonSerializer());
// Deserializar la expresión
var deserializedExpression = serializer.DeserializeText(request.Expression) as Expression<Func<NOMINATRABAJADORCABECERA, bool>>;
if (deserializedExpression == null)
{
return BadRequest("La expresión deserializada es nula o incorrecta.");
}
var entities = await context.NOMINATRABAJADORCABECERA.Where(deserializedExpression)
.Include(x => x.IDPERSONANavigation)
.AsNoTracking()
.ToListAsync();
// Verificar si el resultado es vacío
if (entities.Count == 0)
{
Console.WriteLine("La consulta no devolvió resultados.");
}
return Ok(entities);
}
}
catch (Exception ex)
{
return StatusCode(500, $"Error interno del servidor: {ex.Message}");
}
}
}
}