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

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

Add state property.

  • Property svn:keywords set to Id
File size: 3.3 KB
RevLine 
[12004]1## $Id: document.py 12017 2014-11-21 05:51:16Z 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
33from waeup.ikoba.utils.logger import Logger
[12005]34from waeup.ikoba.documents.interfaces import IDocument, IDocument
35from waeup.ikoba.documents.utils import generate_document_id
[11982]36
37class Document(grok.Container, Logger):
38    """This is a document.
39    """
40    grok.implements(IDocument)
41    grok.provides(IDocument)
42    grok.baseclass()
43
44    logger_name = 'waeup.ikoba.${sitename}.documents'
45    logger_filename = 'documents.log'
46    logger_format_str = '"%(asctime)s","%(user)s",%(message)s'
47
48    def logger_info(self, comment=None):
49        """Get the logger's info method.
50        """
51        self.logger.info('%s' % comment)
52        return
53
[12005]54    #def __init__(self):
55    #    super(Document, self).__init__()
56    #    timestamp = ("%d" % int(time()*10000))[1:]
57    #    self.document_id = "d%s" % timestamp
58     #   return
59
[11982]60    def __init__(self):
61        super(Document, self).__init__()
[12005]62        # The site doesn't exist in unit tests
63        try:
64            self.document_id = generate_document_id()
65        except AttributeError:
66            self.document_id = u'd123'
[11982]67        return
68
[11983]69    @property
70    def history(self):
71        history = IObjectHistory(self)
72        return history
73
[12017]74    @property
75    def state(self):
76        state = IWorkflowState(self).getState()
77        return state
78
[11982]79Document = attrs_to_fields(Document)
80
81class DocumentFactory(grok.GlobalUtility):
82    """A factory for documents.
83    """
84    grok.implements(IFactory)
85    grok.name(u'waeup.Document')
86    title = u"Create a new document.",
87    description = u"This factory instantiates new documents."
88
89    def __call__(self, *args, **kw):
90        return Document(*args, **kw)
91
92    def getInterfaces(self):
93        return implementedBy(Document)
94
95@grok.subscribe(IDocument, grok.IObjectAddedEvent)
96def handle_document_added(document, event):
97    """If a document is added the transition create is fired.
98    The latter produces a logging message.
99    """
100    if IWorkflowState(document).getState() is None:
101        IWorkflowInfo(document).fireTransition('create')
102    return
Note: See TracBrowser for help on using the repository browser.