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

Last change on this file since 9736 was 9736, checked in by uli, 12 years ago

Students catalog now supports current study level (requires site updates and reindexing).

  • Property svn:keywords set to Id
File size: 4.8 KB
Line 
1## $Id: catalog.py 9736 2012-11-28 16:17:14Z uli $
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_level = index.Field(attribute='current_level')
49    current_mode = index.Field(attribute='current_mode')
50
51class StudentQueryResultItem(object):
52    grok.implements(IQueryResultItem)
53
54    title = u'Student Query Item'
55    description = u'Some student found in a search'
56
57    def __init__(self, context, view):
58        self.context = context
59        self.url = view.url(context)
60        self.student_id = context.student_id
61        self.display_fullname = context.display_fullname
62        self.reg_number = context.reg_number
63        self.matric_number = context.matric_number
64        self.state = context.state
65        self.translated_state = context.translated_state
66        self.current_level = context['studycourse'].current_level
67        try:
68            current_session = academic_sessions_vocab.getTerm(
69                context['studycourse'].current_session).title
70        except LookupError:
71            current_session = None
72        self.current_session = current_session
73        self.certificate = context['studycourse'].certificate
74        self.comment = getattr(context, 'officer_comment', None)
75
76def search(query=None, searchtype=None, view=None):
77    hitlist = []
78    if searchtype in ('fullname',):
79        results = Query().searchResults(
80            Text(('students_catalog', searchtype), query))
81    else:
82        # Temporary solution to display all students added
83        if query == '*':
84            cat = queryUtility(ICatalog, name='students_catalog')
85            results = cat.searchResults(student_id=(None, None))
86        else:
87            results = Query().searchResults(
88                Eq(('students_catalog', searchtype), query))
89    for result in results:
90        hitlist.append(StudentQueryResultItem(result, view=view))
91    return hitlist
92
93class SimpleFieldSearch(object):
94    """A programmatic (no UI required) search.
95
96    Looks up a given field attribute of the students catalog for a
97    single value. So normally you would call an instance of this
98    search like this:
99
100      >>> SimpleFieldSearch()(reg_number='somevalue')
101
102    """
103    catalog_name = 'students_catalog'
104    def __call__(self, **kw):
105        """Search students catalog programmatically.
106        """
107        if len(kw) != 1:
108            raise ValueError('must give exactly one index name to search')
109        cat = queryUtility(ICatalog, name=self.catalog_name)
110        index_name, query_term = kw.items()[0]
111        results = cat.searchResults(index_name=(query_term, query_term))
112        return results
113
114#: an instance of `SimpleFieldSearch` looking up students catalog.
115simple_search = SimpleFieldSearch()
116
117class CourseTicketIndexes(grok.Indexes):
118    """A catalog for course tickets.
119    """
120    grok.site(IUniversity)
121    grok.name('coursetickets_catalog')
122    grok.context(ICourseTicket)
123
124    level = index.Field(attribute='getLevel')
125    session = index.Field(attribute='getLevelSession')
126    code = index.Field(attribute='code')
Note: See TracBrowser for help on using the repository browser.