Docfile commited on
Commit
9b43085
·
verified ·
1 Parent(s): 07de6c6

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +74 -11
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
- return render_template('index.html')
 
 
 
 
 
 
 
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
- # Envoyer le message à Gemini et obtenir la réponse
32
- response = chat_session.send_message(user_message)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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'})