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

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

We don't need a logger for documents only.

  • Property svn:keywords set to Id
File size: 3.3 KB
Line 
1## $Id: document.py 12063 2014-11-26 15:20:34Z 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.documents.interfaces import (
34    IDocument, IDocument, IDocumentsUtils)
35from waeup.ikoba.documents.utils import generate_document_id
36
37class Document(grok.Container):
38    """This is a document.
39    """
40    grok.implements(IDocument)
41    grok.provides(IDocument)
42    grok.baseclass()
43
44    def __init__(self):
45        super(Document, self).__init__()
46        # The site doesn't exist in unit tests
47        try:
48            self.document_id = generate_document_id()
49        except AttributeError:
50            self.document_id = u'd123'
51        return
52
53    @property
54    def history(self):
55        history = IObjectHistory(self)
56        return history
57
58    @property
59    def state(self):
60        state = IWorkflowState(self).getState()
61        return state
62
63    @property
64    def translated_state(self):
65        try:
66            TRANSLATED_STATES = getUtility(IDocumentsUtils).TRANSLATED_STATES
67            return TRANSLATED_STATES[self.state]
68        except KeyError:
69            return
70
71    @property
72    def class_name(self):
73        return self.__class__.__name__
74
75    @property
76    def formatted_transition_date(self):
77        try:
78            return self.last_transition_date.strftime('%Y-%m-%d %H:%M:%S')
79        except AttributeError:
80            return
81       
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.