From 11f2f264213663e4b940d07b87c23d567cae2ee7 Mon Sep 17 00:00:00 2001 From: Andrea Cecchi Date: Tue, 3 Sep 2024 11:57:06 +0200 Subject: [PATCH] Customize @@display-file to allow to download files with proper filename (#113) * Customize @@display-file to allow to download files with proper filename * add missing file --- CHANGES.rst | 3 ++- src/redturtle/volto/browser/configure.zcml | 8 ++++++ src/redturtle/volto/browser/display_file.py | 27 +++++++++++++++++++++ 3 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 src/redturtle/volto/browser/display_file.py diff --git a/CHANGES.rst b/CHANGES.rst index 61cc48a..ac53243 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -9,7 +9,8 @@ Changelog [lucabel] - remove newsitem template override, use default dexterity view for newsitem in backend [mamico] - +- Customize @@display-file to allow to download files with proper filename. + [cekk] 5.5.1 (2024-07-22) ------------------ diff --git a/src/redturtle/volto/browser/configure.zcml b/src/redturtle/volto/browser/configure.zcml index 4803272..98cdbe8 100644 --- a/src/redturtle/volto/browser/configure.zcml +++ b/src/redturtle/volto/browser/configure.zcml @@ -66,4 +66,12 @@ layer="redturtle.volto.interfaces.IRedturtleVoltoLayer" /> + + diff --git a/src/redturtle/volto/browser/display_file.py b/src/redturtle/volto/browser/display_file.py new file mode 100644 index 0000000..c011455 --- /dev/null +++ b/src/redturtle/volto/browser/display_file.py @@ -0,0 +1,27 @@ +from plone.namedfile.browser import DisplayFile as BaseView +from urllib.parse import quote + + +class DisplayFile(BaseView): + """ + Custom view + """ + + def set_headers(self, file): + """ + We need to add filename to the reponse because otherwise the browser + use the field name as filename (last path element). + + content-disposition should be "inline" to allow to display the file in the browser + without forcing download (with "attachment" the browser will download it). + """ + super().set_headers(file=file) + + filename = getattr(file, "filename", "") + if filename is not None: + if not isinstance(filename, str): + filename = str(filename, "utf-8", errors="ignore") + filename = quote(filename.encode("utf8")) + self.request.response.setHeader( + "Content-Disposition", f"inline; filename*=UTF-8''{filename}" + )