# Utiliser une image Node.js légère FROM node:20-alpine # Build arguments pour invalider le cache si nécessaire ARG BUILD_DATE=unknown ARG BUILD_VERSION=unknown ARG CACHE_BUST=1 LABEL build.date="${BUILD_DATE}" \ build.version="${BUILD_VERSION}" \ cache.bust="${CACHE_BUST}" # Invalider le cache en utilisant CACHE_BUST dans une instruction RUN # Cela force Docker à reconstruire à partir de cette ligne si CACHE_BUST change # Utiliser CACHE_BUST dans une variable d'environnement pour forcer l'invalidation RUN echo "Cache bust: ${CACHE_BUST}" && \ echo "Build date: ${BUILD_DATE}" && \ date && \ echo "${CACHE_BUST}" > /tmp/cache_bust.txt WORKDIR /app # Variables d'environnement à définir AVANT npm install ENV HUSKY=0 ENV HUSKY_SKIP_INSTALL=1 ENV NODE_PATH=/app/node_modules ENV NODE_ENV=production # Installation des dépendances système RUN apk add --no-cache git python3 # Copie des fichiers de dépendances COPY package.json package-lock.json* ./ # Installation des dépendances Node RUN npm install --legacy-peer-deps --ignore-scripts # Patch du package aoe_technology_radar pour inclure gray-matter dans les dépendances runtime RUN node -e "const fs=require('fs');const pkgPath='./node_modules/aoe_technology_radar/package.json';const pkg=JSON.parse(fs.readFileSync(pkgPath,'utf8'));pkg.dependencies=pkg.dependencies||{};pkg.dependencies['gray-matter']='^4.0.3';pkg.dependencies['postcss']='^8.4.47';pkg.scripts=pkg.scripts||{};pkg.scripts.prepare='';fs.writeFileSync(pkgPath,JSON.stringify(pkg,null,2));" # Copie du reste du projet COPY . . RUN chmod +x scripts/start-business.sh # Préparer .techradar une fois pour toutes (évite les réinstallations au runtime) # Le script techradar.js crée automatiquement .techradar lors de l'exécution # Création manuelle de .techradar en copiant depuis node_modules RUN mkdir -p .techradar && \ cp -r node_modules/aoe_technology_radar/* .techradar/ # Créer le fichier hash pour éviter la recréation (calculé séparément pour éviter les problèmes d'échappement) RUN node -e "const crypto=require('crypto');const fs=require('fs');const hash=crypto.createHash('sha256').update(fs.readFileSync('package.json')).digest('hex');fs.writeFileSync('.techradar/hash',hash);" RUN node -e "const fs=require('fs');const p='.techradar/package.json';if(!fs.existsSync(p)){console.error('.techradar/package.json not found');process.exit(1);}const pkg=JSON.parse(fs.readFileSync(p,'utf8'));pkg.scripts=pkg.scripts||{};pkg.scripts.prepare='';fs.writeFileSync(p,JSON.stringify(pkg,null,2));" # Installer les dépendances dans .techradar (y compris devDependencies pour tsx nécessaire à build:data) RUN cd .techradar && npm install --legacy-peer-deps --include=dev RUN cd .techradar && npm run build:icons # --- CONFIGURATION BUSINESS --- # Application de la logique Business (remplacement de la config et des données) # Préserver la structure de dossiers par date pour que le framework puisse parser les dates RUN cp radar-business/config-business.json config.json && \ rm -rf radar/* && \ mkdir -p radar/2025-01-15 && \ cp -r radar-business/2025-01-15/* radar/2025-01-15/ # Copier les fichiers nécessaires dans .techradar avant le build (comme le fait techradar.js) RUN mkdir -p .techradar/data/radar/2025-01-15 && \ cp -r radar-business/2025-01-15/* .techradar/data/radar/2025-01-15/ && \ cp -r public .techradar/public && \ cp config.json .techradar/data/config.json && \ cp about.md .techradar/data/about.md 2>/dev/null || echo "about.md not found, skipping" && \ cp custom.css .techradar/src/styles/custom.css 2>/dev/null || echo "custom.css not found, skipping" && \ echo "Fichiers public copiés" && \ echo "📁 Vérification des fichiers team dans .techradar/public/:" && \ ls -la .techradar/public/ | grep -E "(team\.html|team-visualization)" && echo "✅ Fichiers team trouvés" || (echo "⚠️ Fichiers team non trouvés dans .techradar/public/" && echo "📁 Contenu de public/ source:" && ls -la public/ | head -10) && \ echo "📁 Vérification que team.html existe dans public/ source:" && \ test -f public/team.html && echo "✅ public/team.html existe" || echo "❌ public/team.html n'existe pas" # Diagnostic : compter les fichiers markdown copiés dans .techradar/data/radar RUN echo "📊 Comptage des fichiers .md dans .techradar/data/radar" && \ find .techradar/data/radar -name "*.md" | wc -l && \ find .techradar/data/radar -name "*.md" | head -5 # Créer la page Next.js /team RUN mkdir -p .techradar/src/pages && \ cat > .techradar/src/pages/team.tsx << 'EOF' import Head from "next/head"; import { CustomPage } from "@/pages/_app"; const TeamPage: CustomPage = () => { return ( <>