From 2c0463320b61c36a4b9497bb45f9505a976f8312 Mon Sep 17 00:00:00 2001 From: Sven Franck <sven.franck@nexedi.com> Date: Wed, 14 Sep 2016 13:55:53 +0000 Subject: [PATCH] erp5_web_renderjs_ui: add handler for file fetched via renderjs --- .../erp5_web_renderjs_ui/File_viewAsWeb.py | 19 ++++++ .../erp5_web_renderjs_ui/File_viewAsWeb.xml | 62 +++++++++++++++++++ 2 files changed, 81 insertions(+) create mode 100644 bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.py create mode 100644 bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.xml diff --git a/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.py b/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.py new file mode 100644 index 0000000000..df62c28e53 --- /dev/null +++ b/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.py @@ -0,0 +1,19 @@ +if REQUEST is None: + REQUEST = context.REQUEST +if response is None: + response = REQUEST.RESPONSE + +file = context +file_content = file.getData() + +if REQUEST.getHeader('If-Modified-Since', '') == file.getModificationDate().rfc822(): + response.setStatus(304) + return "" + +#file_content_type = file.getContentType() +#if file_content_type is None: +# file_content_type = 'application/octet-stream' + +response.setHeader('Content-Type', (file.getContentType() or 'application/octet-stream')) + +return file_content diff --git a/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.xml b/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.xml new file mode 100644 index 0000000000..293f4a2f97 --- /dev/null +++ b/bt5/erp5_web_renderjs_ui/SkinTemplateItem/portal_skins/erp5_web_renderjs_ui/File_viewAsWeb.xml @@ -0,0 +1,62 @@ +<?xml version="1.0"?> +<ZopeData> + <record id="1" aka="AAAAAAAAAAE="> + <pickle> + <global name="PythonScript" module="Products.PythonScripts.PythonScript"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>Script_magic</string> </key> + <value> <int>3</int> </value> + </item> + <item> + <key> <string>_bind_names</string> </key> + <value> + <object> + <klass> + <global name="NameAssignments" module="Shared.DC.Scripts.Bindings"/> + </klass> + <tuple/> + <state> + <dictionary> + <item> + <key> <string>_asgns</string> </key> + <value> + <dictionary> + <item> + <key> <string>name_container</string> </key> + <value> <string>container</string> </value> + </item> + <item> + <key> <string>name_context</string> </key> + <value> <string>context</string> </value> + </item> + <item> + <key> <string>name_m_self</string> </key> + <value> <string>script</string> </value> + </item> + <item> + <key> <string>name_subpath</string> </key> + <value> <string>traverse_subpath</string> </value> + </item> + </dictionary> + </value> + </item> + </dictionary> + </state> + </object> + </value> + </item> + <item> + <key> <string>_params</string> </key> + <value> <string>REQUEST=None, response=None, mapping_dict=None</string> </value> + </item> + <item> + <key> <string>id</string> </key> + <value> <string>File_viewAsWeb</string> </value> + </item> + </dictionary> + </pickle> + </record> +</ZopeData> -- 2.30.9