source: WAeUP_SRP/trunk/skins/waeup_student/getClearanceInfo.py @ 5070

Last change on this file since 5070 was 5029, checked in by Henrik Bettermann, 15 years ago

add logging info

  • Property svn:keywords set to Id
File size: 3.2 KB
RevLine 
[1161]1## Script (Python) "getClearanceInfo"
[1073]2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=
8##title=
9##
10# $Id: getClearanceInfo.py 5029 2010-02-22 09:23:10Z henrik $
11"""
12return Info about the current Student
13"""
[3452]14try:
15    from Products.zdb import set_trace
16except:
17    def set_trace():
18        pass
[1073]19import logging
[1571]20logger = logging.getLogger('Skins.getClearanceInfo')
[1141]21from DateTime import DateTime
[1073]22
23request = context.REQUEST
24mtool = context.portal_membership
25wf = context.portal_workflow
26member = mtool.getAuthenticatedMember()
27member_id = str(member)
28path_info = request.get('PATH_INFO').split('/')
29
[2975]30# if mtool.isAnonymousUser():
31#     return None
32# info = {}
33# #from Products.zdb import set_trace
34# #set_trace()
35# requested_id = context.getStudentId()
36# if requested_id and not context.isStaff() and member_id != requested_id:
37#     logger.info('%s tried to access %s' % (member_id,requested_id))
38#     return None
39# elif context.isStaff():
40#     student_id = requested_id
41# else:
42#     student_id = member_id
43
44info = context.waeup_tool.getAccessInfo(context)
45student_id = info['student_id']
46if student_id is None:
[1073]47    return None
[5028]48if info['is_staff'] and not info['is_clearanceofficer'] and not info['is_sectionofficer']:
[5029]49    logger.info('%s tried to access %s' % (member_id,student_id))
[5028]50    return None
[1073]51
[3452]52student_record = context.students_catalog.getRecordByKey(student_id)
[1073]53students_object = context.portal_url.getPortalObject().campus.students
54student = getattr(students_object, student_id)
[3452]55# res = context.portal_catalog(portal_type='Student',id = student_id)
56# if len(res) == 0:
57#     return None
58# creation_date = DateTime(res[0].CreationDate)
59# info['penalty'] = creation_date.lessThan(DateTime('2006/12/5'))
60info['penalty'] = False
[1073]61info['id'] = student_id
62info['student'] = student
[3452]63info['student_name'] = student_record.name
64#info['review_state'] = context.getStudentReviewState()
65info['review_state'] = student_record.review_state
[3455]66info['app'] = student.application
[3619]67try:
68    info['app_doc'] = student.application.getContent()
69except:
70    return
[1073]71info['clear'] = student.clearance
[3619]72try:
73    info['clear_doc'] = student.clearance.getContent()
74except:
75    return   
[1073]76info['clear_review_state'] = wf.getInfoFor(student.clearance,'review_state',None)
[2670]77info['per'] = student.personal
78info['per_review_state'] = wf.getInfoFor(student.personal,'review_state',None)
[3452]79ci = {}
80ci['course'] = student_record.course
81ci['faculty'] = student_record.faculty
82ci['department'] = student_record.department
83info['course_doc'] = ci
84# if info['review_state'] in ('clearance_requested', 'cleared_and_validated',):
85#     info['penalty'] = info['penalty'] and\
86#                       info['clear_doc'].entry_date.greaterThan(DateTime('2006/12/30'))
87# course = getattr(student,'study_course',None)
88# if course:
89#     cert_id = course.getContent().study_course
90#     res = context.portal_catalog(portal_type = "Certificate", id = cert_id)
91#     ci = {}
92#     if len(res) > 0:
93#         info['course'] = course
94#         brain = res[0]
95#         ci['study_course'] = brain.getId
96#         ci['title'] = brain.Title
97#         pl = brain.getPath().split('/')
98#         ci['faculty'] = pl[-4]
99#         ci['department'] = pl[-3]
100#         info['course_doc'] = ci
101#     else:
102#         info['course'] = None
[1073]103return info
Note: See TracBrowser for help on using the repository browser.