--- ECHO_content/ECHO_helpers.py 2004/12/10 19:33:09 1.32 +++ ECHO_content/ECHO_helpers.py 2005/01/19 19:38:55 1.34 @@ -4,7 +4,7 @@ import socket import urllib import string import xml.dom.minidom -from types import * +import types from Products.PageTemplates.PageTemplateFile import PageTemplateFile from OFS.SimpleItem import SimpleItem from Globals import package_home @@ -310,7 +310,7 @@ class ECHO_basis: def toList(field): """Einzelfeld in Liste umwandeln""" - if type(field)==StringType: + if type(field)==types.StringType: return [field] else: return field @@ -383,7 +383,7 @@ def checkOnlyOneInGroup(object): return displayedObjects[0][1] else: return object -def getSubCols(self,sortfield="weight",subColTypes= displayTypes,sortFieldMD=None): +def getSubCols(self, sortfield="weight", subColTypes=displayTypes, sortFieldMD=None): def sortfnc(sortfield,x,y): xa=x[1].getMDValue(sortfield) @@ -580,23 +580,46 @@ def checkDiffs(self,metadict): return diffs -def zptFile(self, path): +def zptFile(self, path, orphaned=False): """returns a page template file from the product""" - pt=PageTemplateFile(os.path.join(package_home(globals()), path)).__of__(self) + if orphaned: + # unusual case + pt=PageTemplateFile(os.path.join(package_home(globals()), path)) + else: + pt=PageTemplateFile(os.path.join(package_home(globals()), path)).__of__(self) return pt -def sendFile(self, filename, type): - """sends an object or a local file (in the product) as response""" +def findObjectPath(startobject, filename): + """returns the object with the name filename starting at startobject""" + if startobject is None: + return None paths = filename.split('/') - object = self - # look for an object called filename + object = startobject for path in paths: if hasattr(object, path): object = getattr(object, path) else: object = None break + return object + + +def zptObjectOrFile(self, filename, localdir='zpt', orphaned=False): + """returns a page template instance or a file from the product""" + # look for an object called path + pt = findObjectPath(self, filename) + # the object should also not be a python function + if (pt is None) or isinstance(pt, types.FunctionType): + # get a ZPT file + pt = zptFile(self, localdir+'/'+filename, orphaned=orphaned) + return pt + + +def sendFile(self, filename, type): + """sends an object or a local file (in the product) as response""" + # look for an object called filename + object = findObjectPath(self, filename) if object: # if the object exists then send it return object.index_html(self.REQUEST.REQUEST, self.REQUEST.RESPONSE)