added cleanup function and logging
This commit is contained in:
@@ -3,3 +3,377 @@
|
|||||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||||
<title>untitled</title>
|
<title>untitled</title>
|
||||||
</head>
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<div class=WordSection1>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<h1><b>
|
||||||
|
Festival des 3 Continents, Nantes 24.11 - 3.12 2023</b></h1>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<h2><b>
|
||||||
|
Anthologie du cinéma vietnamien</b></h2>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<h2>19 films vietnamiens
|
||||||
|
|
||||||
|
de 1974 à 2022</h2>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<img src="yda_anthologie_cinema_viet_fig_3.jpg" alt="We will meet again" width="510" heigth="500"><br><br>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>We will meet
|
||||||
|
|
||||||
|
again</b> / Đến hẹn lại lên - Tran Vu, 1974, 108’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Dimanche 26.11,
|
||||||
|
|
||||||
|
18:30 - Vendredi 1.12, 13:45</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Premier amour</b>
|
||||||
|
/ Mối tình đầu - Hai Ninh, 1977, 112’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Samedi 25.11, 13:45
|
||||||
|
|
||||||
|
- Jeudi 30.11, 20:30</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>The faces of may</b>
|
||||||
|
/ Tháng năm, những gương mặt- Dang Nhat Minh, 1975, 37’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<img src="yda_anthologie_cinema_viet_fig_2.jpg" alt="Nostalgie de la campagne" width="510" heigth="500"><br><br>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Nostalgie de la
|
||||||
|
|
||||||
|
campagne</b> / Thương nhớ đồng quê - Dang Nhat Minh,
|
||||||
|
|
||||||
|
1995, 116’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Mercredi 29.11,
|
||||||
|
|
||||||
|
20:30 - Vendredi 1.12, 17:00</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Chom et Sa</b>
|
||||||
|
/ Chom và Sa - Pham Ky Nam, 1979, 70’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Dimanche 26.11,
|
||||||
|
|
||||||
|
10:00 - Lundi 27.11, 16:15</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Hanoi through
|
||||||
|
|
||||||
|
whose eyes ?</b> / Hà Nội trong mắt ai - Tran Van
|
||||||
|
|
||||||
|
Thuy, 1982, 45’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>The story of kindness
|
||||||
|
|
||||||
|
</b>or<b> How to behave</b> / Chuyện tử tế - Tran Van
|
||||||
|
|
||||||
|
Thuy, 1987, 43’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Mardi 28.11, 16:00 -
|
||||||
|
|
||||||
|
Dimanche 3.12, 10:30</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Brothers</b>
|
||||||
|
/ Anh và em - Nguyen Huu Luyen & Tran Vu, 1986, 87’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Dimanche 26.11, 20:45
|
||||||
|
|
||||||
|
- Jeudi 30.11, 18:30</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>La fille du
|
||||||
|
|
||||||
|
fleuve</b> / Cô gái trên sông - Dang Nhat Minh, 1987, 100’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Samedi 25.11, 20:45
|
||||||
|
|
||||||
|
- Jeudi 30.11, 10:15</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Troupe de cirque
|
||||||
|
|
||||||
|
ambulant</b> / Gánh xiếc rong - Viet Linh, 1988, 80’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Lundi 27.11, 17:30 -
|
||||||
|
|
||||||
|
Dimanche 3.12, 17:30</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Fairytale for a
|
||||||
|
|
||||||
|
17-year-old girl</b> / Chuyện cổ tích cho tuổi 17 -
|
||||||
|
|
||||||
|
Nguyen Xuan Son, 1988, 77’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Mercredi 29.11,
|
||||||
|
|
||||||
|
13 :00 - Samedi 2.12, 13 :00</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>La lampe dans le
|
||||||
|
|
||||||
|
rêve</b> / Ngọn đèn trong mơ - Do Minh Tuan, 1988, 75’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Mardi 28.11, 10:15 -
|
||||||
|
|
||||||
|
Vendredi 1.12, 18:45</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Money,
|
||||||
|
|
||||||
|
Money !</b> / Tiền ơi ! - Tran Vu & Nguyen
|
||||||
|
|
||||||
|
Huu Luyen, 1989, 93’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Dimanche 26.11,
|
||||||
|
|
||||||
|
15:30 - Samedi 2.12, 15:45</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Enfance orageuse</b>
|
||||||
|
/ Tuổi thơ dữ dội - Nguyen Vinh Son, 1990, 135’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Lundi 27.11, 13:30 -
|
||||||
|
|
||||||
|
Samedi 2.12, 20:30</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>PLease forgive me</b>
|
||||||
|
/ Hãy tha thứ cho em - Luu Trong Ninh, 1992, 90’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Lundi 27.11, 18:30 -
|
||||||
|
|
||||||
|
Mercredi 29.11, 18:15</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>Piège d’amour</b>
|
||||||
|
/ Cạm bảy tình yêu - Pham Loc, 1992, 82’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Lundi 27.11, 10:30 -
|
||||||
|
|
||||||
|
Mercredi 29.11, 14:45</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>In the lane</b>
|
||||||
|
/ Ngõ hẹp - Bach Diep, 1993, 98’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Samedi 25.11, 10:15
|
||||||
|
|
||||||
|
- Mardi 28.11, 14:00</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<img src="yda_anthologie_cinema_viet_fig_4.jpg" alt="L’Immeuble" width="510" heigth="500"><br><br>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"><b>L’Immeuble</b>
|
||||||
|
/ Chung cư - Viet Linh, 1999, 90’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Samedi 25.11, 16:15
|
||||||
|
|
||||||
|
- Mercredi 29.11, 15:00</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<img src="yda_anthologie_cinema_viet_fig_1.jpg" alt="Dust & metal" width="510" heigth="510"><br><br>
|
||||||
|
|
||||||
|
<p align="justify"><b>Dust & metal</b>
|
||||||
|
/ Cát bụi và kim loại - Esther Johnson, 2022, 83’</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Vendredi 1.12, 20:30
|
||||||
|
|
||||||
|
- Dimanche 3.12, 18:00</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Anthologie du cinéma vietnamien :</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">
|
||||||
|
https://www.3continents.com/fr/programme/2023/anthologie-du-cinema-vietnamien/</a></p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">Programme 2023, horaires et lieux :</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify">
|
||||||
|
https://www.3continents.com/wp-content/uploads/f3c-prog-2023-40p-net-planche.pdf</a></p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<p align="justify"> </p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</html>
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
<html>
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
|
||||||
<title>untitled</title>
|
|
||||||
</head>
|
|
||||||
3
html_cleanup/static/temp/errors_log
Normal file
3
html_cleanup/static/temp/errors_log
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
2023-11-29 11:40:58 - DSC03776.JPGERREUR: La taille du fichier dépasse la limite autorisée. Téléchargement refusé.
|
||||||
|
2023-11-29 11:44:29 - DSC03777.JPG - ERREUR: La taille du fichier dépasse la limite autorisée. Téléchargement refusé.
|
||||||
|
2023-11-29 11:45:44 - devis prothèse dentaire CKT.pdf - ERREUR: Le format du fichier n'est pas valide. Téléchargement refusé.
|
||||||
File diff suppressed because one or more lines are too long
@@ -17,21 +17,21 @@
|
|||||||
<br />
|
<br />
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<button id="uploadButton" class="btn btn-success" type="submit" name="form.submitted">
|
<button id="uploadButton" class="btn btn-success" type="submit" name="form.submitted">
|
||||||
<i class="glyphicon glyphicon-arrow-up"></i> Clean up</button>
|
<i class="glyphicon glyphicon-arrow-up"></i> & Clean up</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<div class="panel-footer">
|
<div class="panel-footer">
|
||||||
<ul>
|
<ul>
|
||||||
<li>Seuls les fichiers au format <b>HTML</b> seront acceptés.</li>
|
<li>Seuls les fichiers au format <b>HTML</b> seront acceptés.</li>
|
||||||
<li>La taille du fichier ne doit <b>pas dépasser 10 Mo</b>.</li>
|
<li>La taille du fichier ne doit pas <b>dépasser 10 Mo</b>.</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% if file_url %}
|
{% if file_url %}
|
||||||
<h2 class="text-info font-semi-bold">CLEANUP réussi</h2>
|
<h2 class="text-info font-semi-bold">Cleanup réussi</h2>
|
||||||
Votre fichier nettoyé : <b>{{ file_name }}</b>: <a href="{{ file_url }}""></a>
|
Votre fichier nettoyé : <b>{{ file_name }}</b> <br><br>
|
||||||
<a class="btn btn-primary" href="{{ file_url }}" download="{{ file_name }}"><span class="glyphicon glyphicon-arrow-up"></span> Télécharger</a>
|
<a class="btn btn-primary" href="{{ file_url }}" download="{{ file_name }}"><span class="glyphicon glyphicon-arrow-down"></span> Télécharger</a>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% endblock content %}
|
{% endblock content %}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import os
|
|||||||
import shutil
|
import shutil
|
||||||
import magic
|
import magic
|
||||||
import sys
|
import sys
|
||||||
|
import datetime
|
||||||
|
|
||||||
@view_config(route_name='home', renderer='html_cleanup:templates/home.jinja2')
|
@view_config(route_name='home', renderer='html_cleanup:templates/home.jinja2')
|
||||||
def home(request):
|
def home(request):
|
||||||
@@ -33,17 +34,18 @@ def clean_html(input_file, output_file):
|
|||||||
# cleanup undesirable tags in html file
|
# cleanup undesirable tags in html file
|
||||||
encoding = "utf-8"
|
encoding = "utf-8"
|
||||||
message = ""
|
message = ""
|
||||||
import pdb;pdb.set_trace()
|
# import pdb;pdb.set_trace()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
with open(input_file, 'r', encoding='utf-8') as fi, open(output_file, 'w', encoding='utf-8') as fo:
|
with open(output_file, 'w') as fo:
|
||||||
fo.write("<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset={}\">\n<title>untitled</title>\n</head>\n")
|
fo.write("<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset={}\">\n<title>untitled</title>\n</head>\n".format(encoding))
|
||||||
|
|
||||||
body = False
|
body = False
|
||||||
skip_tag = False
|
skip_tag = False
|
||||||
nb_lines = 0
|
nb_lines = 0
|
||||||
|
|
||||||
for line_in in fi:
|
for line_in_bytes in input_file:
|
||||||
|
line_in = line_in_bytes.decode('utf-8')
|
||||||
line_out = ""
|
line_out = ""
|
||||||
|
|
||||||
if not body:
|
if not body:
|
||||||
@@ -125,26 +127,41 @@ def process_file(request, input_file, input_name):
|
|||||||
# and if OK, process file
|
# and if OK, process file
|
||||||
message = ''
|
message = ''
|
||||||
ext_allowed = ['text/html', 'image/png', 'image/jpeg']
|
ext_allowed = ['text/html', 'image/png', 'image/jpeg']
|
||||||
max_size = 10 * (1024 ** 2) # 10 Mb
|
max_size = 5 * (1024 ** 2) # 10 Mb
|
||||||
temp_folder = request.registry.settings['temp_folder']
|
temp_folder = request.registry.settings['temp_folder']
|
||||||
|
logfile_name = os.path.join(temp_folder, 'errors_log')
|
||||||
|
|
||||||
mime = magic.from_buffer(input_file.read(), mime=True)
|
mime = magic.from_buffer(input_file.read(), mime=True)
|
||||||
# types de fichiers autorisés ?
|
# types de fichiers autorisés ?
|
||||||
if mime not in ext_allowed:
|
if mime not in ext_allowed:
|
||||||
message = "ERREUR: Le format du fichier n'est pas valide. Téléchargement refusé."
|
message = "Le format du fichier n'est pas valide. Téléchargement refusé."
|
||||||
|
add_error2log(logfile_name, input_name, message)
|
||||||
else:
|
else:
|
||||||
# lire la taille du fichier
|
# lire la taille du fichier
|
||||||
pos = input_file.tell()
|
|
||||||
input_file.seek(0, 2) #seek to end
|
input_file.seek(0, 2) #seek to end
|
||||||
filesize = input_file.tell()
|
filesize = input_file.tell()
|
||||||
input_file.seek(pos) # back to original position
|
input_file.seek(0) # back to original position
|
||||||
# controler la taille du fichier
|
# controler la taille du fichier
|
||||||
if filesize > max_size:
|
if filesize > max_size:
|
||||||
message = "ERREUR: La taille du fichier dépasse la limite autorisée. Téléchargement refusé."
|
message = "La taille du fichier dépasse la limite autorisée. Téléchargement refusé."
|
||||||
|
add_error2log(logfile_name, input_name, message)
|
||||||
else:
|
else:
|
||||||
# controle OK, traiter le fichier
|
# controle OK, traiter le fichier
|
||||||
output_name = "clean_" + input_name
|
output_name = "clean_" + input_name
|
||||||
output_file = os.path.join(temp_folder, output_name)
|
output_file = os.path.join(temp_folder, output_name)
|
||||||
message = clean_html(input_file, output_file)
|
message = clean_html(input_file, output_file)
|
||||||
|
if message:
|
||||||
|
add_error2log(logfile_name, input_name, message)
|
||||||
|
|
||||||
|
|
||||||
return message
|
return message
|
||||||
|
|
||||||
|
def add_error2log(logfile_name, input_name, message):
|
||||||
|
# ecrire message d'erreur dans le log
|
||||||
|
|
||||||
|
|
||||||
|
# Get the current date and time
|
||||||
|
now = datetime.datetime.now()
|
||||||
|
with open(logfile_name, 'a', encoding='utf-8') as file:
|
||||||
|
line = now.strftime("%Y-%m-%d %H:%M:%S") + ' [' + input_name + '] ' + f'{message}\n'
|
||||||
|
file.write(line)
|
||||||
|
|||||||
Reference in New Issue
Block a user