No longer need to rely on Acquisition to get to stuff (and to validate security),

so let's simply reuse Zope3's ViewPageTemplateFIle
parent fc3930c9
...@@ -15,79 +15,25 @@ ...@@ -15,79 +15,25 @@
$Id$ $Id$
""" """
import os, sys import zope.app.pagetemplate
from Acquisition import aq_inner, aq_acquire
from Globals import package_home
from Products.PageTemplates.PageTemplateFile import PageTemplateFile
from Products.PageTemplates.Expressions import SecureModuleImporter from Products.PageTemplates.Expressions import SecureModuleImporter
from Products.PageTemplates.Expressions import createTrustedZopeEngine from Products.PageTemplates.Expressions import createTrustedZopeEngine
from zope.app.pagetemplate.viewpagetemplatefile import ViewMapper
_engine = createTrustedZopeEngine() _engine = createTrustedZopeEngine()
def getEngine(): def getEngine():
return _engine return _engine
class ZopeTwoPageTemplateFile(PageTemplateFile): class ViewPageTemplateFile(zope.app.pagetemplate.ViewPageTemplateFile):
"""A strange hybrid between Zope 2 and Zope 3 page template.
Uses Zope 2's engine, but with security disabled and with some
initialization and API from Zope 3.
"""
def __init__(self, filename, _prefix=None, content_type=None):
# XXX doesn't use content_type yet
self.ZBindings_edit(self._default_bindings)
path = self.get_path_from_prefix(_prefix)
self.filename = os.path.join(path, filename)
if not os.path.isfile(self.filename):
raise ValueError("No such file", self.filename)
basepath, ext = os.path.splitext(self.filename)
self.__name__ = os.path.basename(basepath)
super(PageTemplateFile, self).__init__(self.filename, _prefix)
def get_path_from_prefix(self, _prefix):
if isinstance(_prefix, str):
path = _prefix
else:
if _prefix is None:
_prefix = sys._getframe(2).f_globals
path = package_home(_prefix)
return path
def pt_getEngine(self): def pt_getEngine(self):
return getEngine() return getEngine()
def pt_getContext(self): def pt_getContext(self, instance, request, **kw):
try: context = super(ViewPageTemplateFile, self).pt_getContext(
root = aq_acquire(self.context, 'getPhysicalRoot')() instance, request, **kw)
except AttributeError: context['modules'] = SecureModuleImporter
root = None context['options'] = ''
view = self._getContext() return context
here = aq_inner(self.context)
try:
request = aq_acquire(root, 'REQUEST')
except AttributeError:
request = None
c = {'template': self,
'here': here,
'context': here,
'container': here,
'nothing': None,
'options': {},
'root': root,
'request': request,
'modules': SecureModuleImporter,
}
if view is not None:
c['view'] = view
c['views'] = ViewMapper(here, request)
return c
ViewPageTemplateFile = ZopeTwoPageTemplateFile # BBB
ZopeTwoPageTemplateFile = ViewPageTemplateFile
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