source: WAeUP_SRP/trunk/skins/waeup_student/register_courses.py @ 5819

Last change on this file since 5819 was 5457, checked in by Henrik Bettermann, 14 years ago

resolve #687

File size: 2.1 KB
Line 
1## Script (Python) "register_courses"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=REQUEST=None, student=None, action_after_reject=None, action_after_validate=None
8##title=
9##
10# $Id: register_courses.py 1504 2007-02-26 21:20:40Z henrik $
11"""
12close the Students StudyLevel
13"""
14from Products.CMFCore.WorkflowCore import WorkflowException
15try:
16    from Products.zdb import set_trace
17except:
18    def set_trace():
19        pass
20
21from urllib import urlencode
22
23request = context.REQUEST
24mtool = context.portal_membership
25member = mtool.getAuthenticatedMember()
26member_id = str(member)
27import logging
28logger = logging.getLogger('Skins.register_courses')
29
30wftool = context.portal_workflow
31students_folder = context.portal_url.getPortalObject().campus.students
32student_id = context.getStudentId()
33student = getattr(students_folder,student_id)
34
35info = context.getStudyLevelInfo()
36if info['credits_exceeded']:
37    args = {}
38    args['portal_status_message'] = "Your total credits exceed %s!" % info['max_credits']
39    url = context.absolute_url() + '?' + urlencode(args)
40    logger.info('%s tried to register course list with credits exceeded, probably by pressing the browser back button' % (student_id))
41    return REQUEST.RESPONSE.redirect(url)
42
43try:
44    wftool.doActionFor(student,'register_courses')
45except WorkflowException,E:
46    logger.info('%s WorkflowException %s for %s' % (member_id,E,student_id))
47    return request.RESPONSE.redirect("%s" % context.absolute_url())
48
49try:
50    wftool.doActionFor(context,'close')
51except WorkflowException,E:
52    #logger.info('%s WorkflowException %s for %s' % (member_id,E,student_id))
53    #return request.RESPONSE.redirect("%s" % context.absolute_url())
54    pass
55
56logger.info('%s registered course list of %s' % (member_id,student_id))
57args = {}
58psm = "You successfully submitted your course list!"
59args['portal_status_message'] = psm
60if action_after_validate:
61    url = context.absolute_url() + '/' + action_after_validate + '?' + urlencode(args)
62else:
63    url = context.absolute_url() + '?' + urlencode(args)
64return REQUEST.RESPONSE.redirect(url)
Note: See TracBrowser for help on using the repository browser.