From 24905f77b46d41d6d54a03f118e63e3f3e0bf79b Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Aur=C3=A9lien=20Calonne?= <aurel@nexedi.com>
Date: Thu, 23 Aug 2012 16:33:14 +0200
Subject: [PATCH] render report section in activity as this can be quite long

Conflicts:
	bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_renderSimpleView.xml
	bt5/erp5_deferred_style/bt/revision
---
 .../Base_activateSimpleView.xml               |   2 +-
 .../Base_activateReport.xml                   |  65 ++------
 .../Base_computeReportSection.xml             | 139 ++++++++++++++++++
 .../Base_renderSimpleView.xml                 |   2 +-
 bt5/erp5_deferred_style/bt/revision           |   3 +-
 5 files changed, 159 insertions(+), 52 deletions(-)
 create mode 100644 bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_computeReportSection.xml

diff --git a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style/Base_activateSimpleView.xml b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style/Base_activateSimpleView.xml
index f42bad6dd0..be7f1c884a 100644
--- a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style/Base_activateSimpleView.xml
+++ b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style/Base_activateSimpleView.xml
@@ -83,7 +83,7 @@ for k, v in request.form.items():\n
       \'PUBLISHED\', \'AcceptLanguage\', \'AcceptCharset\', \'RESPONSE\',\n
       \'ACTUAL_URL\'):\n
     # XXX proxy fields stores a cache in request.other that cannot be pickled\n
