source: WAeUP_SRP/trunk/skins/waeup_futminna/getAccommodationInfo.py @ 3925

Last change on this file since 3925 was 3843, checked in by Henrik Bettermann, 16 years ago
  • pay_interswitch.py: add bank account for futminna spillovers
  • minor changes
File size: 3.0 KB
Line 
1## Script (Python) "getAccommodationInfo"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=student_id=None
8##title=
9##
10# $Id: getAccommodationInfo.py 1726 2007-05-02 06:21:50Z henrik $
11"""
12return Info about the current Student
13"""
14import logging
15logger = logging.getLogger('Skins.getAccommodationInfo')
16import DateTime
17
18booking_disabled = False
19
20request = context.REQUEST
21mtool = context.portal_membership
22wf = context.portal_workflow
23member = mtool.getAuthenticatedMember()
24member_id = str(member)
25path_info = request.get('PATH_INFO').split('/')
26
27if mtool.isAnonymousUser():
28    return None
29info = {}
30if student_id is None:
31    requested_id = context.getStudentId()
32    if requested_id and not context.isStaff() and member_id != requested_id:
33        logger.info('%s tried to access %s' % (member_id,requested_id))
34        return None
35    elif context.isStaff():
36        student_id = requested_id
37    else:
38        student_id = member_id
39student_record = context.students_catalog.getRecordByKey(student_id)
40if student_record is None:
41    logger.info('%s not found in students_catalog' % student_id)
42    return None
43
44info['error'] = None
45info['matric_no']=student_record.matric_no
46info['jamb_reg_no']=student_record.jamb_reg_no
47info['name']=student_record.name
48info['email']=student_record.email
49info['level']=student_record.level
50info['verdict']=getattr(student_record,'verdict','')
51review_state = info['review_state'] = student_record.review_state
52info['session'] = session = context.getSessionId()
53students_object = context.portal_url.getPortalObject().campus.students
54student = getattr(students_object, student_id)
55info['student_id'] = student_id
56info['student'] = student
57
58booking_allowed = False
59
60# customize from here
61
62try:
63    level = int(student_record.level)
64except:
65    logger.info('%s has invalid level %s' % (student_id,student_record.level))
66    info['acco'] = None
67    info['booking_allowed'] = False
68    info['student_status'] = ''
69    return info   
70
71if review_state in ('cleared_and_validated','school_fee_paid','courses_registered', 'courses_validated',) and student_record.session == session[0]:
72    info['booking_allowed'] = True
73    info['online_payment'] = True
74else:
75    info['acco'] = None
76    info['booking_allowed'] = False
77    info['student_status'] = ''
78    return info
79
80acco_id = 'accommodation_' + session[0]
81acco = getattr(student,acco_id,None)
82info['acco'] = acco
83info['acco_id'] = acco_id
84
85info['maintenance_paid'] = False
86if acco is not None:
87    info['acco_doc'] = acco.getContent()
88    info['acco_review_state'] = wf.getInfoFor(acco,'review_state',None)
89    info['maintenance_paid'] = info['acco_review_state'] == "maintenance_fee_paid"
90elif booking_disabled:
91    info['booking_allowed'] = False
92   
93d = {}
94d['sex'] = 'male'
95d['bt'] = 'all'
96if student_record.sex:
97    d['sex'] = 'female'
98
99info['sex']=d['sex']
100student_status = "%(sex)s_%(bt)s" % d
101info['student_status'] = student_status
102
103return info
104
Note: See TracBrowser for help on using the repository browser.