#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging. # Use the official Microsoft ASP.NET Core image to build the backend FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build-backend WORKDIR /src/backend COPY Back . RUN dotnet restore skydiveLogs-api/skydiveLogs-api.csproj RUN dotnet publish skydiveLogs-api/skydiveLogs-api.csproj -c Release -o /app/publish # Use the official node image to build the Angular app FROM node:22-alpine AS build-frontend WORKDIR /app # COPY ["../Front/skydivelogs-app/package.json", "../Front/skydivelogs-app/package-lock.json*", "./"] COPY Front/skydivelogs-app/package.json . COPY Front/skydivelogs-app/package-lock.json . RUN npm install COPY --exclude=Front/skydivelogs-app/node_modules/* Front/skydivelogs-app/ . RUN npm run build # Use a .NET runtime image to serve both the backend and frontend FROM mcr.microsoft.com/dotnet/aspnet:8.0.16-bookworm-slim-amd64 AS final WORKDIR /app # Install nginx RUN apt-get update && apt-get install -y nginx curl && rm -rf /var/lib/apt/lists/* # Copy custom nginx configuration COPY nginx.conf /etc/nginx/sites-available/default RUN rm -rf /usr/share/nginx/html/* # Copy frontend dist folder to nginx html directory COPY --from=build-frontend --exclude=/app/dist/browser/config/* /app/dist/browser /usr/share/nginx/html RUN mkdir -p /usr/share/nginx/html/config # Copy backend from the correct build stage COPY --from=build-backend /app/publish /app # Expose port 80 for the application EXPOSE 80 ENV ASPNETCORE_URLS http://+:5001 VOLUME /app/Data VOLUME /usr/share/nginx/html/config # Start nginx and the .NET Core app CMD ["sh", "-c", "dotnet /app/skydiveLogs-api.dll & nginx -g 'daemon off;'"]