source: WAeUP_SRP/trunk/skins/waeup_student/lecturer_course_edit.py @ 5162

Last change on this file since 5162 was 4300, checked in by Henrik Bettermann, 16 years ago

resolve schools #7 and more ...

File size: 3.6 KB
RevLine 
[3611]1## Script (Python) "lecturer_course_edit"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=REQUEST, cpsdocument_edit_button=None, cpsdocument_edit_and_view_button=None, action=None
8##title=
9# $Id: course_edit.py 1071 2006-12-16 15:53:13Z joachim $
10"""
11"""
12try:
13    from Products.zdb import set_trace
14except:
15    def set_trace():
16        pass
17from urllib import urlencode
18from Products.CPSDocument.utils import getFormUidUrlArg
19from Products.AdvancedQuery import Eq, Between, Le,In
20import DateTime
21current = DateTime.DateTime()
22import logging
[3617]23logger = logging.getLogger('Skins.lecturer_course_edit')
[3611]24wf = context.portal_workflow
25request = REQUEST
26edit = "edit" in request.form.keys()
27mtool = context.portal_membership
28member = mtool.getAuthenticatedMember()
29groups = member.getGroups()
30
31member_id = str(member)
32requested_id = context.getStudentId()
[3752]33if not 'Lecturers' in groups and not context.isSectionOfficer():
[4033]34    logger.info('%s tried to access course result record of %s but is not a lecturer' % (member_id,requested_id))
[3611]35    return REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())
36
37student_id = requested_id
[4033]38student_record = context.students_catalog.getRecordByKey(student_id)
39if student_record.review_state != 'courses_validated':
40    logger.info('%s tried to access non-validated course result record of %s' % (member_id,requested_id))
[4043]41    return 'Subject/course lists must be validated before editing results!'
[3611]42
[4033]43
[3611]44level_id = context.getId()
45course_id = traverse_subpath[0]
46query = Eq('student_id',student_id) &\
47        Eq('level_id', level_id) &\
48        Eq('code', course_id)
49
50course_results = context.course_results.evalAdvancedQuery(query)
51mode = 'edit'
52object = {}
[3818]53course_result = course_results[0]
54course = context.courses_catalog(code=course_id)[0]
55lecturer_id = getattr(course,'lecturer',None)
56#set_trace()
[4300]57if  member_id not in str(lecturer_id) and not context.isSectionOfficer():
[4033]58    logger.info('%s tried to access course result record %s of %s but is not a lecturer of this course' % (member_id,course_id,requested_id))
[3818]59    return REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())
60
[3611]61for field in context.course_results.schema():
[3818]62    object[field] = getattr(course_result,field,None)
[3707]63    if repr(object[field]) == 'Missing.Value':
64        object[field] = None
[3818]65     
[3611]66lt = context.portal_layouts
67res,psm, ds = lt.renderLayout(schema_id = 'student_course_result',
68                               layout_id = 'student_course_result',
69                               layout_mode = mode,
70                               context=context,
71                               mapping=edit and REQUEST,
72                               ob=object,
73                               commit = False)
74
75while True:
76    if psm == 'invalid':
77        psm = "Please correct your input"
78        break
79    elif psm == '':
80        break
81    if edit:
82        data = {}
83        dm = ds.getDataModel()
84        for field in context.course_results.schema():
85            if dm.has_key("%s" % field):
86                data[field] = dm.get(field)
87        data['key'] = object['key']
88        context.course_results.modifyRecord(**data)
[3786]89        logger.info('%s edited course result %s of %s' % (member_id,course_id,student_id))
[3611]90        psm = 'psm_content_changed'
91        break
[3617]92return context.lecturer_course_edit_form(rendered = res,
[3611]93                                psm = psm,
94                                mode = mode,
95                                ds = ds,
[4043]96                               )
Note: See TracBrowser for help on using the repository browser.