[1860] | 1 | ## Script (Python) "clearance_edit" |
---|
[1107] | 2 | ##bind container=container |
---|
| 3 | ##bind context=context |
---|
| 4 | ##bind namespace= |
---|
| 5 | ##bind script=script |
---|
| 6 | ##bind subpath=traverse_subpath |
---|
| 7 | ##parameters=REQUEST, acknowledge=None |
---|
| 8 | ##title= |
---|
[805] | 9 | # $Id: clearance_edit.py 3746 2008-10-30 10:18:09Z henrik $ |
---|
[788] | 10 | """ |
---|
| 11 | """ |
---|
| 12 | wftool = context.portal_workflow |
---|
| 13 | from urllib import urlencode |
---|
| 14 | from Products.CPSDocument.utils import getFormUidUrlArg |
---|
| 15 | import DateTime |
---|
| 16 | current = DateTime.DateTime() |
---|
[1016] | 17 | import logging |
---|
[1571] | 18 | logger = logging.getLogger('Skins.clearance_edit') |
---|
[1098] | 19 | request = REQUEST |
---|
[788] | 20 | |
---|
[885] | 21 | cpsdocument_edit_button = REQUEST.has_key('cpsdocument_edit_button') |
---|
| 22 | cpsdocument_edit_and_view_button = REQUEST.has_key('cpsdocument_edit_and_view_button') |
---|
| 23 | clear_and_validate_button = REQUEST.has_key('clear_and_validate_button') |
---|
| 24 | reject_clearance_button = REQUEST.has_key('reject_clearance_button') |
---|
[1098] | 25 | result_edit_button = REQUEST.has_key('result_edit_button') |
---|
[893] | 26 | |
---|
[788] | 27 | # Until ajax posts directly to its own script... |
---|
| 28 | ##if 'ajax_edit' in REQUEST.form: |
---|
| 29 | ## return context.cpsdocument_edit_ajax(REQUEST, cluster=cluster) |
---|
| 30 | |
---|
| 31 | # Validate the document and write it if it's valid |
---|
| 32 | # (We don't call getEditableContent here, validate does it when needed.) |
---|
[832] | 33 | wftool = context.portal_workflow |
---|
[1073] | 34 | info = context.getClearanceInfo() |
---|
[788] | 35 | |
---|
[1036] | 36 | #'Sorry, you are not allowed to access this page!' |
---|
| 37 | if info == None: |
---|
[2364] | 38 | return REQUEST.RESPONSE.redirect(context.standard_error_message()) |
---|
[788] | 39 | student = info['student'] |
---|
[1098] | 40 | #app = info['app'] |
---|
| 41 | #app_doc = info['app_doc'] |
---|
[788] | 42 | clear = info['clear'] |
---|
| 43 | clear_doc = info['clear_doc'] |
---|
[1016] | 44 | student_id = info['id'] |
---|
| 45 | member_id = str(context.portal_membership.getAuthenticatedMember()) |
---|
[1098] | 46 | result_widgets = ('fst_sit_results', |
---|
| 47 | 'scd_sit_results', |
---|
| 48 | 'alr_results', |
---|
| 49 | ) |
---|
| 50 | required_scans = ('fst_sit_scan', |
---|
[1217] | 51 | # 'jamb_slip', |
---|
[1101] | 52 | 'ref_let', |
---|
[1098] | 53 | 'acc_let' |
---|
[1860] | 54 | ) |
---|
[3746] | 55 | # start customization |
---|
[2991] | 56 | |
---|
[3746] | 57 | no_scans_required = False |
---|
| 58 | |
---|
| 59 | # end customization |
---|
| 60 | |
---|
[1098] | 61 | form = request.form |
---|
| 62 | psm = "" |
---|
| 63 | args = {} |
---|
| 64 | action = "/external_clearance_edit_form" |
---|
[1860] | 65 | clearance_closed = False |
---|
| 66 | |
---|
[1098] | 67 | if context.isStudent(): |
---|
| 68 | action = "/clearance_edit_form" |
---|
[1860] | 69 | if info['clear_review_state'] == 'closed': |
---|
| 70 | clearance_closed = True |
---|
[832] | 71 | |
---|
[1860] | 72 | if not clearance_closed: |
---|
| 73 | is_valid, ds = clear_doc.validate(request=REQUEST, |
---|
[788] | 74 | schema_id = 'student_clearance', |
---|
[885] | 75 | layout_id = 'student_clearance', |
---|
[788] | 76 | proxy=clear, |
---|
[2373] | 77 | use_session=False) |
---|
[1839] | 78 | if clear_and_validate_button and info['review_state'] == "clearance_requested": |
---|
| 79 | logger.info('%s cleared %s' % (member_id,student_id )) |
---|
| 80 | #from Products.zdb import set_trace |
---|
| 81 | #set_trace() |
---|
[2670] | 82 | clear_doc.edit(mapping = {'cleared_date': current,}) |
---|
[1839] | 83 | wftool.doActionFor(info['student'],'clear_and_validate') |
---|
[2672] | 84 | |
---|
| 85 | |
---|
| 86 | if clear_doc.firstname and clear_doc.lastname: |
---|
| 87 | if info['per_review_state'] != 'opened': |
---|
| 88 | wftool.doActionFor(info['per'],'open') |
---|
| 89 | per_doc = info['per'].getContent() |
---|
[2676] | 90 | firstname = clear_doc.firstname.replace('-',' - ') |
---|
| 91 | firstname = ' '.join([m.capitalize() for m in firstname.split()]) |
---|
[2696] | 92 | firstname = firstname.replace(' - ','-') |
---|
[2676] | 93 | middlename = clear_doc.middlename.replace('-',' - ') |
---|
| 94 | middlename = ' '.join([m.capitalize() for m in middlename.split()]) |
---|
[2696] | 95 | middlename = middlename.replace(' - ','-') |
---|
[2676] | 96 | lastname = clear_doc.lastname.replace('-',' - ') |
---|
| 97 | lastname = ' '.join([m.capitalize() for m in lastname.split()]) |
---|
[2696] | 98 | lastname = lastname.replace(' - ','-') |
---|
| 99 | # we changed |
---|
| 100 | context.waeup_tool.updateRoleMappingsFor('waeup_student_subobject_wf',info['per']) |
---|
[2676] | 101 | per_doc.edit(mapping = {'firstname': firstname, 'middlename': middlename, 'lastname': lastname,}) |
---|
[2672] | 102 | |
---|
[2013] | 103 | psm = "Clearance and eligibility record is validated and student is cleared!" |
---|
[1839] | 104 | elif clear_and_validate_button and info['review_state'] == "cleared_and_validated": |
---|
| 105 | psm = "This student is already cleared!" |
---|
| 106 | elif reject_clearance_button: |
---|
| 107 | logger.info('%s rejected clearance for %s' % (member_id,student_id )) |
---|
[2491] | 108 | try: |
---|
| 109 | wftool.doActionFor(info['clear'],'open') |
---|
| 110 | except: |
---|
| 111 | return |
---|
[1839] | 112 | wftool.doActionFor(info['student'],'reject_clearance') |
---|
| 113 | action = "/external_contact_student_form" |
---|
| 114 | psm = "Student's clearance request has been rejected! Please fill and submit the form below!" |
---|
| 115 | subject = "Clearance request rejected" |
---|
| 116 | args['subject'] = subject |
---|
| 117 | args['continue'] = 'external_clearance_edit_form' |
---|
[1860] | 118 | elif clearance_closed: |
---|
| 119 | action = "/clearance_view" |
---|
[1862] | 120 | logger.info('%s tried to edit closed clearance object of %s' % (member_id,student_id )) |
---|
[1839] | 121 | elif is_valid: |
---|
[1098] | 122 | if cpsdocument_edit_button or result_edit_button: |
---|
[891] | 123 | psm = "Content changed!" |
---|
[1996] | 124 | logger.info('%s edited clearance object of %s' % (member_id,student_id )) |
---|
[851] | 125 | elif cpsdocument_edit_and_view_button: |
---|
[1016] | 126 | if acknowledge and info['review_state'] == "clearance_pin_entered": |
---|
[2364] | 127 | files = context.waeup_tool.picturesList() |
---|
[2991] | 128 | req_found = [scan for scan in required_scans if scan in files] or no_scans_required |
---|
| 129 | birth_found = "age_dec" in files or "birth_certificate" in files or no_scans_required |
---|
[2673] | 130 | if not req_found or not birth_found: |
---|
| 131 | logger.info('%s requested clearance with documents missing' % (student_id)) |
---|
| 132 | psm = "You have not uploaded all necessary documents to request clearance!" |
---|
| 133 | elif not clear_doc.firstname or not clear_doc.lastname: |
---|
[2670] | 134 | logger.info('%s requested clearance without confirming name' % (student_id)) |
---|
[2672] | 135 | psm = "Please fill the name fields! First and last name are required. " |
---|
[1098] | 136 | else: |
---|
[1571] | 137 | logger.info('%s requested clearance' % (student_id)) |
---|
[2670] | 138 | clear_doc.edit(mapping = {'request_date': current,}) |
---|
[1098] | 139 | wftool.doActionFor(info['clear'],'close') |
---|
| 140 | wftool.doActionFor(info['student'],'request_clearance',dest_container=1) |
---|
| 141 | psm = "You successfully requested clearance!" |
---|
| 142 | if context.isStudent(): |
---|
| 143 | action = "/clearance_view" |
---|
[1016] | 144 | elif acknowledge and info['review_state'] != "clearance_pin_entered": |
---|
[1571] | 145 | logger.info('%s repeatedly requested clearance' % (student_id)) |
---|
[1017] | 146 | psm = "You have already requested clearance!" |
---|
[893] | 147 | else: |
---|
| 148 | psm = "You must tick the acknowledgement check box before submission!" |
---|
[851] | 149 | else: |
---|
[891] | 150 | psm = "Please correct your errors!" |
---|
| 151 | args = getFormUidUrlArg(REQUEST) |
---|
[1996] | 152 | logger.info('%s got error when editing the clearance object of %s' % (member_id,student_id)) |
---|
[891] | 153 | |
---|
[851] | 154 | args['portal_status_message'] = psm |
---|
[891] | 155 | url = clear.absolute_url() + action + '?' + urlencode(args) |
---|
[1575] | 156 | return REQUEST.RESPONSE.redirect(url) |
---|
[1106] | 157 | |
---|