87 lines
3.2 KiB
C#
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}");
|
|
}
|
|
}
|
|
}
|
|
}
|