source: main/waeup.sirp/trunk/src/waeup/sirp/applicants/container.py @ 7016

Last change on this file since 7016 was 6601, checked in by uli, 13 years ago

Use NotImplemented? correctly.

File size: 3.6 KB
Line 
1##
2## container.py
3## Login : <uli@pu.smp.net>
4## Started on  Thu Jan 20 04:33:18 2011 Uli Fouquet
5## $Id$
6##
7## Copyright (C) 2011 Uli Fouquet & Henrik Bettermann
8## This program is free software; you can redistribute it and/or modify
9## it under the terms of the GNU General Public License as published by
10## the Free Software Foundation; either version 2 of the License, or
11## (at your option) any later version.
12##
13## This program is distributed in the hope that it will be useful,
14## but WITHOUT ANY WARRANTY; without even the implied warranty of
15## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16## GNU General Public License for more details.
17##
18## You should have received a copy of the GNU General Public License
19## along with this program; if not, write to the Free Software
20## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21##
22"""
23Containers for university applicants.
24"""
25import grok
26from zope.component.factory import Factory
27from zope.component.interfaces import IFactory
28from waeup.sirp.applicants.interfaces import (
29    IApplicantsContainer, IApplicantsContainerAdd,
30    IApplicantsContainerProvider,
31    )
32from waeup.sirp.utils.helpers import attrs_to_fields
33
34class ApplicantsContainer(grok.Container):
35    """An applicants container contains university applicants.
36    """
37    grok.implements(IApplicantsContainer,IApplicantsContainerAdd)
38
39    #: These are 'class-attributes'. Do not fiddle around with it in
40    #: instances of this class.
41    #:
42    #: The title of this container as displayed in add-forms. It should
43    #: give some idea about what kind of container this is (one or two words)
44    container_title = u'Basic'
45
46    #: Another 'class-attribute'. Do not fiddle around with it in instances
47    #: of this class.
48    #:
49    #: The `container_description` gives a short explanation about for what
50    #: purposes this container type serves (a few words only).
51    container_description = u'handles basic applicants'
52
53    @property
54    def local_roles(cls):
55        return ['waeup.ApplicationsOfficer']
56
57    def archive(self, app_ids=None):
58        """Create on-dist archive of applicants stored in this term.
59
60        If app_ids is `None`, all applicants are archived.
61
62        If app_ids contains a single id string, only the respective
63        applicants are archived.
64
65        If app_ids contains a list of id strings all of the respective
66        applicants types are saved to disk.
67        """
68        raise NotImplementedError()
69
70    def clear(self, app_ids=None, archive=True):
71        """Remove applicants of type given by 'id'.
72
73        Optionally archive the applicants.
74
75        If id is `None`, all applicants are archived.
76
77        If id contains a single id string, only the respective
78        applicants are archived.
79
80        If id contains a list of id strings all of the respective
81        applicant types are saved to disk.
82
83        If `archive` is ``False`` none of the archive-handling is done
84        and respective applicants are simply removed from the
85        database.
86        """
87        raise NotImplementedError()
88
89ApplicantsContainer = attrs_to_fields(ApplicantsContainer)
90
91class ApplicantsContainerProvider(grok.GlobalUtility):
92    """A utility that provides basic applicants containers.
93    """
94    grok.implements(IApplicantsContainerProvider)
95    grok.name('waeup.sirp.applicants.ApplicantsContainer')
96
97    #: The applicants container type this provider provides:
98    #: :class:`ApplicantsContainer`.
99    factory = ApplicantsContainer
100
101factory = Factory(lambda : ApplicantsContainer, 'ApplicantsContainer')
102grok.global_utility(factory, IFactory, name='waeup.ApplicantsContainer')
Note: See TracBrowser for help on using the repository browser.