[859] | 1 | ##parameters=REQUEST, cluster=None, cpsdocument_edit_and_view_button=None, came_from=None |
---|
| 2 | # $Id: external_edit.py 805 2006-11-09 09:38:29Z joachim $ |
---|
| 3 | """ |
---|
| 4 | Called when a document form is posted. |
---|
| 5 | |
---|
| 6 | Validates data, then: |
---|
| 7 | |
---|
| 8 | - if there's no error, updates the object and redirects to it, |
---|
| 9 | |
---|
| 10 | - if there's an error, puts data in session and redirects to edit form. |
---|
| 11 | |
---|
| 12 | A form uid is propagated during the redirect to uniquely identify the |
---|
| 13 | form in the session. |
---|
| 14 | """ |
---|
| 15 | |
---|
| 16 | from urllib import urlencode |
---|
| 17 | from Products.CPSDocument.utils import getFormUidUrlArg |
---|
| 18 | |
---|
[1571] | 19 | import logging |
---|
| 20 | logger = logging.getLogger('Skins.waeup_edit') |
---|
| 21 | |
---|
| 22 | mtool = context.portal_membership |
---|
| 23 | member = mtool.getAuthenticatedMember() |
---|
| 24 | |
---|
[859] | 25 | # Check flexible controls |
---|
| 26 | #context.editLayouts(REQUEST=REQUEST) |
---|
| 27 | |
---|
| 28 | # Validate the document and write it if it's valid |
---|
| 29 | # (We don't call getEditableContent here, validate does it when needed.) |
---|
| 30 | doc = context.getContent() |
---|
[1025] | 31 | if context.portal_type == "StudentStudyCourse": |
---|
| 32 | if len(context.objectIds()) > 0: |
---|
[1571] | 33 | psm = 'Edit of StudentStudyCourse is only possible if there are no levels inside!' |
---|
[1025] | 34 | args = getFormUidUrlArg(REQUEST) |
---|
| 35 | args['portal_status_message'] = psm |
---|
| 36 | url = context.absolute_url() + '?' + urlencode(args) |
---|
| 37 | REQUEST.RESPONSE.redirect(url) |
---|
[1435] | 38 | |
---|
[859] | 39 | is_valid, ds = doc.validate(request=REQUEST, proxy=context, cluster=cluster, |
---|
| 40 | use_session=True) |
---|
| 41 | |
---|
[1840] | 42 | student_id = context.getStudentId() |
---|
| 43 | |
---|
[859] | 44 | ##if action is None: |
---|
| 45 | ## ti = doc.getTypeInfo() |
---|
| 46 | ## action = ti.queryMethodID('edit', 'external_edit_form') |
---|
| 47 | ## action = '/' + action |
---|
| 48 | |
---|
| 49 | action = "/" + came_from |
---|
| 50 | if is_valid: |
---|
| 51 | comments = REQUEST.get('comments') |
---|
| 52 | context.cpsdocument_notify_modification(comments=comments) |
---|
[1744] | 53 | if False: |
---|
| 54 | if context.portal_type == "StudentStudyCourse": |
---|
| 55 | course = ds.get('study_course') |
---|
[1025] | 56 | student_id = context.getStudentId() |
---|
[1744] | 57 | res = context.portal_catalog(portal_type='Certificate',id = course) |
---|
| 58 | if res: |
---|
| 59 | c_brain = res[0] |
---|
| 60 | c_path = c_brain.getPath().split('/') |
---|
| 61 | student_id = context.getStudentId() |
---|
| 62 | context.students_catalog.modifyRecord(id = student_id, |
---|
| 63 | course = course, |
---|
| 64 | level = ds.get('current_level'), |
---|
| 65 | verdict = ds.get('current_verdict'), |
---|
| 66 | faculty = c_path[-4], |
---|
| 67 | department = c_path[-3], |
---|
| 68 | ) |
---|
| 69 | logger.info('%s edited %s (%s) of %s' % (member,context.id,course,student_id)) |
---|
[1840] | 70 | |
---|
[1744] | 71 | elif context.portal_type == "StudentApplication": # disabled |
---|
| 72 | entry_mode = ds.get('entry_mode') |
---|
| 73 | student_id = context.getStudentId() |
---|
[1025] | 74 | context.students_catalog.modifyRecord(id = student_id, |
---|
[1744] | 75 | entry_mode = entry_mode, |
---|
| 76 | ) |
---|
| 77 | logger.info('%s edited %s of %s' % (member,context.id,student_id)) |
---|
| 78 | elif context.portal_type == "StudentClearance": |
---|
| 79 | matric_no = ds.get('matric_no') |
---|
| 80 | student_id = context.getStudentId() |
---|
| 81 | context.students_catalog.modifyRecord(id = student_id, |
---|
| 82 | matric_no = matric_no, |
---|
| 83 | ) |
---|
[1840] | 84 | logger.info('%s edited %s of %s' % (member,context.id,student_id)) |
---|
[1744] | 85 | elif context.portal_type in ("StudentPersonal",): |
---|
| 86 | name = "%(firstname)s %(middlename)s %(lastname)s" % ds |
---|
| 87 | name = name.strip() |
---|
| 88 | name = name.replace(' ',' ') |
---|
| 89 | email = ds.get('email') |
---|
| 90 | phone = ds.get('phone') |
---|
| 91 | student_id = context.getStudentId() |
---|
| 92 | #app_doc = context.application.getContent() |
---|
| 93 | #jamb_sex = 'M' |
---|
| 94 | #if ds.get('sex'): |
---|
| 95 | # jamb_sex = 'F' |
---|
| 96 | # originally imported data must be kept; app_doc should not be changed here |
---|
| 97 | #app_doc.edit(mapping={'jamb_lastname': name, |
---|
| 98 | # 'jamb_sex': jamb_sex |
---|
| 99 | # }) |
---|
| 100 | context.students_catalog.modifyRecord(id = student_id, |
---|
| 101 | name = name, |
---|
| 102 | email = email, |
---|
| 103 | phone = phone, |
---|
| 104 | sex = ds.get('sex'), |
---|
| 105 | ) |
---|
| 106 | logger.info('%s edited %s of %s' % (member,context.id,student_id)) |
---|
| 107 | elif context.portal_type == "xxxxCourse": # disabled handled by events |
---|
| 108 | dd = {} |
---|
| 109 | dd.update(ds) # ds is not a real dictionary |
---|
| 110 | try: |
---|
| 111 | context.courses_catalog.modifyRecord(**dd) |
---|
| 112 | except KeyError: |
---|
| 113 | context.courses_catalog.addRecord(**dd) |
---|
[859] | 114 | if cpsdocument_edit_and_view_button is not None: |
---|
| 115 | action = '' |
---|
| 116 | psm = 'psm_content_changed' |
---|
| 117 | args = {} |
---|
| 118 | else: |
---|
| 119 | psm = 'psm_content_error' |
---|
| 120 | args = getFormUidUrlArg(REQUEST) |
---|
| 121 | |
---|
[1840] | 122 | logger.info('%s edited %s of %s' % (member,context.id,student_id)) |
---|
[859] | 123 | args['portal_status_message'] = psm |
---|
| 124 | url = context.absolute_url() + action + '?' + urlencode(args) |
---|
| 125 | REQUEST.RESPONSE.redirect(url) |
---|
| 126 | |
---|