Résumé des modifications J'ai implémenté une configuration runtime pour le frontend qui permet de changer l'URL de l'API sans rebuilder l'image Docker. Voici ce qui a été fait : 📝 Fichiers modifiés : frontend/Dockerfile - Ajout du script de génération de config au démarrage frontend/lib/api.ts - Lecture de la config depuis window.__RUNTIME_CONFIG__ frontend/app/layout.tsx - Chargement du script config.js docker-compose.yml - Utilisation de la variable d'environnement .env.example - Documentation de la variable DEPLOYMENT.md - Documentation de la configuration runtime 📄 Fichiers créés : frontend/generate-config.sh - Script de génération de config frontend/public/config.js - Fichier de config (placeholder) frontend/README.md - Documentation du frontend 🚀 Pour résoudre votre problème en production : Sur votre serveur, modifiez le fichier .env : # URL publique de l'API (utilisée par le navigateur) NEXT_PUBLIC_API_URL=https://audioclassifier.benoitsz.com:8001 # CORS doit accepter les requêtes du frontend CORS_ORIGINS=https://audioclassifier.benoitsz.com,https://audioclassifier.benoitsz.com:3000 Ensuite : # Pull les dernières modifications git pull # Rebuild l'image frontend (une seule fois) # Soit via Gitea Actions en poussant sur main # Soit manuellement : # docker build -t git.benoitsz.com/benoit/audio-classifier-frontend:dev -f frontend/Dockerfile . # docker push git.benoitsz.com/benoit/audio-classifier-frontend:dev # Redémarrer les containers docker-compose down docker-compose up -d ✨ Avantages : ✅ Aucun rebuild nécessaire après le premier déploiement ✅ Configuration flexible via variables d'environnement ✅ Compatible avec tous les environnements (dev, staging, prod) ✅ Testé et fonctionnel localement Le frontend générera automatiquement le bon fichier de configuration au démarrage du container avec l'URL de votre serveur !
25 lines
843 B
Plaintext
25 lines
843 B
Plaintext
# Database
|
|
DATABASE_URL=postgresql://audio_user:audio_password@localhost:5432/audio_classifier
|
|
POSTGRES_USER=audio_user
|
|
POSTGRES_PASSWORD=audio_password
|
|
POSTGRES_DB=audio_classifier
|
|
|
|
# Backend API
|
|
# Use "*" to allow all origins (recommended for development/local deployment)
|
|
# Or specify comma-separated URLs for production: http://yourdomain.com,https://yourdomain.com
|
|
CORS_ORIGINS=*
|
|
API_HOST=0.0.0.0
|
|
API_PORT=8000
|
|
|
|
# Audio Analysis Configuration
|
|
ANALYSIS_USE_CLAP=false
|
|
ANALYSIS_NUM_WORKERS=4
|
|
ESSENTIA_MODELS_PATH=/app/models
|
|
AUDIO_LIBRARY_PATH=/path/to/your/audio/library
|
|
|
|
# Frontend
|
|
# API URL accessed by the browser (use port 8001 since backend is mapped to 8001)
|
|
# For production on a remote server, set this to your server's public URL
|
|
# Example: NEXT_PUBLIC_API_URL=http://yourserver.com:8001
|
|
NEXT_PUBLIC_API_URL=http://localhost:8001
|