source: WAeUP_SRP/trunk/skins/waeup_student/clearance_edit.py @ 1065

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

logging messages modified

  • Property svn:keywords set to Id
File size: 4.3 KB
RevLine 
[845]1## Script (Python) "clearance_edit"
[788]2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
[893]7##parameters=REQUEST, acknowledge=None
[788]8##title=
[805]9# $Id: clearance_edit.py 1054 2006-12-14 07:32:31Z henrik $
[788]10"""
11"""
12wftool = context.portal_workflow
13from urllib import urlencode
14from Products.CPSDocument.utils import getFormUidUrlArg
15import DateTime
16current = DateTime.DateTime()
[1016]17import logging
18logger = logging.getLogger('Student.Clearance')
[788]19
[885]20cpsdocument_edit_button = REQUEST.has_key('cpsdocument_edit_button')
21cpsdocument_edit_and_view_button = REQUEST.has_key('cpsdocument_edit_and_view_button')
22clear_and_validate_button = REQUEST.has_key('clear_and_validate_button')
23reject_clearance_button = REQUEST.has_key('reject_clearance_button')
[893]24
[788]25# Until ajax posts directly to its own script...
26##if 'ajax_edit' in REQUEST.form:
27##    return context.cpsdocument_edit_ajax(REQUEST, cluster=cluster)
28
29# Validate the document and write it if it's valid
30# (We don't call getEditableContent here, validate does it when needed.)
[832]31wftool = context.portal_workflow
[788]32info = context.getStudentInfo()
33
[1036]34
35#'Sorry, you are not allowed to access this page!'
36if info == None:
37        #return REQUEST.RESPONSE.redirect(context.portal_url())
38        return REQUEST.RESPONSE.redirect(context.standard_error_message())
39
[1054]40
[788]41student = info['student']
42app = info['app']
43app_doc = info['app_doc']
44clear = info['clear']
45clear_doc = info['clear_doc']
[1016]46student_id = info['id']
47member_id = str(context.portal_membership.getAuthenticatedMember())
[832]48
[801]49is_valid, ds = clear_doc.validate(request=REQUEST,
[788]50                                schema_id = 'student_clearance',
[885]51                                layout_id = 'student_clearance',
[788]52                                proxy=clear,
53                                use_session=True)
54
55psm = ""
56args = {}
[895]57action = "/external_clearance_edit_form"
[1032]58if context.isStudent():
59    action = "/clearance_edit_form"
60
[851]61if is_valid:
62    if cpsdocument_edit_button:
[891]63        psm = "Content changed!"
[1054]64        logger.info('"%s","edited clearance of","%s"' % (member_id,student_id ))
[1027]65        if clear_doc.clr_ac_pin == "":
66            res = context.portal_pins(student=member_id)
67            if res:
68                p = res[0].pin
69                if len(p) > 10:
70                    pin = "%s-%s-%s" % (p[:3],p[3:4],p[4:])
71                else:
72                    pin = p
73                clear_doc.edit(mapping={'clr_ac_pin': pin})
[851]74    elif cpsdocument_edit_and_view_button:
[1016]75        if acknowledge and info['review_state'] == "clearance_pin_entered":
76            logger.info('"%s","requested clearance"' % (student_id))
77            info['clear_doc'].edit(mapping = {'request_date': current,})
[893]78            wftool.doActionFor(info['clear'],'close')
79            wftool.doActionFor(info['student'],'request_clearance',dest_container=1)
80            psm = "You successfully requested clearance!"
[895]81            if context.isStudent():
82               action = "/clearance_view"
[1016]83        elif acknowledge and info['review_state'] != "clearance_pin_entered":
[1017]84            logger.info('"%s","repeatedly requested clearance"' % (student_id))
85            psm = "You have already requested clearance!"
[893]86        else:
87            psm = "You must tick the acknowledgement check box before submission!"
[1016]88    elif clear_and_validate_button and info['review_state'] == "clearance_requested":
89        logger.info('"%s","cleared","%s"' % (member_id,student_id ))
[1035]90        #from Products.zdb import set_trace
91        #set_trace()
92        info['clear_doc'].edit(mapping = {'cleared_date': current,})
[885]93        wftool.doActionFor(info['student'],'clear_and_validate')
[891]94        psm = "Clearance and eligibility record is validated and and student is cleared!"
[1016]95    elif clear_and_validate_button and info['review_state'] == "cleared_and_validated":
96        psm = "This student is already cleared!"
[885]97    elif reject_clearance_button:
[1016]98        logger.info('"%s","rejected clearance for","%s"' % (member_id,student_id ))
[885]99        wftool.doActionFor(info['clear'],'open')
100        wftool.doActionFor(info['student'],'reject_clearance')
[891]101        action = "/contact_student_form"
102        psm = "Student's clearance request has been rejected! Please fill and submit the form below!"
[851]103else:
[891]104    psm = "Please correct your errors!"
105    args = getFormUidUrlArg(REQUEST)
106
[851]107args['portal_status_message'] = psm
[891]108url = clear.absolute_url() + action + '?' + urlencode(args)
[845]109REQUEST.RESPONSE.redirect(url)
Note: See TracBrowser for help on using the repository browser.