ed42a41bcd
- Integra ASP.NET Core Identity: login/password, lockout brute-force, cookie sicuri, password policy forte - Seed automatico utente admin da variabili ambiente (fallback password temporanea forte) - Tutte le pagine principali ora protette con [Authorize] e redirect automatico a /login - Nuovo layout login/logout pulito senza sidebar, spinner durante redirect - NavMenu mostra utente autenticato e logout - Rimosse credenziali Bidoo da env/Docker: ora solo cookie sessione da UI - Aggiornata documentazione: sicurezza, deploy, backup, troubleshooting - Fix NavigationException, SectionRegistry, errori header read-only - Versione incrementata a 1.2.0, pronto per deploy production Tailscale/Unraid
78 lines
2.3 KiB
Docker
78 lines
2.3 KiB
Docker
# ============================================
|
|
# STAGE 1: Build
|
|
# ============================================
|
|
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
|
ARG BUILD_CONFIGURATION=Release
|
|
WORKDIR /src
|
|
|
|
# Copy csproj and restore dependencies (cache layer)
|
|
COPY ["AutoBidder.csproj", "."]
|
|
RUN dotnet restore "./AutoBidder.csproj"
|
|
|
|
# Copy all source files
|
|
COPY . .
|
|
|
|
# Build application
|
|
WORKDIR "/src/."
|
|
RUN dotnet build "./AutoBidder.csproj" -c $BUILD_CONFIGURATION -o /app/build --no-restore
|
|
|
|
# ============================================
|
|
# STAGE 2: Publish
|
|
# ============================================
|
|
FROM build AS publish
|
|
ARG BUILD_CONFIGURATION=Release
|
|
# RIMOSSO --no-build per evitare errore path
|
|
RUN dotnet publish "./AutoBidder.csproj" \
|
|
-c $BUILD_CONFIGURATION \
|
|
-o /app/publish \
|
|
/p:UseAppHost=false
|
|
|
|
# ============================================
|
|
# STAGE 3: Final Runtime
|
|
# ============================================
|
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS final
|
|
WORKDIR /app
|
|
|
|
# Install curl for healthcheck and sqlite3
|
|
RUN apt-get update && \
|
|
apt-get install -y --no-install-recommends \
|
|
curl \
|
|
ca-certificates \
|
|
sqlite3 && \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
# Create data directories for persistence
|
|
RUN mkdir -p /app/Data /app/Data/backups /app/logs && \
|
|
chmod 777 /app/Data /app/logs
|
|
|
|
# Copy published application
|
|
COPY --from=publish /app/publish .
|
|
|
|
# Expose port (single HTTP for simplicity)
|
|
EXPOSE 8080
|
|
|
|
# Environment variables (overridable via docker-compose/unraid)
|
|
ENV ASPNETCORE_URLS=http://+:8080
|
|
ENV ASPNETCORE_ENVIRONMENT=Production
|
|
ENV Kestrel__EnableHttps=false
|
|
|
|
# Autenticazione applicazione (OBBLIGATORIO)
|
|
ENV ADMIN_USERNAME=admin
|
|
ENV ADMIN_PASSWORD=
|
|
|
|
# Health check
|
|
# Aumentato timeout e start-period per Blazor Server
|
|
HEALTHCHECK --interval=30s --timeout=30s --start-period=90s --retries=5 \
|
|
CMD curl -f http://localhost:8080/ || exit 1
|
|
|
|
# Labels for metadata
|
|
LABEL org.opencontainers.image.title="AutoBidder" \
|
|
org.opencontainers.image.description="Sistema automatizzato gestione aste Bidoo - Blazor .NET 8" \
|
|
org.opencontainers.image.version="1.2.0" \
|
|
org.opencontainers.image.vendor="Alby96" \
|
|
org.opencontainers.image.source="https://gitea.encke-hake.ts.net/Alby96/Mimante"
|
|
|
|
# Entry point
|
|
ENTRYPOINT ["dotnet", "AutoBidder.dll"]
|
|
|