Update app.py
Browse files
app.py
CHANGED
@@ -3,6 +3,8 @@ from google import genai
|
|
3 |
import os
|
4 |
from datetime import datetime
|
5 |
import uuid
|
|
|
|
|
6 |
|
7 |
app = Flask(__name__)
|
8 |
app.secret_key = os.urandom(24) # Requis pour utiliser les sessions Flask
|
@@ -11,12 +13,45 @@ app.secret_key = os.urandom(24) # Requis pour utiliser les sessions Flask
|
|
11 |
# os.environ["GOOGLE_API_KEY"] = "VOTRE_GEMINI_API_KEY"
|
12 |
client = genai.Client(api_key=os.environ.get("GOOGLE_API_KEY", "GEMINI_API_KEY"))
|
13 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
14 |
@app.route('/')
|
15 |
def index():
|
16 |
# Créer un ID de session unique s'il n'existe pas déjà
|
17 |
if 'session_id' not in session:
|
18 |
session['session_id'] = str(uuid.uuid4())
|
19 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
20 |
|
21 |
@app.route('/chat', methods=['POST'])
|
22 |
def chat():
|
@@ -28,17 +63,40 @@ def chat():
|
|
28 |
chat_session = get_or_create_chat_session(session_id)
|
29 |
|
30 |
try:
|
31 |
-
#
|
32 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
33 |
|
34 |
# Formater l'historique pour l'interface
|
35 |
-
history = []
|
36 |
-
for msg in chat_session.get_history():
|
37 |
-
history.append({
|
38 |
-
'role': msg.role,
|
39 |
-
'content': msg.parts[0].text,
|
40 |
-
'timestamp': datetime.now().strftime("%H:%M")
|
41 |
-
})
|
42 |
|
43 |
return jsonify({
|
44 |
'response': response.text,
|
@@ -66,8 +124,13 @@ def get_or_create_chat_session(session_id):
|
|
66 |
def reset_chat():
|
67 |
"""Réinitialise la session de chat actuelle"""
|
68 |
session_id = session.get('session_id')
|
|
|
|
|
|
|
|
|
|
|
|
|
69 |
if hasattr(app, 'chat_sessions') and session_id in app.chat_sessions:
|
70 |
-
# Créer une nouvelle session
|
71 |
app.chat_sessions[session_id] = client.chats.create(model="gemini-2.0-flash")
|
72 |
|
73 |
return jsonify({'status': 'success'})
|
|
|
3 |
import os
|
4 |
from datetime import datetime
|
5 |
import uuid
|
6 |
+
import io
|
7 |
+
import httpx
|
8 |
|
9 |
app = Flask(__name__)
|
10 |
app.secret_key = os.urandom(24) # Requis pour utiliser les sessions Flask
|
|
|
13 |
# os.environ["GOOGLE_API_KEY"] = "VOTRE_GEMINI_API_KEY"
|
14 |
client = genai.Client(api_key=os.environ.get("GOOGLE_API_KEY", "GEMINI_API_KEY"))
|
15 |
|
16 |
+
# URL du PDF à analyser (fixe dans cette version)
|
17 |
+
PDF_URL = "http://www.ddl.cnrs.fr/projets/clhass/PageWeb/ressources/fang.pdf"
|
18 |
+
|
19 |
+
# Variable globale pour stocker le fichier PDF une fois téléchargé
|
20 |
+
pdf_file = None
|
21 |
+
|
22 |
+
def load_pdf():
|
23 |
+
"""Télécharge et prépare le fichier PDF pour l'analyse"""
|
24 |
+
global pdf_file
|
25 |
+
if pdf_file is None:
|
26 |
+
try:
|
27 |
+
print(f"Téléchargement du PDF depuis {PDF_URL}...")
|
28 |
+
pdf_content = httpx.get(PDF_URL).content
|
29 |
+
pdf_io = io.BytesIO(pdf_content)
|
30 |
+
|
31 |
+
# Télécharger le fichier via l'API Gemini
|
32 |
+
pdf_file = client.files.upload(
|
33 |
+
file=pdf_io,
|
34 |
+
config=dict(mime_type='application/pdf')
|
35 |
+
)
|
36 |
+
print("PDF téléchargé et préparé avec succès!")
|
37 |
+
except Exception as e:
|
38 |
+
print(f"Erreur lors du téléchargement du PDF: {str(e)}")
|
39 |
+
raise
|
40 |
+
return pdf_file
|
41 |
+
|
42 |
@app.route('/')
|
43 |
def index():
|
44 |
# Créer un ID de session unique s'il n'existe pas déjà
|
45 |
if 'session_id' not in session:
|
46 |
session['session_id'] = str(uuid.uuid4())
|
47 |
+
|
48 |
+
# Précharger le PDF au démarrage de l'application
|
49 |
+
try:
|
50 |
+
load_pdf()
|
51 |
+
except Exception as e:
|
52 |
+
return render_template('index.html', error=f"Erreur de chargement du PDF: {str(e)}")
|
53 |
+
|
54 |
+
return render_template('index.html', pdf_url=PDF_URL)
|
55 |
|
56 |
@app.route('/chat', methods=['POST'])
|
57 |
def chat():
|
|
|
63 |
chat_session = get_or_create_chat_session(session_id)
|
64 |
|
65 |
try:
|
66 |
+
# S'assurer que le PDF est chargé
|
67 |
+
pdf_document = load_pdf()
|
68 |
+
|
69 |
+
# Construire le prompt pour Gemini avec référence au PDF
|
70 |
+
prompt = f"En vous basant sur le contenu du PDF sur la langue fang, veuillez répondre à: {user_message}"
|
71 |
+
|
72 |
+
# Envoyer le message à Gemini avec le PDF comme contexte et obtenir la réponse
|
73 |
+
# Note: Pour utiliser le PDF dans chaque message, nous devons créer un nouveau message avec le PDF
|
74 |
+
response = client.models.generate_content(
|
75 |
+
model="gemini-2.0-flash",
|
76 |
+
contents=[pdf_document, prompt]
|
77 |
+
)
|
78 |
+
|
79 |
+
# Ajouter cette paire question/réponse à l'historique local
|
80 |
+
if not hasattr(app, 'chat_histories'):
|
81 |
+
app.chat_histories = {}
|
82 |
+
|
83 |
+
if session_id not in app.chat_histories:
|
84 |
+
app.chat_histories[session_id] = []
|
85 |
+
|
86 |
+
app.chat_histories[session_id].append({
|
87 |
+
'role': 'user',
|
88 |
+
'content': user_message,
|
89 |
+
'timestamp': datetime.now().strftime("%H:%M")
|
90 |
+
})
|
91 |
+
|
92 |
+
app.chat_histories[session_id].append({
|
93 |
+
'role': 'model',
|
94 |
+
'content': response.text,
|
95 |
+
'timestamp': datetime.now().strftime("%H:%M")
|
96 |
+
})
|
97 |
|
98 |
# Formater l'historique pour l'interface
|
99 |
+
history = app.chat_histories[session_id]
|
|
|
|
|
|
|
|
|
|
|
|
|
100 |
|
101 |
return jsonify({
|
102 |
'response': response.text,
|
|
|
124 |
def reset_chat():
|
125 |
"""Réinitialise la session de chat actuelle"""
|
126 |
session_id = session.get('session_id')
|
127 |
+
|
128 |
+
# Réinitialiser l'historique stocké
|
129 |
+
if hasattr(app, 'chat_histories') and session_id in app.chat_histories:
|
130 |
+
app.chat_histories[session_id] = []
|
131 |
+
|
132 |
+
# Réinitialiser la session de chat
|
133 |
if hasattr(app, 'chat_sessions') and session_id in app.chat_sessions:
|
|
|
134 |
app.chat_sessions[session_id] = client.chats.create(model="gemini-2.0-flash")
|
135 |
|
136 |
return jsonify({'status': 'success'})
|