File size: 2,065 Bytes
93d4490
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4cbb647
 
 
 
93d4490
 
 
4cbb647
93d4490
 
 
 
 
 
 
 
 
 
 
c7da71a
93d4490
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
17ddbdc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# ÉTAPE 1: Image de base
FROM python:3.11-slim

# ÉTAPE 2: Configuration et Dossier de travail
# Ligne supprimée (ENV PORT 8080) pour laisser Hugging Face Spaces injecter le port correct ($PORT, généralement 7860).
ENV FLASK_APP app.py
ENV GUNICORN_WORKERS 4
ENV GUNICORN_THREADS 2

# Création et utilisation du répertoire /app
WORKDIR /app

# ÉTAPE 3: Installation des dépendances (OPTIMISATION CACHING)
# Copie uniquement de requirements.txt pour mettre en cache l'installation
COPY requirements.txt .
# Installation des dépendances du système (eSpeak, PortAudio) et Python
RUN apt-get update && \
    # SUPPRESSION: Retrait de l'ancienne version d'espeak et des données
    apt-get remove -y espeak libespeak1 espeak-data || echo "espeak non installé, continuer" && \
    # AJOUT: Installation d'eSpeak-NG et libportaudio2 (pour la compatibilité)
    apt-get install -y espeak-ng libportaudio2 && \ 
    pip install --no-cache-dir -r requirements.txt \
    && rm requirements.txt


# ÉTAPE 4: Copie de l'Application et des Fichiers
# Nous copions tous les fichiers de l'application et nous assurons que
# l'utilisateur 'user' en est le propriétaire.

# CORRECTION MAJEURE : Ajout du dossier templates
# Ceci est l'étape essentielle pour que Flask trouve vos fichiers HTML
COPY templates /app/templates

# Copie des autres fichiers (y compris app.py, votre point d'entrée)
COPY app.py .
COPY tts_engine.py .
COPY gunicorn.conf.py .

# Copie du script d'entrée
COPY entrypoint.sh .

# NOUVEAU: CORRECTION DES FINS DE LIGNE (Résout 'exec ./entrypoint.sh: no such file or directory')
# Supprime le caractère de retour chariot (\r)
RUN sed -i 's/\r$//' entrypoint.sh

# Le rendre exécutable
RUN chmod +x entrypoint.sh

# ÉTAPE 5: Sécurité et Exécution
# Création et bascule vers l'utilisateur non-root ('user') pour la sécurité
RUN useradd -ms /bin/bash user
RUN chown -R user:user /app
USER user

# Indique à Docker que le conteneur écoute sur ce port
EXPOSE $PORT

# Lance l'application via le script d'entrée
CMD ["./entrypoint.sh"]