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