diff --git a/app/decorators.py b/app/decorators.py index 9f30bead21..a32805bbaf 100644 --- a/app/decorators.py +++ b/app/decorators.py @@ -230,6 +230,7 @@ def scodoc7func(func): if arg_name == "REQUEST": # special case pos_arg_values.append(REQUEST) else: + # peut produire une KeyError s'il manque un argument attendu: v = req_args[arg_name] # try to convert all arguments to INTEGERS # necessary for db ids and boolean values diff --git a/app/scodoc/sco_photos.py b/app/scodoc/sco_photos.py index 286314bf75..1e24c6dff9 100644 --- a/app/scodoc/sco_photos.py +++ b/app/scodoc/sco_photos.py @@ -43,6 +43,7 @@ Les images sont servies par ScoDoc, via la méthode getphotofile?etudid=xxx """ +from app.scodoc.sco_exceptions import ScoGenError import datetime import glob import io @@ -52,6 +53,7 @@ import requests import time import traceback +import PIL from PIL import Image as PILImage from flask import request, g @@ -246,7 +248,10 @@ def store_photo(etud, data): filesize = len(data) if filesize < 10 or filesize > MAX_FILE_SIZE: return 0, "Fichier image de taille invalide ! (%d)" % filesize - filename = save_image(etud["etudid"], data) + try: + filename = save_image(etud["etudid"], data) + except PIL.UnidentifiedImageError: + raise ScoGenError(msg="Fichier d'image invalide ou non format non supporté") # update database: etud["photo_filename"] = filename etud["foto"] = None