Files
SIG-CM/src/SIGCM.API/Program.cs

86 lines
2.3 KiB
C#
Raw Normal View History

2025-12-18 13:32:50 -03:00
using System.Text;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.IdentityModel.Tokens;
using SIGCM.Infrastructure;
using SIGCM.Infrastructure.Data;
var builder = WebApplication.CreateBuilder(args);
2025-12-18 13:32:50 -03:00
// 1. Agregar servicios al contenedor.
builder.Services.AddControllers();
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
2025-12-18 13:32:50 -03:00
// 2. Configurar Autenticación JWT
var key = Encoding.ASCII.GetBytes(builder.Configuration["Jwt:Key"]!);
builder.Services.AddAuthentication(options =>
{
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
})
.AddJwtBearer(options =>
{
options.RequireHttpsMetadata = false;
options.SaveToken = true;
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuerSigningKey = true,
IssuerSigningKey = new SymmetricSecurityKey(key),
ValidateIssuer = true,
ValidIssuer = builder.Configuration["Jwt:Issuer"],
ValidateAudience = true,
ValidAudience = builder.Configuration["Jwt:Audience"],
ValidateLifetime = true,
ClockSkew = TimeSpan.Zero
};
});
// 3. Agregar Capa de Infraestructura
builder.Services.AddInfrastructure();
2025-12-18 13:32:50 -03:00
// 4. Configurar CORS
builder.Services.AddCors(options =>
{
options.AddPolicy("AllowFrontend",
policy =>
{
2025-12-18 13:32:50 -03:00
policy.WithOrigins(
"http://localhost:5173",
"http://localhost:5174",
"http://localhost:5175",
"http://localhost:5177")
.AllowAnyHeader()
.AllowAnyMethod();
});
});
var app = builder.Build();
2025-12-18 13:32:50 -03:00
// --- Configuración del Pipeline HTTP ---
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
}
app.UseHttpsRedirection();
2025-12-18 13:32:50 -03:00
app.UseStaticFiles(); // Para servir imágenes
app.UseCors("AllowFrontend");
2025-12-18 13:32:50 -03:00
// IMPORTANTE: El orden importa aquí
app.UseAuthentication(); // <- Esto faltaba
app.UseAuthorization();
app.MapControllers();
2025-12-18 13:32:50 -03:00
// Inicializar BD
using (var scope = app.Services.CreateScope())
{
var initializer = scope.ServiceProvider.GetRequiredService<DbInitializer>();
await initializer.InitializeAsync();
}
2025-12-18 13:32:50 -03:00
app.Run();