source: main/waeup.kofa/trunk/src/waeup/kofa/students/catalog.py @ 9182

Last change on this file since 9182 was 9170, checked in by Henrik Bettermann, 12 years ago

Add former_course attribute. Logic will follow.

  • Property svn:keywords set to Id
File size: 4.9 KB
Line 
1## $Id: catalog.py 9170 2012-09-11 09:13:41Z henrik $
2##
3## Copyright (C) 2011 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"""Cataloging and searching components for students.
19"""
20import grok
21from grok import index
22from hurry.query import Eq, Text
23from hurry.query.query import Query
24from zope.catalog.interfaces import ICatalog
25from zope.component import queryUtility
26from waeup.kofa.interfaces import (
27    IUniversity, IQueryResultItem, academic_sessions_vocab)
28from waeup.kofa.students.interfaces import IStudent, ICourseTicket
29from waeup.kofa.university.vocabularies import course_levels
30
31class StudentsCatalog(grok.Indexes):
32    """A catalog for students.
33    """
34    grok.site(IUniversity)
35    grok.name('students_catalog')
36    grok.context(IStudent)
37
38    student_id = index.Field(attribute='student_id')
39    fullname = index.Text(attribute='fullname')
40    email = index.Field(attribute='email')
41    reg_number = index.Field(attribute='reg_number')
42    matric_number = index.Field(attribute='matric_number')
43    state = index.Field(attribute='state')
44    certcode = index.Field(attribute='certcode')
45    depcode = index.Field(attribute='depcode')
46    faccode = index.Field(attribute='faccode')
47    current_session = index.Field(attribute='current_session')
48    current_mode = index.Field(attribute='current_mode')
49
50class StudentQueryResultItem(object):
51    grok.implements(IQueryResultItem)
52
53    title = u'Student Query Item'
54    description = u'Some student found in a search'
55
56    def __init__(self, context, view):
57        self.context = context
58        self.url = view.url(context)
59        self.student_id = context.student_id
60        self.display_fullname = context.display_fullname
61        self.reg_number = context.reg_number
62        self.matric_number = context.matric_number
63        self.state = context.state
64        self.translated_state = context.translated_state
65        #try:
66        #    current_level = course_levels.getTerm(
67        #        context['studycourse'].current_level).title
68        #except LookupError:
69        #    current_level = None
70        #self.current_level = current_level
71
72        self.current_level = context['studycourse'].current_level
73
74        try:
75            current_session = academic_sessions_vocab.getTerm(
76                context['studycourse'].current_session).title
77        except LookupError:
78            current_session = None
79        self.current_session = current_session
80        self.certificate = context['studycourse'].certificate
81
82def search(query=None, searchtype=None, view=None):
83    hitlist = []
84    if searchtype in ('fullname',):
85        results = Query().searchResults(
86            Text(('students_catalog', searchtype), query))
87    else:
88        # Temporary solution to display all students added
89        if query == '*':
90            cat = queryUtility(ICatalog, name='students_catalog')
91            results = cat.searchResults(student_id=(None, None))
92        else:
93            results = Query().searchResults(
94                Eq(('students_catalog', searchtype), query))
95    for result in results:
96        hitlist.append(StudentQueryResultItem(result, view=view))
97    return hitlist
98
99class SimpleFieldSearch(object):
100    """A programmatic (no UI required) search.
101
102    Looks up a given field attribute of the students catalog for a
103    single value. So normally you would call an instance of this
104    search like this:
105
106      >>> SimpleFieldSearch()(reg_number='somevalue')
107
108    """
109    catalog_name = 'students_catalog'
110    def __call__(self, **kw):
111        """Search students catalog programmatically.
112        """
113        if len(kw) != 1:
114            raise ValueError('must give exactly one index name to search')
115        cat = queryUtility(ICatalog, name=self.catalog_name)
116        index_name, query_term = kw.items()[0]
117        results = cat.searchResults(index_name=(query_term, query_term))
118        return results
119
120#: an instance of `SimpleFieldSearch` looking up students catalog.
121simple_search = SimpleFieldSearch()
122
123class CourseTicketIndexes(grok.Indexes):
124    """A catalog for course tickets.
125    """
126    grok.site(IUniversity)
127    grok.name('coursetickets_catalog')
128    grok.context(ICourseTicket)
129
130    level = index.Field(attribute='getLevel')
131    session = index.Field(attribute='getLevelSession')
132    code = index.Field(attribute='code')
Note: See TracBrowser for help on using the repository browser.