# Utiliser une image Node.js légère FROM node:20-alpine 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 # 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));" RUN cd .techradar && npm install --legacy-peer-deps 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/ # Builder l'application en mode production pour éviter Fast Refresh RUN cd .techradar && npm run build # Exposition du port interne EXPOSE 3000 # Démarrage du serveur via script (exporte les variables avant npm run serve) CMD ["./scripts/start-business.sh"]