##parameters=REQUEST, cluster=None, cpsdocument_edit_and_view_button=None, action=None # $Id: external_edit.py 805 2006-11-09 09:38:29Z joachim $ """ Called when a document form is posted. Validates data, then: - if there's no error, updates the object and redirects to it, - if there's an error, puts data in session and redirects to edit form. A form uid is propagated during the redirect to uniquely identify the form in the session. """ from urllib import urlencode from Products.CPSDocument.utils import getFormUidUrlArg # Check flexible controls context.editLayouts(REQUEST=REQUEST) # Validate the document and write it if it's valid # (We don't call getEditableContent here, validate does it when needed.) doc = context.getContent() is_valid, ds = doc.validate(request=REQUEST, proxy=context, cluster=cluster, use_session=True) if action is None: ti = doc.getTypeInfo() action = ti.queryMethodID('edit', 'external_edit_form') action = '/' + action if is_valid: comments = REQUEST.get('comments') context.cpsdocument_notify_modification(comments=comments) if cpsdocument_edit_and_view_button is not None: action = '' psm = 'psm_content_changed' args = {} else: psm = 'psm_content_error' args = getFormUidUrlArg(REQUEST) args['portal_status_message'] = psm url = context.absolute_url() + action + '?' + urlencode(args) REQUEST.RESPONSE.redirect(url)