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

Last change on this file since 6097 was 6077, checked in by uli, 14 years ago

Remove trailing whitespaces.

File size: 3.3 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
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 waeup.sirp.applicants.interfaces import (
27    IApplicantsContainer, IApplicantsContainerAdd,
28    IApplicantsContainerProvider,
29    )
30from waeup.sirp.utils.helpers import attrs_to_fields
31
32class ApplicantsContainer(grok.Container):
33    """An applicants container contains university applicants.
34    """
35    grok.implements(IApplicantsContainer,IApplicantsContainerAdd)
36    #grok.provides(IApplicantsContainer)
37
38    #: These are 'class-attributes'. Do not fiddle around with it in
39    #: instances of this class.
40    #:
41    #: The title of this container as displayed in add-forms. It should
42    #: give some idea about what kind of container this is (one or two words)
43    container_title = u'Basic'
44
45    #: Another 'class-attribute'. Do not fiddle around with it in instances
46    #: of this class.
47    #:
48    #: The `container_description` gives a short explanation about for what
49    #: purposes this container type serves (a few words only).
50    container_description = u'handles basic applicants'
51
52    def archive(self, app_ids=None):
53        """Create on-dist archive of applicants stored in this term.
54
55        If app_ids is `None`, all applicants are archived.
56
57        If app_ids contains a single id string, only the respective
58        applicants are archived.
59
60        If app_ids contains a list of id strings all of the respective
61        applicants types are saved to disk.
62        """
63        raise NotImplemented()
64
65    def clear(self, app_ids=None, archive=True):
66        """Remove applicants of type given by 'id'.
67
68        Optionally archive the applicants.
69
70        If id is `None`, all applicants are archived.
71
72        If id contains a single id string, only the respective
73        applicants are archived.
74
75        If id contains a list of id strings all of the respective
76        applicant types are saved to disk.
77
78        If `archive` is ``False`` none of the archive-handling is done
79        and respective applicants are simply removed from the
80        database.
81        """
82        raise NotImplemented()
83
84ApplicantsContainer = attrs_to_fields(ApplicantsContainer)
85
86class ApplicantsContainerProvider(grok.GlobalUtility):
87    """A utility that provides basic applicants containers.
88    """
89    grok.implements(IApplicantsContainerProvider)
90    grok.name('waeup.sirp.applicants.ApplicantsContainer')
91
92    #: The applicants container type this provider provides:
93    #: :class:`ApplicantsContainer`.
94    factory = ApplicantsContainer
Note: See TracBrowser for help on using the repository browser.