Spaces:
Running
Running
Create utils.py
Browse files
utils.py
ADDED
@@ -0,0 +1,47 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import os
|
2 |
+
from functools import lru_cache
|
3 |
+
import logging
|
4 |
+
|
5 |
+
# Configuration d'un logger simple pour ce module
|
6 |
+
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
|
7 |
+
|
8 |
+
@lru_cache(maxsize=32)
|
9 |
+
def load_prompt(filename: str) -> str:
|
10 |
+
"""
|
11 |
+
Charge le contenu d'un fichier de prompt depuis le dossier 'prompts'.
|
12 |
+
|
13 |
+
Cette fonction met en cache les résultats pour éviter de lire le même fichier
|
14 |
+
plusieurs fois, ce qui améliore les performances.
|
15 |
+
|
16 |
+
Args:
|
17 |
+
filename (str): Le nom du fichier à charger (ex: 'philo_type1.txt').
|
18 |
+
|
19 |
+
Returns:
|
20 |
+
str: Le contenu du fichier de prompt, ou un message d'erreur si le fichier
|
21 |
+
est introuvable ou si une autre erreur de lecture se produit.
|
22 |
+
"""
|
23 |
+
try:
|
24 |
+
# Construit le chemin vers le dossier 'prompts' en supposant qu'il se
|
25 |
+
# trouve au même niveau que le répertoire contenant ce fichier utils.py
|
26 |
+
# Structure attendue :
|
27 |
+
# /votre-projet/
|
28 |
+
# |- app.py
|
29 |
+
# |- utils.py
|
30 |
+
# |- prompts/
|
31 |
+
# |- philo_type1.txt
|
32 |
+
# |- ...
|
33 |
+
base_dir = os.path.dirname(os.path.abspath(__file__))
|
34 |
+
prompt_path = os.path.join(base_dir, 'prompts', filename)
|
35 |
+
|
36 |
+
with open(prompt_path, 'r', encoding='utf-8') as f:
|
37 |
+
return f.read()
|
38 |
+
|
39 |
+
except FileNotFoundError:
|
40 |
+
# Erreur très importante à logger car elle empêche l'app de fonctionner
|
41 |
+
logging.error(f"FICHIER DE PROMPT MANQUANT: Impossible de trouver '{prompt_path}'")
|
42 |
+
return f"Erreur critique du serveur: Le fichier de prompt '{filename}' est manquant."
|
43 |
+
|
44 |
+
except Exception as e:
|
45 |
+
# Capture toute autre erreur potentielle (ex: droits de lecture)
|
46 |
+
logging.error(f"Erreur inattendue lors du chargement du prompt '{filename}': {e}")
|
47 |
+
return "Erreur critique du serveur lors de la lecture d'un fichier de configuration."
|