source: WAeUP_SRP/trunk/skins/waeup_student/getAccommodationInfo.py @ 1656

Last change on this file since 1656 was 1571, checked in by Henrik Bettermann, 18 years ago

new logging format Part 4 (rest)

  • Property svn:keywords set to Id
File size: 3.9 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 1571 2007-03-17 15:25:56Z henrik $
11"""
12return Info about the current Student
13"""
14import logging
15logger = logging.getLogger('Skins.getAccommodationInfo')
16import DateTime
17
18request = context.REQUEST
19mtool = context.portal_membership
20wf = context.portal_workflow
21member = mtool.getAuthenticatedMember()
22member_id = str(member)
23path_info = request.get('PATH_INFO').split('/')
24
25if mtool.isAnonymousUser():
26    return None
27info = {}
28if student_id is None:
29    requested_id = context.getStudentId()
30    if requested_id and not context.isStaff() and member_id != requested_id:
31        logger.info('%s tried to access %s' % (member_id,requested_id))
32        return None
33    elif context.isStaff():
34        student_id = requested_id
35    else:
36        student_id = member_id
37res = context.students_catalog(id=student_id)
38if len(res) != 1:
39    logger.info('%s not found in students_catalog' % student_id)
40    return None
41
42ekehuan_certificates = ('BARTAPG',
43                        'BARTAPM',
44                        'BARTCER',
45                        'BARTFAA',
46                        'BARTFAP',
47                        'BARTSCP',
48                        'BARTTXT',
49                        'BARTMAS',
50                        'BARTTHR',
51                        )
52pti_certificates = ('BENGIEP',
53                    'BENGGCPP',
54                    'BENGEEP',
55                    'BENGGEP',
56                    'BENGPEP',
57                    'BENGMEP',
58                    )
59s_brain = res[0]
60info['error'] = None
61info['matric_no']=s_brain.matric_no
62info['jamb_reg_no']=s_brain.jamb_reg_no
63info['name']=s_brain.name
64info['email']=s_brain.email
65info['level']=s_brain.level
66info['verdict']=getattr(s_brain,"verdict","N/A")
67
68
69students_object = context.portal_url.getPortalObject().campus.students
70student = getattr(students_object, student_id)
71info['id'] = student_id
72info['student'] = student
73review_state = info['review_state'] = wf.getInfoFor(student,'review_state',None)
74booking_allowed = False
75if review_state in ('cleared_and_validated','returning','school_fee_paid','courses_registered', 'courses_validated',):
76    booking_allowed = True
77    res = context.results_import(matric_no = s_brain.matric_no)
78    if res:
79        booking_allowed = info['verdict'] in ("A",
80                                             "B",)
81info['booking_allowed'] = booking_allowed
82if not booking_allowed:
83    info['acco'] = None
84    return info
85acco_id = 'accommodation_2006'
86acco = getattr(student,acco_id,None)
87info['acco'] = acco
88info['acco_id'] = acco_id
89bt = 're'
90if acco is not None:
91    info['acco_doc'] = acco.getContent()
92    info['acco_review_state'] = wf.getInfoFor(acco,'review_state',None)
93d = {}
94if review_state == "cleared_and_validated":
95    bt = 'fr'
96elif int(s_brain.level) < 300:
97    bt = 're'
98else:
99    res = context.portal_catalog(portal_type = "Certificate", id = s_brain.course)
100    if res:
101        c_brain = res[0]
102        #from Products.zdb import set_trace; set_trace()
103        certificate = c_brain.getObject().getContent()
104        try:
105            certlevel = int(certificate.end_level)
106        except:
107            info["error"] = '"no end_level for","%s"' % c_brain.getId
108            return info
109        try:
110            studentlevel = int(s_brain.level)
111        except:
112            info["error"] = '"no level for","%s"' % s_brain.getId
113            return info
114        if studentlevel >= certlevel:
115            bt = "fi"
116d['sex'] = 'male'
117if s_brain.sex:
118    d['sex'] = 'female'
119if s_brain.course in ekehuan_certificates:
120    bt += "_ekenhuan"
121elif s_brain.course in pti_certificates:
122    bt += "_pti"
123elif s_brain.faculty in ('MED') and int(s_brain.level) >= 400:
124    bt += "_med"
125
126info['sex']=d['sex']
127
128
129d['bt'] = bt
130#from Products.zdb import set_trace
131#set_trace()
132student_status = "%(sex)s_%(bt)s" % d
133info['student_status'] = student_status
134return info
135
Note: See TracBrowser for help on using the repository browser.