-    if k.startswith(\'field__proxyfield\'):\n
+    if str(k).startswith(\'field__proxyfield\'):\n
       continue\n
     # Remove FileUpload parameters\n
     elif getattr(v, \'headers\', \'\'):\n
diff --git a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_activateReport.xml b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_activateReport.xml
index ca74939b67..c25419b95a 100644
--- a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_activateReport.xml
+++ b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_activateReport.xml
@@ -53,9 +53,6 @@
             <value> <string>request = container.REQUEST\n
 RESPONSE =  request.RESPONSE\n
 \n
-format = request.get(\'format\', \'\')\n
-skin_name = request[\'deferred_portal_skin\']\n
-\n
 portal = context.getPortalObject()\n
 N_ = portal.Base_translateString\n
 \n
@@ -69,23 +66,13 @@ if person_value.getDefaultEmailText(\'\') in (\'\', None):\n
   portal.changeSkin(None)\n
   return context.Base_redirect(\'view\', keep_items=dict(\n
               portal_status_message=N_("You haven\'t defined your email address")))\n
-  \n
-active_process = portal.portal_activities.newActiveProcess()\n
-user_name = person_value.getReference()\n
 \n
-tag = \'active-report-%s\' % random.randint(0, 1000)\n
-priority = 3\n
 \n
-# compute list of report section to render\n
-if form.meta_type == \'ERP5 Report\':\n
-  report_section_list = getattr(context, form.report_method)()\n
-elif form.meta_type == \'ERP5 Form\':\n
-  report_section_list = []\n
-  for field in form.get_fields():\n
-    if field.getRecursiveTemplateField().meta_type == \'ReportBox\':\n
-      report_section_list.extend(field.render())\n
-else:\n
-  raise ValueError, \'form meta_type unknown\'\n
+user_name = person_value.getReference()\n
+tag = \'active-report-%s\' % random.randint(0, 1000)\n
+priority = 2\n
+format = request.get(\'format\', \'\')\n
+skin_name = request[\'deferred_portal_skin\']\n
 \n
 # save request parameters (after calling the report_method which may tweak the\n
 # request). XXX we exclude some reserved names in a very ad hoc way\n
@@ -96,45 +83,25 @@ for k, v in request.items():\n
       \'PUBLISHED\', \'AcceptLanguage\', \'AcceptCharset\', \'RESPONSE\', \'SESSION\',\n
       \'ACTUAL_URL\'):\n
     # XXX proxy fields stores a cache in request.other that cannot be pickled\n
-    if k.startswith(\'field__proxyfield\'):\n
+    if same_type(k, \'\') and k.startswith(\'field__proxyfield\'):\n
       continue\n
     # Remove FileUpload parameters\n
     elif getattr(v, \'headers\', \'\'):\n
       continue\n
     request_other[k] = v\n
 \n
-localizer_language = portal.Localizer.get_selected_language()\n
-\n
-for idx, report_section in enumerate(report_section_list):\n
-  if report_section.getPath():\n
-    doc = report_section.getObject(portal)\n
-  else:\n
-    doc = context\n
-  doc.activate(activity=\'SQLQueue\',\n
-               active_process=active_process,\n
-               tag=tag,\n
-               priority=priority,\n
-              ).Base_renderReportSection(skin_name=skin_name,\n
-                                         localizer_language=localizer_language,\n
-                                         report_section=report_section,\n
-                                         report_section_idx=idx,\n
-                                         request_other=request_other)\n
 \n
-activity_context = context\n
-if activity_context == portal:\n
-  # portal is not an active object\n
-  activity_context = portal.portal_simulation\n
 \n
-activity_context.activate(activity=\'SQLQueue\', after_tag=tag, priority=priority).Base_report(\n
-           active_process_url=active_process.getRelativeUrl(),\n
-           skin_name=skin_name,\n
-           localizer_language=localizer_language,\n
-           title=N_(form.getProperty(\'title\')),\n
-           request_other=request_other,\n
-           form_path=form.getPhysicalPath(),\n
-           user_name=user_name,\n
-           format=format,\n
-          )\n
+context.activate(activity="SQLQueue", tag=tag, \n
+  priority=priority).Base_computeReportSection(\n
+    form=form.getId(), \n
+    request_other=request_other, \n
+    user_name=user_name, \n
+    tag=tag,\n
+    skin_name=skin_name, \n
+    format=format,\n
+    priority=priority, \n
+    **kw)\n
 \n
 context.activate(activity=\'SQLQueue\', after_tag=tag).getTitle()\n
 \n
diff --git a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_computeReportSection.xml b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_computeReportSection.xml
new file mode 100644
index 0000000000..241fed0515
--- /dev/null
+++ b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_computeReportSection.xml
@@ -0,0 +1,139 @@
+<?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>_body</string> </key>
+            <value> <string>portal = context.getPortalObject()\n
+N_ = portal.Base_translateString\n
+\n
+form = context.restrictedTraverse(form)\n
+request = container.REQUEST\n
+request.other.update(request_other)\n
+\n
+if form.meta_type == \'ERP5 Report\':\n
+  report_section_list = getattr(context, form.report_method)()\n
+elif form.meta_type == \'ERP5 Form\':\n
+  report_section_list = []\n
+  for field in form.get_fields():\n
+    if field.getRecursiveTemplateField().meta_type == \'ReportBox\':\n
+      report_section_list.extend(field.render())\n
+else:\n
+  raise ValueError, \'form meta_type (%r) unknown\' %(form.meta_type,)\n
+\n
+# Rebuild request_other as report section can have modify request content\n
+request_other = dict()\n
+for k, v in request.items():\n
+  if k not in (\'TraversalRequestNameStack\', \'AUTHENTICATED_USER\', \'URL\',\n
+      \'SERVER_URL\', \'AUTHENTICATION_PATH\', \'USER_PREF_LANGUAGES\', \'PARENTS\',\n
+      \'PUBLISHED\', \'AcceptLanguage\', \'AcceptCharset\', \'RESPONSE\', \'SESSION\',\n
+      \'ACTUAL_URL\'):\n
+    # XXX proxy fields stores a cache in request.other that cannot be pickled\n
+    if same_type(k, \'\') and str(k).startswith(\'field__proxyfield\'):\n
+      continue\n
+    # Remove FileUpload parameters\n
+    elif getattr(v, \'headers\', \'\'):\n
+      continue\n
+    request_other[k] = v\n
+\n
+localizer_language = portal.Localizer.get_selected_language()\n
+active_process = portal.portal_activities.newActiveProcess()\n
+\n
+for idx, report_section in enumerate(report_section_list):\n
+  if report_section.getPath():\n
+    doc = report_section.getObject(portal)\n
+  else:\n
+    doc = context\n
+  doc.activate(activity=\'SQLQueue\',\n
+               active_process=active_process,\n
+               tag=tag,\n
+               priority=priority,\n
+              ).Base_renderReportSection(skin_name=skin_name,\n
+                                         localizer_language=localizer_language,\n
+                                         report_section=report_section,\n
+                                        report_section_idx=idx,\n
+                                         request_other=request_other)\n
+\n
+activity_context = context\n
+if activity_context == portal:\n
+  # portal is not an active object\n
+  activity_context = portal.portal_simulation\n
+\n
+activity_context.activate(activity=\'SQLQueue\', after_tag=tag, priority=priority).Base_report(\n
+           active_process_url=active_process.getRelativeUrl(),\n
+           skin_name=skin_name,\n
+           localizer_language=localizer_language,\n
+           title=N_(form.getProperty(\'title\')),\n
+           request_other=request_other,\n
+           form_path=form.getPhysicalPath(),\n
+           user_name=user_name,\n
+           format=format,\n
+          )\n
+</string> </value>
+        </item>
+        <item>
+            <key> <string>_params</string> </key>
+            <value> <string>form, request_other, user_name, tag, skin_name, format, priority, **kw</string> </value>
+        </item>
+        <item>
+            <key> <string>_proxy_roles</string> </key>
+            <value>
+              <tuple>
+                <string>Manager</string>
+              </tuple>
+            </value>
+        </item>
+        <item>
+            <key> <string>id</string> </key>
+            <value> <string>Base_computeReportSection</string> </value>
+        </item>
+      </dictionary>
+    </pickle>
+  </record>
+</ZopeData>
diff --git a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_renderSimpleView.xml b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_renderSimpleView.xml
index 617ca67516..1966730204 100644
--- a/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_renderSimpleView.xml
+++ b/bt5/erp5_deferred_style/SkinTemplateItem/portal_skins/erp5_deferred_style_core/Base_renderSimpleView.xml
@@ -76,7 +76,7 @@ attachment_list = (\n
 # XXX Use notification message to improve message content\n
 portal.portal_notifications.sendMessage(\n
   recipient=user_name,\n
-  subject=attachment_name.rsplit(\'.\', 1)[0],\n
+  subject=str(attachment_name.rsplit(\'.\', 1)[0]),\n
   message=str(translateString(\'Your report is attached.\\n\')),\n
   message_text_format=\'text/plain\',\n
   notifier_list=(\'Mail Message\',),\n
diff --git a/bt5/erp5_deferred_style/bt/revision b/bt5/erp5_deferred_style/bt/revision
index 0fd0714a51..e55677ae8d 100644
--- a/bt5/erp5_deferred_style/bt/revision
+++ b/bt5/erp5_deferred_style/bt/revision
@@ -1 +1,2 @@
-103
\ No newline at end of file
+108
+
-- 
2.30.9