[798] | 1 | ##parameters=REQUEST |
---|
[805] | 2 | # $Id: start_clearance.py 1021 2006-12-09 13:24:47Z joachim $ |
---|
[798] | 3 | """ |
---|
| 4 | request Clearance |
---|
| 5 | """ |
---|
| 6 | import DateTime |
---|
| 7 | current = DateTime.DateTime() |
---|
| 8 | pr = context.portal_registration |
---|
[1016] | 9 | import logging |
---|
| 10 | logger = logging.getLogger('Student.Clearance.Start') |
---|
[798] | 11 | |
---|
| 12 | type_name = 'Student' |
---|
| 13 | ti = context.portal_types[type_name] |
---|
| 14 | REQUEST.set('type_name',type_name) |
---|
| 15 | redirect = REQUEST.RESPONSE.redirect |
---|
| 16 | wf = context.portal_workflow |
---|
| 17 | validate = REQUEST.has_key("cpsdocument_create_button") |
---|
| 18 | |
---|
| 19 | lt = context.portal_layouts |
---|
| 20 | pr = context.portal_registration |
---|
| 21 | |
---|
[1016] | 22 | info = context.getStudentInfo() |
---|
| 23 | app_doc = info['app_doc'] |
---|
| 24 | review_state = info['review_state'] |
---|
| 25 | |
---|
[798] | 26 | res,psm,ds = lt.renderLayout(layout_id='student_clearance', |
---|
| 27 | schema_id= 'student_clearance', |
---|
| 28 | context=context, |
---|
| 29 | mapping=validate and REQUEST, |
---|
| 30 | ob={}, |
---|
| 31 | layout_mode='create', |
---|
| 32 | formaction = "start_clearance", |
---|
| 33 | button = "Start", |
---|
| 34 | ) |
---|
[1016] | 35 | if psm == '': |
---|
[798] | 36 | return context.clearance_pin_form(rendered = res, |
---|
[1016] | 37 | psm = None, |
---|
[798] | 38 | firstlayout = True, |
---|
| 39 | lastlayout = True, |
---|
| 40 | ds = ds, |
---|
| 41 | ) |
---|
[1016] | 42 | error = False |
---|
| 43 | if app_doc.passport is None: |
---|
| 44 | psm = "You must upload your passport picture before you can start the registration process!" |
---|
| 45 | error = True |
---|
| 46 | elif review_state == "clearance_pin_entered": |
---|
| 47 | psm = "You have already entered a clearance pin" |
---|
| 48 | error = True |
---|
| 49 | elif psm == 'invalid': |
---|
[1021] | 50 | psm = "Please correct your input!" |
---|
[1016] | 51 | error = True |
---|
| 52 | if error: |
---|
[798] | 53 | return context.clearance_pin_form(rendered = res, |
---|
[1016] | 54 | psm = psm, |
---|
[798] | 55 | firstlayout = True, |
---|
| 56 | lastlayout = True, |
---|
| 57 | ds = ds, |
---|
| 58 | ) |
---|
[1016] | 59 | pin = str(ds.get('clr_ac_pin')) |
---|
[1017] | 60 | logger.info('"%s", "entered clearance pin", "%s"' % (info['id'],pin)) |
---|
[1016] | 61 | wf.doActionFor(info['student'],'enter_clearance_pin') |
---|
| 62 | wf.doActionFor(info['clear'],'open') |
---|
| 63 | dc = {} |
---|
| 64 | app_doc = info['app_doc'] |
---|
| 65 | dc['lga_ident'] = app_doc.get('jamb_lga') |
---|
[1017] | 66 | dc['lga'] = app_doc.get('jamb_state','no state') + ' / ' + app_doc.get('jamb_lga','no lga') |
---|
[1016] | 67 | dc['clr_ac_date'] = current |
---|
| 68 | dc['entry_date'] = current |
---|
| 69 | dc['entry_session'] = "2006/2007" |
---|
| 70 | wf.doActionFor(info['app'],'close') |
---|
| 71 | info['clear_doc'].edit(mapping = dc) |
---|
[798] | 72 | return redirect("%s/clearance_edit_form" % info['clear'].absolute_url()) |
---|