source: WAeUP_SRP/base/skins/waeup_student/getStudentFolderInfo.py @ 2927

Last change on this file since 2927 was 2837, checked in by joachim, 17 years ago

sort by title

  • Property svn:keywords set to Id
File size: 5.7 KB
Line 
1## Script (Python) "getStudentFolderInfo"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=with_items=None
8##title=
9##
10# $Id: getStudentFolderInfo.py 2837 2007-12-01 12:42:28Z joachim $
11"""
12return Info about the current Student
13try:
14    from Products.zdb import set_trace
15except:
16    def set_trace():
17        pass
18"""
19import DateTime
20request = context.REQUEST
21form = request.form
22fget = form.get
23wf = context.portal_workflow
24mtool = context.portal_membership
25member = mtool.getAuthenticatedMember()
26path_info = request.get('PATH_INFO').split('/')
27
28import logging
29logger = logging.getLogger('Skins.getStudentFolderInfo')
30from Products.AdvancedQuery import Eq, Between, Le,In
31try:
32    aq_portal = context.portal_catalog.evalAdvancedQuery
33except:
34    aq_portal = context.portal_catalog_real.evalAdvancedQuery
35
36
37info = {}
38member_id = str(member)
39#from Products.zdb import set_trace;set_trace()
40is_student = info['is_student'] = context.isStudent()
41is_staff = info['is_staff'] = context.isStaff()
42is_sectionofficer = info['is_sectionofficer'] = context.isSectionOfficer()
43while True:
44    if mtool.isAnonymousUser():
45        return None
46    requested_id = context.getStudentId()
47    if not is_student and requested_id:
48        student_id = requested_id
49        break
50    if member_id != requested_id:
51        logger.info('%s tried to access %s' % (member_id,requested_id))
52        student_id = member_id
53        mtool.assertViewable(context)
54        break
55    student_id = member_id
56    break
57student_path_root = "%s/campus/students/%s" % (context.portal_url.getPortalPath(),student_id)
58student_path = "%s/campus/students/%s" % (context.portal_url(),student_id)
59students_folder = context.portal_url.getPortalObject().campus.students
60# res = context.students_catalog(id = student_id)
61# if not res:
62#     return None
63# student_record = res[0]
64student_record = context.students_catalog.getRecordByKey(student_id)
65if student_record is None:
66    return None
67
68#from Products.zdb import set_trace;set_trace()
69for field in context.students_catalog.schema():
70    info[field] = getattr(student_record,field)
71
72#res = context.portal_catalog(portal_type='Student',id = student_id)
73#if res:
74#    info['review_state'] = res[0].review_state
75
76#info['review_state'] = context.getStudentReviewState()
77
78info['session'] = False
79if student_record.matric_no:
80    res = context.results_import(matric_no = student_record.matric_no)
81    if res:
82       info['session'] = True
83
84info['base_info'] = context.getFormattedStudentEntry(student_record)
85
86info['id'] = student_id
87items = []
88s_edit_links = {'StudentApplication': 'application_edit_form',
89              'StudentAccommodation': 'reserve_accommodation',
90              'StudentClearance': 'clearance_edit_form',
91              'StudentPersonal': 'personal_edit_form',
92              }
93s_view_links = {'StudentApplication': 'application_view',
94              'StudentAccommodation': 'accommodation_view',
95              'StudentClearance': 'clearance_view',
96              'StudentPersonal': 'personal_view',
97              'StudentStudyCourse': 'study_course_view',
98              'PaymentsFolder': 'payments_view',
99              }
100#logger.info("before search")
101#starttime = DateTime.DateTime().timeTime()
102#sos = context.portal_catalog(container_path=student_path_root)
103# query = Eq('container_path',student_path_root)
104# sos = aq_portal(query)
105# logger.info("searchtime %f" % (DateTime.DateTime().timeTime() - starttime))
106# starttime = DateTime.DateTime().timeTime()
107# for so in sos:
108#     row = {}
109#     row['id'] = so.getId
110#     row['title'] = so.Title
111#     url = row['url'] = "%s/%s" % (student_path,so.getId)
112#     row['type'] = so.portal_type
113#     review_state = row['review_state'] = so.review_state
114#     row['is_editable'] = (is_student and review_state == "opened") or is_sectionofficer
115#     sv_link = s_view_links.get(so.portal_type,None) or "waeup_document_view"
116#     row['s_view_link'] = "%s/%s" % (url,sv_link)
117#     se_link = s_edit_links.get(so.portal_type,None)
118#     row['s_edit_link'] = None
119#     if se_link:
120#         row['s_edit_link'] = "%s/%s" % (url,se_link)
121#     row['display'] = review_state in ('opened','closed','bed_reserved','maintenance_fee_paid',)\
122#                     and so.portal_type not in  ('StudentPume','StudentAccommodation','PaymentsFolder',) or\
123#                     so.portal_type == 'StudentStudyCourse'
124#     items.append(row)
125#sos = context.portal_catalog(container_path=student_path_root)
126student_obj = getattr(students_folder,student_id)
127subobjects = student_obj.objectValues()
128#logger.info("searchtime %f" % (DateTime.DateTime().timeTime() - starttime))
129#starttime = DateTime.DateTime().timeTime()
130for subobject in subobjects:
131    row = {}
132    row['id'] = subobject.getId()
133    row['title'] = subobject.Title()
134    url = row['url'] = subobject.absolute_url()
135    row['type'] = subobject.portal_type
136    review_state = row['review_state'] = wf.getInfoFor(subobject,'review_state',None)
137    row['is_editable'] = (is_student and review_state == "opened") or is_sectionofficer
138    sv_link = s_view_links.get(subobject.portal_type,None) or "waeup_document_view"
139    row['s_view_link'] = "%s/%s" % (url,sv_link)
140    se_link = s_edit_links.get(subobject.portal_type,None)
141    row['s_edit_link'] = None
142    if se_link:
143        row['s_edit_link'] = "%s/%s" % (url,se_link)
144    row['display'] = review_state in ('opened','closed','bed_reserved','maintenance_fee_paid',)\
145                    and subobject.portal_type not in  ('StudentPume','StudentAccommodation','PaymentsFolder',) or\
146                    subobject.portal_type == 'StudentStudyCourse'
147    items.append(row)
148#logger.info("listtime %f" % (DateTime.DateTime().timeTime() - starttime))
149#set_trace()
150items.sort(cmp=lambda x,y: cmp( x['title'],y['title']))
151info['items'] = items
152info['member'] = member
153return info
154
Note: See TracBrowser for help on using the repository browser.