source: main/waeup.ikoba/trunk/src/waeup/ikoba/documents/document.py @ 12038

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

Implement translated_state property correctly so that we can more easily customized customer registration and document verification state names.

  • Property svn:keywords set to Id
File size: 3.4 KB
Line 
1## $Id: document.py 12032 2014-11-21 18:52:43Z henrik $
2##
3## Copyright (C) 2014 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"""
19These are the document tickets.
20"""
21import grok
22from time import time
23from grok import index
24from hurry.workflow.interfaces import IWorkflowInfo, IWorkflowState
25from zope.event import notify
26from zope.component import getUtility
27from zope.component.interfaces import IFactory
28from zope.interface import implementedBy
29from zope.i18n import translate
30from waeup.ikoba.interfaces import IIkobaUtils, IObjectHistory
31from waeup.ikoba.interfaces import MessageFactory as _
32from waeup.ikoba.utils.helpers import attrs_to_fields, get_current_principal
33from waeup.ikoba.utils.logger import Logger
34from waeup.ikoba.documents.interfaces import (
35    IDocument, IDocument, IDocumentsUtils)
36from waeup.ikoba.documents.utils import generate_document_id
37
38class Document(grok.Container, Logger):
39    """This is a document.
40    """
41    grok.implements(IDocument)
42    grok.provides(IDocument)
43    grok.baseclass()
44
45    logger_name = 'waeup.ikoba.${sitename}.documents'
46    logger_filename = 'documents.log'
47    logger_format_str = '"%(asctime)s","%(user)s",%(message)s'
48
49    def logger_info(self, comment=None):
50        """Get the logger's info method.
51        """
52        self.logger.info('%s' % comment)
53        return
54
55    def __init__(self):
56        super(Document, self).__init__()
57        # The site doesn't exist in unit tests
58        try:
59            self.document_id = generate_document_id()
60        except AttributeError:
61            self.document_id = u'd123'
62        return
63
64    @property
65    def history(self):
66        history = IObjectHistory(self)
67        return history
68
69    @property
70    def state(self):
71        state = IWorkflowState(self).getState()
72        return state
73
74    @property
75    def translated_state(self):
76        try:
77            TRANSLATED_STATES = getUtility(IDocumentsUtils).TRANSLATED_STATES
78            ts = TRANSLATED_STATES[self.state]
79            return ts
80        except KeyError:
81            return
82
83Document = attrs_to_fields(Document)
84
85class DocumentFactory(grok.GlobalUtility):
86    """A factory for documents.
87    """
88    grok.implements(IFactory)
89    grok.name(u'waeup.Document')
90    title = u"Create a new document.",
91    description = u"This factory instantiates new documents."
92
93    def __call__(self, *args, **kw):
94        return Document(*args, **kw)
95
96    def getInterfaces(self):
97        return implementedBy(Document)
98
99@grok.subscribe(IDocument, grok.IObjectAddedEvent)
100def handle_document_added(document, event):
101    """If a document is added the transition create is fired.
102    The latter produces a logging message.
103    """
104    if IWorkflowState(document).getState() is None:
105        IWorkflowInfo(document).fireTransition('create')
106    return
Note: See TracBrowser for help on using the repository browser.