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

Last change on this file since 12078 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
RevLine 
[12004]1## $Id: document.py 12063 2014-11-26 15:20:34Z henrik $
[11982]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
[11990]22from time import time
[11982]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
[11983]30from waeup.ikoba.interfaces import IIkobaUtils, IObjectHistory
[11982]31from waeup.ikoba.interfaces import MessageFactory as _
32from waeup.ikoba.utils.helpers import attrs_to_fields, get_current_principal
[12032]33from waeup.ikoba.documents.interfaces import (
34    IDocument, IDocument, IDocumentsUtils)
[12005]35from waeup.ikoba.documents.utils import generate_document_id
[11982]36
[12063]37class Document(grok.Container):
[11982]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__()
[12005]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'
[11982]51        return
52
[11983]53    @property
54    def history(self):
55        history = IObjectHistory(self)
56        return history
57
[12017]58    @property
59    def state(self):
60        state = IWorkflowState(self).getState()
61        return state
62
[12032]63    @property
64    def translated_state(self):
65        try:
66            TRANSLATED_STATES = getUtility(IDocumentsUtils).TRANSLATED_STATES
[12053]67            return TRANSLATED_STATES[self.state]
[12032]68        except KeyError:
69            return
70
[12053]71    @property
[12056]72    def class_name(self):
[12053]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
[11982]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.