HistoireGeo / app.py
Docfile's picture
Update app.py
7bfe8df verified
raw
history blame
14.5 kB
from flask import Flask, request, render_template, jsonify
import PIL.Image
import google.generativeai as genai
import os
from tempfile import NamedTemporaryFile
import logging
import traceback # Import traceback
# Configuration du logging
logging.basicConfig(level=logging.DEBUG, # Définir le niveau de logging à DEBUG
format='%(asctime)s - %(levelname)s - %(message)s')
app = Flask(__name__)
# Configuration de Gemini
generation_config = {
"temperature": 1,
"max_output_tokens": 8192,
}
safety_settings = [
{
"category": "HARM_CATEGORY_HARASSMENT",
"threshold": "BLOCK_NONE"
},
{
"category": "HARM_CATEGORY_HATE_SPEECH",
"threshold": "BLOCK_NONE"
},
{
"category": "HARM_CATEGORY_SEXUALLY_EXPLICIT",
"threshold": "BLOCK_NONE"
},
{
"category": "HARM_CATEGORY_DANGEROUS_CONTENT",
"threshold": "BLOCK_NONE"
},
]
GOOGLE_API_KEY = os.environ.get("TOKEN")
genai.configure(api_key=GOOGLE_API_KEY)
logging.info("Gemini API configuré.")
def generer_histoire(sujet, points):
"""Génère une histoire à partir d'un sujet et de points donnés."""
logging.info(f"Début de la génération de l'histoire avec sujet: {sujet} et points: {points}")
prompt = f"""
je souhaite faire mon travail d'histoire sous forme de dissertation. le thème {sujet} et les différents point a détaillé sont : {points}
Voici la méthodologie que tu devras scrupuleusement respecté pour la dissertation et assure toi d'intégrer les connecteur logique pour débuter les arguments Je veux un travail bien détaillé. commence directement ta réponse par l'introduction :
Introduction
Amorce
Problématique
Annonce du plan(les points )
Développement(il y a trois points et donc une partie pour chaque points )
1er partie
Phrase chapeau ( Avec annonce des deux arguments)
Argument 1+ explication+ exemple
Argument 2 + explication + exemple
Transition
2eme partie
Phrase chapeau ( Avec annonce des deux arguments)
Argument 1+ explication+ exemple
Argument 2 + explication + exemple
Transition
3eme partie
Phrase chapeau ( Avec annonce des deux arguments)
Argument 1+ explication+ exemple
Argument 2 + explication + exemple
Conclusion
bilan
question d'ouverture
"""
logging.debug(f"Prompt utilisé pour Gemini: {prompt}")
try:
model = genai.GenerativeModel('gemini-2.0-flash', generation_config=generation_config, safety_settings=safety_settings)
logging.info("Modèle Gemini initialisé.")
response = model.generate_content(prompt, request_options={"timeout": 600})
logging.info("Réponse de Gemini reçue.")
logging.debug(f"Réponse brute de Gemini: {response}")
return response.text
except Exception as e:
logging.error(f"Erreur lors de la génération de l'histoire: {e}")
logging.error(traceback.format_exc()) # Log the full traceback
raise
@app.route('/')
def index():
"""Route pour la page d'accueil."""
logging.info("Accès à la page d'accueil.")
return render_template('histoire.html')
@app.route('/api/histoire', methods=['POST'])
def submit_histoire():
"""Route pour soumettre un sujet d'histoire et générer une dissertation."""
logging.info("Requête POST reçue sur /api/histoire")
# Récupération des données
sujet = request.form.get('sujet-histoire', '').strip()
points = [
request.form.get('pointt1-histoire', '').strip(),
request.form.get('point2-histoire', '').strip(),
request.form.get('point3-histoire', '').strip()
]
logging.debug(f"Sujet reçu: {sujet}, Points reçus: {points}")
if not sujet or not all(points):
logging.warning("Tous les champs ne sont pas remplis.")
return jsonify({"error": "Tous les champs sont obligatoires"}), 400
try:
logging.info("Début de la génération de la dissertation.")
dissertation = generer_histoire(sujet,points)
logging.info("Dissertation générée avec succès.")
return jsonify({"output": dissertation}), 200
except Exception as e:
logging.exception("Erreur lors du traitement de la requête /api/histoire") # Use logging.exception to log the exception with traceback
return jsonify({"error": str(e)}), 500
@app.route('/api/geographie', methods=['POST'])
def submit_geographie():
"""Route pour soumettre un sujet de géographie et générer une dissertation."""
logging.info("Requête POST reçue sur /api/geographie")
# Récupération des données
sujet = request.form.get('sujet-geographie', '').strip()
points = [
request.form.get('point1-geographie', '').strip(),
request.form.get('point2-geographie', '').strip(),
request.form.get('point3-geographie', '').strip()
]
logging.debug(f"Sujet reçu: {sujet}, Points reçus: {points}")
if not sujet or not all(points):
logging.warning("Tous les champs ne sont pas remplis.")
return jsonify({"error": "Tous les champs sont obligatoires"}), 400
try:
logging.info("Début de la génération de la dissertation.")
# Génération de l'introduction
dissertation = generer_histoire(sujet,points)
logging.info("Dissertation générée avec succès.")
return jsonify({"output": dissertation}), 200
except Exception as e:
logging.exception("Erreur lors du traitement de la requête /api/geographie") # Use logging.exception to log the exception with traceback
return jsonify({"error": str(e)}), 500
def analyze_images(images, prompt):
"""Analyse les images fournies et génère une réponse textuelle."""
logging.info("Début de l'analyse des images.")
logging.debug(f"Prompt utilisé pour l'analyse d'images: {prompt}")
try:
model = genai.GenerativeModel('gemini-2.0-flash')
logging.info("Modèle Gemini initialisé pour l'analyse d'images.")
response = model.generate_content(
[prompt, *images],
generation_config=generation_config,
safety_settings=safety_settings
)
logging.info("Réponse de Gemini reçue pour l'analyse d'images.")
logging.debug(f"Réponse brute de Gemini (analyse d'images): {response}")
return response.text
except Exception as e:
logging.error(f"Erreur lors de l'analyse des images: {e}")
logging.error(traceback.format_exc()) # Log the full traceback
raise
@app.route('/api/histoire-type2', methods=['POST'])
def submit_histoire_type2():
"""Route pour soumettre un sujet d'histoire et des images et générer une dissertation."""
logging.info("Requête POST reçue sur /api/histoire-type2")
# Récupération des données
sujet = request.form.get('sujet-histoire-type2', '').strip()
if 'images-histoire-type2' not in request.files:
logging.warning("Aucune image n'a été envoyée.")
return jsonify({"error": "Aucune image n'a été envoyée."}), 400
files = request.files.getlist('images-histoire-type2')
if not sujet:
logging.warning("Le champ sujet est obligatoire.")
return jsonify({"error": "Le champ sujet est obligatoire"}), 400
images = []
for file in files:
if file.filename == '':
logging.warning("Un ou plusieurs fichiers n'ont pas de nom.")
return jsonify({"error": "Un ou plusieurs fichiers n'ont pas de nom."}), 400
try:
img = PIL.Image.open(file)
images.append(img)
logging.debug(f"Image {file.filename} chargée avec succès.")
except Exception as e:
logging.error(f"Impossible de lire l'image : {file.filename}. Erreur : {str(e)}")
return jsonify({"error": f"Impossible de lire l'image : {file.filename}. Erreur : {str(e)}"}), 400
try:
# Prompt pour l'analyse d'images en histoire
prompt = f"""
je souhaite faire mon travail d'histoire sous forme de dissertation. le thème est {sujet}.
Voici la méthodologie que tu devras scrupuleusement respecté pour la dissertation et assure toi d'intégrer les connecteur logique pour débuter les arguments Je veux un travail bien détaillé. commence directement ta réponse par l'introduction :
Introduction:
1er Paragraphe: Présentation des documents (Natures et auteurs au programme). Cela signifie qu'il faut identifier la nature des documents (ex : texte, image, graphique) et mentionner les auteurs, si disponibles, en lien avec le programme.
2ème Paragraphe: Contexte historique. Il faut situer les documents dans leur contexte historique, c'est-à-dire l'époque, les événements, et les grandes tendances associées.
3ème Paragraphe: Résumé des idées majeures. En quelques phrases, il faut synthétiser les principaux thèmes ou les grandes idées qui ressortent des documents et du contexte.
Note: Il est recommandé de sauter 2 ou 3 lignes entre l'introduction et le développement.
Développement :
Le développement est structuré autour de plusieurs consignes, chacune ayant la même structure :
Pour chaque consigne (n°1, n°2, n°3):
1er Paragraphe: Constat. Il s'agit de présenter ce qui est observable, un fait, une situation, une information tirée du document.
2ème Paragraphe: Explication. Il faut analyser et expliquer le constat fait dans le paragraphe précédent. Pourquoi observe-t-on cela ? Quels sont les mécanismes, les causes, les facteurs à l'œuvre ?
3ème Paragraphe: Critique. Il faut prendre du recul, analyser de manière critique les informations, les sources ou le contexte. Peut-on nuancer ou remettre en cause certaines affirmations ?
4ème Paragraphe: Phrase de transition. Il s'agit d'une phrase courte pour faire le lien avec la consigne suivante.
Note: Il est recommandé de sauter 1 ligne entre chaque consigne du développement.
Conclusion
bilan
phrase d'ouverture
"""
# Analyse des images et génération de la réponse
response_text = analyze_images(images, prompt)
return jsonify({"output": response_text}), 200
except Exception as e:
logging.exception("Erreur lors du traitement de la requête /api/histoire-type2") # Use logging.exception to log the exception with traceback
return jsonify({"error": str(e)}), 500
@app.route('/api/geographie-type2', methods=['POST'])
def submit_geographie_type2():
"""Route pour soumettre un sujet de géographie et des images et générer une dissertation."""
logging.info("Requête POST reçue sur /api/geographie-type2")
# Récupération des données
sujet = request.form.get('sujet-geographie-type2', '').strip()
if 'images-geographie-type2' not in request.files:
logging.warning("Aucune image n'a été envoyée.")
return jsonify({"error": "Aucune image n'a été envoyée."}), 400
files = request.files.getlist('images-geographie-type2')
if not sujet:
logging.warning("Le champ sujet est obligatoire.")
return jsonify({"error": "Le champ sujet est obligatoire"}), 400
images = []
for file in files:
if file.filename == '':
logging.warning("Un ou plusieurs fichiers n'ont pas de nom.")
return jsonify({"error": "Un ou plusieurs fichiers n'ont pas de nom."}), 400
try:
img = PIL.Image.open(file)
images.append(img)
logging.debug(f"Image {file.filename} chargée avec succès.")
except Exception as e:
logging.error(f"Impossible de lire l'image : {file.filename}. Erreur : {str(e)}")
return jsonify({"error": f"Impossible de lire l'image : {file.filename}. Erreur : {str(e)}"}), 400
try:
# Prompt pour l'analyse d'images en histoire
prompt = f"""
je souhaite faire mon travail de géographie sous forme de dissertation. le thème est {sujet}.
Voici la méthodologie que tu devras scrupuleusement respecté pour la dissertation et assure toi d'intégrer les connecteur logique pour débuter les arguments Je veux un travail bien détaillé. commence directement ta réponse par l'introduction :
Introduction:
1er Paragraphe: Définition du thème (ou définition des mots-clés). Il faut commencer par clairement définir le sujet de l'étude. Si nécessaire, il faut définir les mots-clés importants et les concepts liés au thème étudié.
2ème Paragraphe: Présentation des documents (Natures uniquement). Il faut présenter la nature des documents : cartes, graphiques, photos, etc. Contrairement à l'histoire, l'accent est mis ici uniquement sur la nature des documents, sans mention des auteurs.
3ème Paragraphe: Résumé des idées majeures. Il faut synthétiser les principales idées, les tendances ou les problématiques qui se dégagent des documents et de la définition du thème.
Note: Il est recommandé de sauter 2 ou 3 lignes entre l'introduction et le développement.
Développement:
Le développement en géographie suit une structure identique à celle de l'histoire, basée sur des consignes :
Pour chaque consigne (n°1, n°2, n°3):
1er Paragraphe: Constat. Présentez ce qui est observable dans les documents, un fait géographique, une tendance, une répartition spatiale, etc.
2ème Paragraphe: Explication. Analysez les raisons de ce constat. Quels facteurs géographiques (naturels, humains, économiques, politiques...) expliquent ce qui a été observé ?
3ème Paragraphe: Critique. Analysez les limites des documents ou de l'approche, la pertinence des facteurs explicatifs, les éventuelles alternatives ou nuances.
4ème Paragraphe: Phrase de transition. Une courte phrase pour passer en douceur à la consigne suivante.
Note: Il est recommandé de sauter 1 ligne entre chaque consigne du développement.
Conclusion
bilan
phrase d'ouverture
"""
# Analyse des images et génération de la réponse
response_text = analyze_images(images, prompt)
return jsonify({"output": response_text}), 200
except Exception as e:
logging.exception("Erreur lors du traitement de la requête /api/geographie-type2") # Use logging.exception to log the exception with traceback
return jsonify({"error": str(e)}), 500
if __name__ == '__main__':
app.run(debug=True)