[Zope-dev] Bug in OFS/Traversable.py
David Alexander Ranvig
davidra@ifi.uio.no
11 Sep 2000 23:34:02 +0200
The unrestrictedTraverse method creates a fake REQUEST "object"
(really a dictionary) and sends this to a __bobo_traverse__. If this
__bobo_traverse__ uses the object properties of the REQUEST object, or
needs the real REQUEST object it will fail.
If __bobo_traverse__ raises an exception while being called from the
unrestrictedTraverse method, which may easily happen if the author of
the __bobo_traverse__ method expected a real REQUEST object,
unrestrictedTraverse just raises the Unauthorized exception. This is
extremely confusing.
I would much appreciate that the _real_ REQUEST object was sent to my
__bobo_traverse__, and that the exception propagated is a little more
informative.
I have worked around this problem like this,
def __bobo_traverse__(self, REQUEST, name):
if type(REQUEST) == type({}):
# do something
else:
# do what I really wanted to do
but would appreciate if the problem did not exist :-)
--
Regards David.