source: WAeUP_SRP/base/skins/waeup_student/create_level.py @ 2987

Last change on this file since 2987 was 2977, checked in by joachim, 17 years ago

fix for #437 please test

  • Property svn:keywords set to Id
File size: 6.6 KB
Line 
1##parameters=
2# $Id: create_level.py 2977 2008-01-03 18:47:51Z joachim $
3"""
4process the Application Form
5return html renderer + psm
6"""
7request = context.REQUEST
8import DateTime,logging
9try:
10    from Products.zdb import set_trace
11except:
12    def set_trace():
13        pass
14from Products.AdvancedQuery import Eq, Between, Le,In
15try:
16    aq_portal = context.portal_catalog.evalAdvancedQuery
17except:
18    aq_portal = context.portal_catalog_real.evalAdvancedQuery
19aq_courses = context.courses_catalog.evalAdvancedQuery
20aq_results = context.course_results.evalAdvancedQuery
21
22current = DateTime.DateTime()
23request = context.REQUEST
24response = request.RESPONSE
25redirect = response.redirect
26logger = logging.getLogger('Skins.create_level')
27# mtool = context.portal_membership
28# member = mtool.getAuthenticatedMember()
29# member_id = str(member)
30# requested_id = context.getStudentId()
31# #set_trace()
32# create_level =  request.form.get('create_level',None)
33# if not create_level or not requested_id or\
34#    (not context.isStaff() and member_id != requested_id):
35#     logger.info('%s tried to access %s' % (member_id,requested_id))
36#     return redirect("%s/srp_anonymous_view" % context.portal_url())
37# student_id = context.getStudentId()
38info = context.waeup_tool.getAccessInfo(context)
39student_id = info['student_id']
40if student_id is None:
41    return None
42
43#lt = context.portal_layouts
44#wt = context.waeup_tool
45student = context.students_catalog.getRecordByKey(student_id)
46cert_id = student.course
47current_level = student.level
48current_session = student.session
49in_progress =  request.get('in_progress','not started')
50if aq_results(Eq('student_id',student_id) & Eq('level_id',current_level)):
51    logger.info('%s tried to create already existing level %s' % (student.id,current_level))
52    return
53
54logger.info('%s started to create level %s' % (student.id,current_level))
55
56if context.hasObject(current_level):
57    #level = getattr(context,"%s" % current_level)
58    return response.redirect("%s/%s" % (context.absolute_url(),current_level))
59else:
60    context.invokeFactory('StudentStudyLevel',"%s" % current_level)
61    level = getattr(context,"%s" % current_level)
62    context.portal_workflow.doActionFor(level,'open')
63    level.getContent().edit(mapping={'session': current_session})
64    #context.portal_workflow.doActionFor(level,'close_for_edit')
65level_id = level.getId()
66onprobation = context.getContent().previous_verdict in ('C',)
67session_id = context.getLevelSession(level.getContent(),student_id,level_id)
68results = []
69records = []
70if student.matric_no:
71    results = context.results_import(matric_no = student.matric_no)
72l = []
73
74# fetch carry_over courses from results_import
75if student.session in ('6', '06') and results:
76    carry_overs = results
77    for co in carry_overs:
78        course_id = co.CosCode
79        if level.hasObject(course_id):    #already created
80            continue
81        carry_over = False
82        query = Eq('code',co.CosCode)
83        c_res = aq_courses(query)
84        if not c_res:
85            #logger.info('%s", course %s not found in courses_catalog' % (student.id,co.CosCode))
86            continue
87        course_cat_entry = c_res[0]
88        passmark = getattr(course_cat_entry,'passmark',None)
89        if not passmark or not co.Score:
90            carry_over = co.GRADE in ('D','E','F')
91        else:
92            try:
93                score = int(co.Score)
94            except:
95                # logger.info('%s, course %s has invalid score %s"' % (student.id,
96                #                                                     course_id,
97                #                                                     co.Score))
98                continue
99            if int(c_res[0].passmark) <= score:
100                continue
101            carry_over = True
102        if not carry_over:
103            continue
104        if course_id in l:
105            # don't add twice
106            continue
107        l += course_id,
108        d = context.getCourseInfo(co.CosCode)
109        d['course_id'] = course_id
110        d['carry_over'] = carry_over
111        d['code'] = course_id
112        d['student_id'] = student_id
113        d['level_id'] = level_id
114        d['session_id'] = session_id
115        records.append(d)
116# fetch carry_over courses from the course_results catalog
117elif not onprobation:
118    res = aq_results(Eq('student_id',student_id),
119                             sortSpecs=('level_id',))
120    if res:
121        last_level_id = res[-1].level_id
122    for result in res:
123        course_id = result.code
124        if course_id in l or result.level_id != last_level_id:
125            continue
126        query = Eq('code',course_id)
127        c_res = aq_courses(query)
128        if not c_res:
129            #logger.info('%s", course %s not found in courses_catalog' % (student.id,result.CosCode))
130            continue
131        course_cat_entry = c_res[0]
132        passmark = getattr(course_cat_entry,'passmark',None)
133        try:
134            score = int(result.score)
135        except:
136            # logger.info('%s, course %s has invalid score %s"' % (student.id,
137            #                                                     course_id,
138            #                                                     result.Score))
139            continue
140        if int(c_res[0].passmark) <= score:
141            continue
142        l += course_id,
143        d = context.getCourseInfo(course_id)
144        d['course_id'] = course_id
145        d['carry_over'] = True
146        d['code'] = course_id
147        d['student_id'] = student_id
148        d['level_id'] = level_id
149        d['session_id'] = session_id
150        records.append(d)
151
152# fetch session courses from the certificate
153res = context.portal_catalog(portal_type="Certificate", id = cert_id)
154if res:
155    cert = res[0]
156    path = cert.getPath()
157    academics_level = 100 * (int(current_level)/100)
158    query = Eq("path","%s/%s" % (path,academics_level)) &\
159            Eq('portal_type','CertificateCourse')
160    courses = aq_portal(query)
161    for c in courses:
162        course_id = "%s" % c.getId
163        if course_id in l:
164            # don't add twice
165            continue
166        l += course_id,
167        d = context.getCourseInfo(c.getId)
168        d['carry_over'] = False
169        d['core_or_elective'] = getattr(c.getObject().getContent(),'core_or_elective')
170        d['course_id'] = course_id
171        d['student_id'] = student_id = context.getStudentId()
172        d['level_id'] = level_id
173        d['session_id'] = session_id
174        records.append(d)
175if records:
176    context.course_results.addMultipleRecords(records)
177logger.info('%s finished to create level %s' % (student.id,current_level))
178
179return response.redirect("%s/%s" % (context.absolute_url(),current_level))
Note: See TracBrowser for help on using the repository browser.