Commit 08717426 authored by Hanno Schlichting's avatar Hanno Schlichting

Added PubStart, PubBeforeCommit and PubAfterTraversal events to the WSGI publisher.

parent 088ad442
...@@ -8,6 +8,9 @@ http://docs.zope.org/zope2/releases/. ...@@ -8,6 +8,9 @@ http://docs.zope.org/zope2/releases/.
2.13.14 (unreleased) 2.13.14 (unreleased)
-------------------- --------------------
- Added PubStart, PubBeforeCommit and PubAfterTraversal events to the
WSGI publisher.
- ZPublisher: Fixed a traversal regression introduced in 2.13.12. - ZPublisher: Fixed a traversal regression introduced in 2.13.12.
- Updated distributions: - Updated distributions:
......
...@@ -30,6 +30,7 @@ from ZPublisher.Publish import call_object ...@@ -30,6 +30,7 @@ from ZPublisher.Publish import call_object
from ZPublisher.Publish import dont_publish_class from ZPublisher.Publish import dont_publish_class
from ZPublisher.Publish import get_module_info from ZPublisher.Publish import get_module_info
from ZPublisher.Publish import missing_name from ZPublisher.Publish import missing_name
from ZPublisher.pubevents import PubStart, PubBeforeCommit, PubAfterTraversal
from ZPublisher.Iterators import IStreamIterator from ZPublisher.Iterators import IStreamIterator
_NOW = None # overwrite for testing _NOW = None # overwrite for testing
...@@ -149,6 +150,7 @@ class WSGIResponse(HTTPResponse): ...@@ -149,6 +150,7 @@ class WSGIResponse(HTTPResponse):
# return '' # return ''
raise NotImplementedError raise NotImplementedError
def publish(request, module_name, def publish(request, module_name,
_get_module_info=get_module_info, # only for testing _get_module_info=get_module_info, # only for testing
): ):
...@@ -160,8 +162,9 @@ def publish(request, module_name, ...@@ -160,8 +162,9 @@ def publish(request, module_name,
err_hook, err_hook,
validated_hook, validated_hook,
transactions_manager, transactions_manager,
)= _get_module_info(module_name) ) = _get_module_info(module_name)
notify(PubStart(request))
request.processInputs() request.processInputs()
response = request.response response = request.response
...@@ -181,8 +184,9 @@ def publish(request, module_name, ...@@ -181,8 +184,9 @@ def publish(request, module_name,
# According to RFC1738 a trailing space in the path is valid. # According to RFC1738 a trailing space in the path is valid.
path = request.get('PATH_INFO') path = request.get('PATH_INFO')
request['PARENTS'] = parents = [object] request['PARENTS'] = [object]
object = request.traverse(path, validated_hook=validated_hook) object = request.traverse(path, validated_hook=validated_hook)
notify(PubAfterTraversal(request))
if transactions_manager: if transactions_manager:
transactions_manager.recordMetaData(object, request) transactions_manager.recordMetaData(object, request)
...@@ -201,8 +205,10 @@ def publish(request, module_name, ...@@ -201,8 +205,10 @@ def publish(request, module_name,
if result is not response: if result is not response:
response.setBody(result) response.setBody(result)
notify(PubBeforeCommit(request))
return response return response
class _RequestCloserForTransaction(object): class _RequestCloserForTransaction(object):
"""Unconditionally close the request at the end of a transaction. """Unconditionally close the request at the end of a transaction.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment