sauvegarde des dates + version de l'app dans le fichier de sauvegarde
[perso/Denise/oms.git] / app.py
1 #!/usr/bin/env python3
2 # -*- coding: utf-8 -*-
3
4 import flask
5 import io
6 import matplotlib.pyplot as plt
7 import base64
8 from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
9
10 from configuration import config_init,CONFIG
11 from gestion_erreurs import initialise_erreurs, debug, niveau_debug, warning
12 import gestion_donnees as donnees
13 import gestion_couleurs as couleurs
14 from trace_courbe import cree_figure
15 import faq as f
16
17
18 def initialise_mode_beta():
19 global beta
20 hote = flask.request.host
21 if hote[:4] == "beta":
22 print("** Mode bêta !**")
23 return True
24 else:
25 return False
26
27
28 app = flask.Flask(__name__)
29
30 @app.route('/',methods=['POST','GET'])
31 def index():
32 beta=initialise_mode_beta()
33 liste_err = initialise_erreurs()
34 val_form = config_init()
35 if flask.request.method=="POST":
36 if 'fichier_donnees' in flask.request.files:
37 ## charger les donneés dans le formulaire
38 fichier = flask.request.files['fichier_donnees']
39 chaine = fichier.read()
40 val_form2 = donnees.fichier_json_vers_configdonnees(chaine,liste_err)
41 if val_form2 == {}:
42 return flask.render_template("index.html",err=liste_err[2]+liste_err[1]+liste_err[0],valform=val_form, CONFIG=CONFIG, beta=beta)
43 val_form.update(val_form2)
44
45 return flask.render_template("index.html",err=liste_err[1],valform=val_form, CONFIG=CONFIG, beta=beta)
46
47 @app.route('/apropos')
48 def apropos():
49 beta=initialise_mode_beta()
50 return flask.render_template("apropos.html",err=[], beta=beta)
51
52
53 @app.route("/courbe/<ext>", methods=['POST'])
54 def courbe_image(ext):
55 liste_err = initialise_erreurs()
56 data = flask.request.form
57 enfants_add = [] # Enfants additionnels
58 for i in range(2, 11):
59 if 'fichier_donnees_'+str(i) in flask.request.files: # UUn enfant à ajouter
60 fichier = flask.request.files["fichier_donnees_"+str(i)]
61 chaine = fichier.read() # On récupère la chaîne
62 if len(chaine)>=5: # Si elle a une longueur à peu près raisonnable
63 debug("Un fichier de données additionnel trouvé", liste_err)
64 formulaire_2 = donnees.fichier_json_vers_configdonnees(chaine, liste_err)
65 if formulaire_2 =={}:
66 warning("Le fichier de données additionnel est vide ou mal formaté", liste_err)
67 else:
68 #debug("Form 2 : "+str(formulaire_2), liste_err)
69 # Récupérer sous forme python
70 conf2, ljours2, listes_donnees2 = donnees.web_vers_python(formulaire_2,liste_err, court=True)
71 # Le symbole et la couleur
72 symb2 = donnees.gere_symbole(data.get("symbole_donnees_"+str(i)))
73 coul2 = couleurs.rgb_vers_tuple(data.get("couleur_donnees_"+str(i),""),CONFIG["couleurs"]["cadretxt"],liste_err)
74 enfant2 = donnees.eclate_donnees_additionnelles(conf2, ljours2, listes_donnees2, symb2, coul2)
75 enfants_add.append(enfant2)
76
77
78 # récupérer les données du formulaire proprement
79 config,listes_jours,listes_donnees = donnees.web_vers_python(data,liste_err)
80 debug(" * On a récupéré et traité les données du formulaire web",liste_err)
81
82 texte = donnees.donnees_vers_json(listes_jours["poids"],listes_donnees["poids"],listes_jours["taille"],listes_donnees["taille"], config)
83
84 debug("texte prêt à être exporté : "+texte,liste_err)
85
86 # noter le nom de l'enfant pour l'export
87 nomenfant = donnees.simplifie_nom(config['nom'])
88
89 # créer les figures
90 try:
91 debug("création des figures...",liste_err)
92 textes_images = {}
93 liste_extracalculs = []
94 for typed in CONFIG["liste_typedonnees"]:
95 if config["tracevide"] == "oui" or listes_jours[typed] != []:
96 debug("On trace la courbe de "+typed,liste_err)
97 fig = cree_figure(config,listes_jours[typed],listes_donnees[typed],typed,liste_extracalculs, liste_err, enfants_add)
98 output = io.BytesIO()
99 FigureCanvas(fig).print_png(output)
100 plt.close(fig)
101 textes_images[typed] = base64.b64encode(output.getvalue()).decode("ascii")
102 else:
103 textes_images[typed] = ""
104
105 result = "success"
106 except:
107 result = "fail"
108 liste_err[0].append("Impossible de générer les courbes ! Config : "+str(config))
109
110
111 if ext == "b64":
112 reponse = { "result":result,
113 "export_txt": texte,
114 "nomenfant": nomenfant}
115 if result == "success":
116 reponse["messages"] = liste_err[0]+liste_err[1]
117 reponse["calculextra"] = liste_extracalculs
118 else:
119 reponse["messages"] = liste_err[2]+liste_err[1]+liste_err[0]
120
121 for typed in CONFIG["liste_typedonnees"]:
122 reponse["image_"+typed] = textes_images.get(typed,"")
123
124
125
126 return flask.jsonify(reponse)
127 elif ext == "png" and result == "success": # à voir cette partie car il faudrait voir ce qu'on y renvoie... vu
128 # qu'il n'y a plus une courbe mais plusieurs. Là ça renverra la dernière générée.
129 return flask.Response(output.getvalue(), mimetype='image/png')
130 elif ext == "png":
131 return flask.render_template("erreur_fatale.html",erreur="Impossible de générer la courbe")
132 else:
133 return flask.render_template("erreur_fatale.html",erreur="Le type d'image demandé n'est pas reconnu")
134
135
136 @app.route("/contact")
137 def contact():
138 beta=initialise_mode_beta()
139 return flask.render_template("contact.html",err=[], beta=beta)
140
141 @app.route("/faq")
142 def faq():
143 beta=initialise_mode_beta()
144
145 table_faq = f.lire_fichier_csv_simple(f.fichier_FAQ)
146 l_categ,table_qr = f.extraire_tables_par_cat(table_faq)
147
148 return flask.render_template("faq.html",lcateg=l_categ,tableqr=table_qr,err=[], beta=beta)
149
150 @app.route("/changelog")
151 def changelog():
152 beta=initialise_mode_beta()
153
154 table_version = f.lire_fichier_csv_simple(f.fichier_changelog)
155
156 return flask.render_template("changelog.html",table = table_version,err=[], beta=beta)
157
158 if __name__ == "__main__":
159 print("Mode debug maison : "+str(niveau_debug))
160 app.run(host='0.0.0.0',debug=True)