source: main/waeup.sirp/trunk/src/waeup/sirp/applicants/root.py @ 6604

Last change on this file since 6604 was 6582, checked in by Henrik Bettermann, 13 years ago

Fix log string.

File size: 4.9 KB
Line 
1##
2## root.py
3## Login : <uli@pu.smp.net>
4## Started on  Thu Jan 20 04:17:59 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"""
23The root for applicants.
24"""
25import grok
26from hurry.query import Eq
27from hurry.query.interfaces import IQuery
28from zope.component import getUtility
29from waeup.sirp.interfaces import IWAeUPSIRPPluggable
30from waeup.sirp.applicants.interfaces import IApplicantsRoot
31from waeup.sirp.utils.helpers import get_current_principal
32from waeup.sirp.utils.logger import Logger
33
34class ApplicantsRoot(grok.Container, Logger):
35    """The root of applicants-related components. It contains only
36    containers for applicants.
37    """
38    grok.implements(IApplicantsRoot)
39
40    local_roles = ['waeup.ApplicationsOfficer']
41
42    logger_name = 'waeup.sirp.${sitename}.applicants'
43    logger_filename = 'applicants.log'
44
45    def logger_info(self, target, ob_class, comment=None):
46        """Get the logger's info method.
47        """
48        user = get_current_principal()
49        if user is None:
50            user = 'system'
51        elif user.title == 'Applicant':
52            user = 'applicant'
53        else:
54            user = user.id
55        self.logger.info('%s - %s - %s - %s' % (
56                user, target, ob_class, comment))
57        return
58
59class ApplicantsPlugin(grok.GlobalUtility):
60    """A WAeUPSIRPPlugin that creates an applicants root in portal.
61
62    This plugin should be called by a typical
63    `waeup.sirp.app.Universtiy` instance on creation time. The
64    :meth:`update` method normally can also be triggered manually over
65    the main site configuration.
66
67    Implements :class:`waeup.sirp.interfaces.IWAeUPSIRPPluggable`
68    """
69    grok.name('applicants')
70    grok.implements(IWAeUPSIRPPluggable)
71    log_prefix = 'ApplicantsPlugin'
72
73    def setup(self, site, name, logger):
74        """Create a new :class:`ApplicantsRoot` instance in `site`.
75        """
76        site['applicants'] = ApplicantsRoot()
77        logger.info(
78            '%s: Installed applicants root.' % (self.log_prefix,)
79            )
80        return
81
82    def update(self, site, name, logger):
83        """Update site wide ``applicants`` root.
84
85        If the site already contains a suitable ``applicants`` root,
86        leave it that way. If not create one and delete the old one if
87        appropriate.
88        """
89        app_folder = site.get('applicants', None)
90        site_name = getattr(site, '__name__', '<Unnamed Site>')
91        if IApplicantsRoot.providedBy(app_folder):
92            # Applicants up to date. Return.
93            logger.info(
94                '%s: Updating site at %s: Nothing to do.' % (
95                    self.log_prefix, site_name,)
96                )
97            return
98        elif app_folder is not None:
99            # Applicants need update. Remove old instance.
100            logger.warn(
101                '%s: Outdated applicants folder detected at site %s.'
102                'Removing it.' % (self.log_prefix, site_name)
103                    )
104            del site['applicants']
105        # Add new applicants.
106        logger.info(
107            '%s: Updating site at %s. Installing '
108            'applicants.' % (self.log_prefix, site_name,)
109            )
110        self.setup(site, name, logger)
111        return
112
113def get_applicant_data(identifier):
114    """Get applicant data associated with `identifier`.
115
116    Returns the applicant object if successful and ``None`` else.
117
118    As `identifier` we expect an access code in format
119    like ``PREFIX-XXX-YYYYYYYY`` where ``PREFIX`` is something like
120    ``APP`` or ``PUDE``, ``XXX`` the access code series and
121    ``YYYYYYYYYY`` the real accesscode number.
122
123    This function requires a fully blown setup as it does catalog
124    lookups for finding applicants.
125    """
126    query = getUtility(IQuery)
127    results = list(query.searchResults(
128            Eq(('applicants_catalog', 'access_code'), identifier)
129            ))
130    if len(results) == 0:
131        return None
132    return results[0]
133
134def application_exists(identifier):
135    """Check whether an application for the given identifier already
136       exists.
137
138       `identifier` will normally be an access code.
139    """
140    applicant = get_applicant_data(identifier)
141    if applicant is None:
142        return False
143    return True
Note: See TracBrowser for help on using the repository browser.