source: main/waeup.ikoba/trunk/src/waeup/ikoba/documents/export.py @ 15806

Last change on this file since 15806 was 13146, checked in by Henrik Bettermann, 10 years ago

Prepare some docstrings for Sphinx docu.

  • Property svn:keywords set to Id
File size: 4.4 KB
Line 
1## $Id: export.py 13146 2015-07-07 05:43:23Z henrik $
2##
3## Copyright (C) 2012 Uli Fouquet & Henrik Bettermann
4## This program is free software; you can redistribute it and/or modify
5## it under the terms of the GNU General Public License as published by
6## the Free Software Foundation; either version 2 of the License, or
7## (at your option) any later version.
8##
9## This program is distributed in the hope that it will be useful,
10## but WITHOUT ANY WARRANTY; without even the implied warranty of
11## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12## GNU General Public License for more details.
13##
14## You should have received a copy of the GNU General Public License
15## along with this program; if not, write to the Free Software
16## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17##
18"""Exporters for documents.
19"""
20import grok
21from zope.securitypolicy.interfaces import IPrincipalRoleMap
22from waeup.ikoba.interfaces import ICSVExporter
23from waeup.ikoba.interfaces import MessageFactory as _
24from waeup.ikoba.utils.batching import ExporterBase
25from waeup.ikoba.utils.helpers import iface_names
26from waeup.ikoba.documents.interfaces import (
27    IPDFDocument, IHTMLDocument, IRESTDocument)
28
29
30class DocumentExporterBase(grok.GlobalUtility, ExporterBase):
31    """This is the exporter base class for all kinds of document exporters.
32    Derived classes export all documents of type `class_name` inside the
33    documents container.
34
35    All schema fields and the property attributes
36    `history`, `state`, `class_name` and `users_with_local_roles`
37    are being exported.
38    """
39    grok.implements(ICSVExporter)
40    grok.baseclass()
41    class_name = None
42    iface = None
43    title = None
44
45    @property
46    def fields(self):
47        return tuple(sorted(iface_names(self.iface, exclude_attribs=False,
48            omit=['is_verifiable',
49                  'translated_state',
50                  'user_id',
51                  'formatted_transition_date',
52                  'translated_class_name',
53                  'connected_files',   # Could be used to export file URLs
54                  'form_fields_interface',
55                  'filenames',
56                  'local_roles',
57                  ]
58            ))) + (
59            'users_with_local_roles',)
60
61    def mangle_value(self, value, name, context=None):
62        """The mangler prepares the history messages and computes the
63        `users_with_local_roles` value which is a Python expression like:
64
65        ``[{'user_name': u'bob', 'local_role': u'bobsrole'},
66        {'user_name': u'anna', 'local_role': u'annasrole'}]``
67        """
68        if name == 'users_with_local_roles':
69            value = []
70            role_map = IPrincipalRoleMap(context)
71            for local_role, user_name, setting in role_map.getPrincipalsAndRoles():
72                value.append({'user_name':user_name,'local_role':local_role})
73        if name == 'history':
74            value = value.messages
75        return super(DocumentExporterBase, self).mangle_value(
76            value, name, context)
77
78    def export(self, documents, filepath=None):
79        """Export `documents`, an iterable, as CSV file.
80
81        If `filepath` is ``None``, a raw string with CSV data is returned.
82        """
83        writer, outfile = self.get_csv_writer(filepath)
84        for document in documents:
85            self.write_item(document, writer)
86        return self.close_outfile(filepath, outfile)
87
88    def export_all(self, site, filepath=None):
89        """Export documents in documentscontainer into filepath as CSV data.
90
91        If `filepath` is ``None``, a raw string with CSV data is returned.
92        """
93        documents = site.get('documents', {}).values()
94        documents = [doc for doc in documents
95                     if doc.class_name == self.class_name]
96        return self.export(documents, filepath)
97
98
99class PDFDocumentExporter(DocumentExporterBase):
100    """Exporter for documents.
101    """
102    grok.name('pdfdocuments')
103    iface = IPDFDocument
104    class_name = 'PDFDocument'
105    title = _(u'Public PDF Documents')
106
107
108class HTMLDocumentExporter(DocumentExporterBase):
109    """Exporter for documents.
110    """
111    grok.name('htmldocuments')
112    iface = IHTMLDocument
113    class_name = 'HTMLDocument'
114    title = _(u'Public HTML Documents')
115
116
117class RESTDocumentExporter(DocumentExporterBase):
118    """Exporter for documents.
119    """
120    grok.name('restdocuments')
121    iface = IRESTDocument
122    class_name = 'RESTDocument'
123    title = _(u'Public REST Documents')
Note: See TracBrowser for help on using the repository browser.