[BlueBream] Strange effect with @@view calling
Dr. Volker Jaenisch
volker.jaenisch at inqbus.de
Tue Mar 30 21:02:07 EDT 2010
Hello BlueBream List!
I am new to Bluebream but I programmed in Python/Plone/Zope/
for some years. Thank you a lot for bringing up Zope3 to live again!
Currently I got a strange effect calling a view in my bluebream project.
A) If I call it like this http://../engine/index
it works without problems .
B) If I call it like this http://../engine/@@index
I got a stacktrace which ends in a forbiddenAttribute error.
The view itself is trivial:
class BookingEngineDefaultView(BrowserView):
"""Default view for a booking engine"""
def update(self):
import pdb; pdb.set_trace()
Suppose the following Model
zope-root -> engine -> Product
where Product has an attribute "name".
The view just uses a pagetemplate that does:
<li tal:repeat="products context/values">
<a tal:attributes="href products/@@absolute_url"
tal:content="python:products.name">Name</a>
In Case B) the following stacktrace results:
*Line 10, Column 6*
*In expression: <PythonExpr (products.name)>*
- Names:
{'args': (),
'context': <inqbus.booking.engine.app.BookingEngine object at 0xa43ca2c>,
'default': <object object at 0xb7547680>,
'loop': {},
'nothing': None,
'options': {},
'repeat': {},
'request': <zope.publisher.browser.BrowserRequest instance URL=http://127.0.0.1:8080/++skin++Booking/engine/@@index>,
'template': <z3c.ptcompat.ViewPageTemplateFile object at 0xa2bd96c>,
'view': <z3c.pagelet.zcml.BookingEngineDefaultView object at 0xa550d2c>,
'views': <zope.browserpage.viewpagetemplatefile.ViewMapper object at 0xa5c306c>}
Module zope.tales.tales:*696* in |evaluate|
<http://127.0.0.1:8080/++skin++Booking/engine/@@index#>
|<< <http://127.0.0.1:8080/++skin++Booking/engine/@@index#>
__traceback_supplement__ = (
TALESTracebackSupplement, self, expression)
return expression(self)
evaluateValue = evaluate||>>
<http://127.0.0.1:8080/++skin++Booking/engine/@@index#>*return*
expression*(*self*)*|
(products.name)
Module zope.tales.pythonexpr:*59* in |__call__|
<http://127.0.0.1:8080/++skin++Booking/engine/@@index#>
|<< <http://127.0.0.1:8080/++skin++Booking/engine/@@index#>
__traceback_info__ = self.text
vars = self._bind_used_names(econtext, __builtins__)
return eval(self._code, vars)
def __str__(self):||>>
<http://127.0.0.1:8080/++skin++Booking/engine/@@index#>*return*
eval*(*self*.*_code*,* vars*)*|
Module ?:*1* in |<module>|
<http://127.0.0.1:8080/++skin++Booking/engine/@@index#>
*ForbiddenAttribute: ('name', <inqbus.booking.classes.product.Product
object at 0xa35c5cc>)*
I am wondering:
* Why do the similiar URLs that lead to the same view (prooved by pdb)
with the same principal (zope.Manager, prooved by pdb) lead to different
results.
* How could it be, that a forbiddenAttribute error is raised if I work
as Zope.Manager that has
a grantAll Permission.
The effect is independed of the type of the view. I tried pagelet-Style
and BrowserView-Style with the some
outcome.
My guess is, that the B) URL results in a more paranoid security
checking than the A) URL.
But if this is the case, is this behavior the correct one?
Any hints welcome. In the appendix you find the relevant ZCML
Best Regards
Volker
<!-- booking engine default view -->
<browser:defaultView
for="..interfaces.IBookingEngine"
name="index"
layer=".layer.IBookingBrowserLayer"
/>
<!-- booking engine default view -->
<z3c:pagelet
for="..interfaces.IBookingEngine"
name="index"
permission="zope.ManageContent"
layer=".layer.IBookingBrowserLayer"
class=".views.BookingEngineDefaultView"
/>
<!-- template for booking engine default view -->
<z3c:template
template="frontpage.pt"
for=".views.BookingEngineDefaultView"
layer=".layer.IBookingBrowserLayer"
/>
<!-- menu item for booking engine default view -->
<browser:viewlet
name="View booking engine"
viewURL="@@index"
for="zope.app.component.interfaces.ISite"
manager=".skin.INavigationMenu"
class="z3c.menu.simple.menu.GlobalMenuItem"
layer=".layer.IBookingBrowserLayer"
permission="zope.ManageContent"
weight="1"
/>
--
====================================================
inqbus it-consulting +49 ( 341 ) 5643800
Dr. Volker Jaenisch http://www.inqbus.de
Herloßsohnstr. 12 0 4 1 5 5 Leipzig
N O T - F Ä L L E +49 ( 170 ) 3113748
====================================================
More information about the bluebream
mailing list