# --- Etapa 1: Build --- # Usamos el SDK de .NET 9 (o el que corresponda) para compilar. FROM mcr.microsoft.com/dotnet/sdk:9.0 AS build WORKDIR /src # Copiamos los archivos de proyecto (.sln y .csproj) y restauramos las dependencias. # Esto es una optimización de caché de Docker. COPY GestionIntegralWeb.sln . COPY Backend/GestionIntegral.Api/GestionIntegral.Api.csproj Backend/GestionIntegral.Api/ # Restauramos los paquetes NuGet. RUN dotnet restore "GestionIntegralWeb.sln" # Copiamos todo el resto del código fuente. COPY . . # Nos movemos al directorio del proyecto y lo construimos en modo Release. WORKDIR "/src/Backend/GestionIntegral.Api" RUN dotnet build "GestionIntegral.Api.csproj" -c Release -o /app/build # --- Etapa 2: Publish --- # Publicamos la aplicación, lo que genera los artefactos listos para producción. FROM build AS publish RUN dotnet publish "GestionIntegral.Api.csproj" -c Release -o /app/publish /p:UseAppHost=false # --- Etapa 3: Final --- # Usamos la imagen de runtime de ASP.NET, que es mucho más ligera que el SDK. FROM mcr.microsoft.com/dotnet/aspnet:9.0 WORKDIR /app # La imagen mcr.microsoft.com/dotnet/aspnet:9.0 está basada en Debian. # Necesitamos instalar libgdiplus para que System.Drawing y el motor de reportes funcionen. RUN apt-get update && apt-get install -y libgdiplus libc6-dev && rm -rf /var/lib/apt/lists/* COPY --from=publish /app/publish . # El puerto en el que la API escuchará DENTRO del contenedor. # Usaremos 8080 para evitar conflictos si en el futuro corres algo en el puerto 80. EXPOSE 8080 # El comando para iniciar la API cuando el contenedor arranque. ENTRYPOINT ["dotnet", "GestionIntegral.Api.dll"]