Test Docker
This commit is contained in:
@@ -1,30 +1,26 @@
|
||||
using Elecciones.Database;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Serilog;
|
||||
|
||||
// Esta es la estructura estándar y recomendada.
|
||||
var builder = WebApplication.CreateBuilder(args);
|
||||
|
||||
// --- 1. Configuración de Servicios ---
|
||||
// 1. Configurar Serilog. Esta es la forma correcta de integrarlo.
|
||||
builder.Host.UseSerilog((context, services, configuration) => configuration
|
||||
.ReadFrom.Configuration(context.Configuration)
|
||||
.ReadFrom.Services(services)
|
||||
.Enrich.FromLogContext()
|
||||
.WriteTo.Console()
|
||||
.WriteTo.File("logs/api-.log", rollingInterval: RollingInterval.Day));
|
||||
|
||||
// Añade la cadena de conexión y el DbContext para Entity Framework Core.
|
||||
// 2. Añadir servicios al contenedor.
|
||||
var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
|
||||
builder.Services.AddDbContext<EleccionesDbContext>(options =>
|
||||
options.UseSqlServer(connectionString));
|
||||
|
||||
// Añade los servicios para los controladores de la API.
|
||||
builder.Services.AddControllers();
|
||||
|
||||
// Configura CORS para permitir que tu frontend (y www.eldia.com) consuman la API.
|
||||
// builder.Services.AddCors(options =>
|
||||
// {
|
||||
// options.AddDefaultPolicy(policy =>
|
||||
// {
|
||||
// policy.WithOrigins("http://localhost:5173", "http://localhost:8600", "http://www.eldia.com", "http://elecciones2025.eldia.com")
|
||||
// .AllowAnyHeader()
|
||||
// .AllowAnyMethod();
|
||||
// });
|
||||
// });
|
||||
|
||||
var allowedOrigins = builder.Configuration["AllowedOrigins"]?.Split(',') ?? [];
|
||||
var allowedOrigins = builder.Configuration["AllowedOrigins"]?.Split(',') ?? Array.Empty<string>();
|
||||
builder.Services.AddCors(options =>
|
||||
{
|
||||
options.AddDefaultPolicy(policy =>
|
||||
@@ -38,34 +34,28 @@ builder.Services.AddCors(options =>
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
// Añade la configuración de Swagger/OpenAPI para la documentación de la API.
|
||||
builder.Services.AddEndpointsApiExplorer();
|
||||
builder.Services.AddSwaggerGen();
|
||||
|
||||
|
||||
// 3. Construir la aplicación.
|
||||
var app = builder.Build();
|
||||
|
||||
// --- 2. Configuración del Pipeline de Peticiones HTTP ---
|
||||
// 4. Configurar el pipeline de peticiones HTTP.
|
||||
// Añadimos el logging de peticiones de Serilog aquí.
|
||||
app.UseSerilogRequestLogging();
|
||||
|
||||
// Habilita la UI de Swagger en el entorno de desarrollo.
|
||||
if (app.Environment.IsDevelopment())
|
||||
{
|
||||
app.UseSwagger();
|
||||
app.UseSwaggerUI();
|
||||
}
|
||||
|
||||
// Redirige las peticiones HTTP a HTTPS.
|
||||
app.UseHttpsRedirection();
|
||||
|
||||
// Usa la política de CORS que definimos arriba.
|
||||
app.UseCors();
|
||||
|
||||
// Habilita la autorización (lo configuraremos si es necesario más adelante).
|
||||
app.UseAuthorization();
|
||||
|
||||
// Mapea las rutas a los controladores de la API.
|
||||
app.MapControllers();
|
||||
|
||||
// Inicia la aplicación.
|
||||
// 5. Ejecutar la aplicación.
|
||||
// El try/catch/finally se puede omitir; el logging de Serilog ya se encarga de los errores fatales.
|
||||
app.Run();
|
||||
Reference in New Issue
Block a user