version 1.6, 2004/12/23 16:31:22
|
version 1.18, 2005/04/06 09:18:41
|
Line 9 from OFS.Folder import Folder
|
Line 9 from OFS.Folder import Folder
|
from OFS.SimpleItem import SimpleItem |
from OFS.SimpleItem import SimpleItem |
from Globals import InitializeClass,package_home |
from Globals import InitializeClass,package_home |
import zLOG |
import zLOG |
|
import base64 |
|
import bz2 |
import os |
import os |
import os.path |
import os.path |
import stat |
import stat |
import xml.dom.minidom |
import xml.dom.minidom |
from types import * |
from types import * |
|
import xmlrpclib |
|
from OSAS_helpers import * |
|
|
|
def decodeRPC(string): |
|
return bz2.decompress(base64.decodestring(string)) |
|
|
|
|
class OSAS_storeOnline(SimpleItem): |
class OSAS_storeOnline(SimpleItem): |
"""Webfrontend für das Storagesystem |
"""Webfrontend für das Storagesystem |
Line 26 class OSAS_storeOnline(SimpleItem):
|
Line 34 class OSAS_storeOnline(SimpleItem):
|
_v_fileSystem={} #chache fuer filesystem |
_v_fileSystem={} #chache fuer filesystem |
_v_metaFiles={} #chache fuer indexMeta |
_v_metaFiles={} #chache fuer indexMeta |
|
|
def __init__(self,id): |
def getParentType(self,path): |
"""initialize a new instance""" |
"""getFileType des parentordners""" |
self.id = id |
|
|
|
|
realPath=os.path.split(path)[0] |
|
|
|
objects=self.readObjectsFromPath(realPath) |
|
|
security.declareProtected('View','index_html') |
try: |
def index_html(self): |
return objects[os.path.join(realPath,".")][0] |
"""main view either standard template zpt/storeOnline_index_html.zpt or storeOnline_index.html in tree""" |
except: |
if hasattr(self,'storeOnline_index.html'): |
return "" |
return getattr(self,'storeOnline_index.html')() |
def getHandlersOfPath(self): |
|
"""handler des actullen path""" |
|
path=self.REQUEST['path'] |
|
objects=self.readObjectsFromPath(path) |
|
|
|
typeObject=objects.get(os.path.join(path,"."),None) |
|
if not typeObject: |
|
return("",[],"") |
|
type=typeObject[0] |
|
|
|
handler=self.giveHandlers(path,type) |
|
|
|
|
|
return (os.path.split(path)[1],handler,objects[os.path.join(path,".")][1],type) |
|
|
|
|
|
def getMetaFile(self,path): |
|
"""get index.meta and translate it to HTML""" |
|
"""Lies Metafile ein |
|
@param path: Pfad des index.met |
|
@return: index.meta file |
|
""" |
|
html=[] |
|
server=xmlrpclib.Server(self.serverUrl) |
|
|
|
|
|
f=server.getFile(path+"/index.meta") |
|
|
|
if not f: |
|
|
|
return self.getMetaInfoFromIndexMeta(path) |
|
#return "NO_METADATA" |
else: |
else: |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','storeOnline_index_html.zpt')).__of__(self) |
|
return pt() |
|
|
|
|
dom = xml.dom.minidom.parseString(f) |
|
|
def findIndexMeta(self,path=""): |
try: |
"""finde index_meta fuer diesen eventuell virtuellen Pfad |
name=getText(dom.getElementsByTagName("name")[0].childNodes) |
@param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName |
except: |
@return: None falls kein index.meta existiert sonst Pfad auf das index.meta |
name="NOT_DEFINED!!!" |
|
try: |
|
creator=getText(dom.getElementsByTagName("creator")[0].childNodes) |
|
except: |
|
creator="NOT_DEFINED!!!" |
|
|
|
try: |
|
creation_date=getText(dom.getElementsByTagName("archive-creation-date")[0].childNodes) |
|
except: |
|
creation_date="NOT_DEFINED!!!" |
|
|
|
try: |
|
description=getText(dom.getElementsByTagName("description")[0].childNodes) |
|
except: |
|
description="NOT_DEFINED!!!" |
|
|
|
try: |
|
type=getText(dom.getElementsByTagName("content-type")[0].childNodes) |
|
except: |
|
type="" |
|
if type=="scanned document": |
|
html="<h3>Document: "+name+"</h3>" |
|
elif type=="folder": |
|
html="<h3>Folder: "+name+"</h3>" |
|
else: |
|
html="<h3>Document: "+name+"</h3>" |
|
|
|
html=html+"<p><i>created by: "+creator+" at: "+creation_date+"</i></p>" |
|
html=html+"<h4>Description</h4><p>"+description+"</p>" |
|
try: |
|
bib = dom.getElementsByTagName("meta")[0].getElementsByTagName("bib")[0] |
|
if bib.attributes.has_key('type'): |
|
html=html+"<h4>Info ("+bib.attributes['type'].value+")</h4>" |
|
else: |
|
html=html+"<h4>Info</h4>" |
|
html=html+getBib(bib.childNodes) |
|
|
|
except: |
|
"""none""" |
|
|
|
# html=html.encode('utf-8','replace')+getBib(bib.childNodes).encode('utf-8','replace') |
|
|
|
return html |
|
|
|
|
|
def getMetaInfoFromIndexMeta(self,path): |
|
"""metadaten zu path als html aus dem index.meta file zu path (meta tag im file bzw. dir container) |
|
@param path: Pfad auf das Object relativ zum rootFolderName |
|
@return: metadata als html |
""" |
""" |
realPath=os.path.normpath(os.path.join(self.rootFolderName,path)) |
|
#suche index.meta |
xmlInfos=self.findEntryInIndexMeta(path) |
while (not os.path.exists(os.path.join(realPath,'index.meta'))) and (not ((realPath=="") or (realPath=="/"))): |
|
realPath=os.path.split(realPath)[0] |
if xmlInfos: |
if realPath=='' or realPath=='/': |
return OSAS_helpers.getMetaInfoFromXML(path,xmlInfos) |
return None |
|
else: |
else: |
return os.path.join(realPath,'index.meta') |
return "" |
|
|
def findEntryInIndexMeta(self,path): |
def findEntryInIndexMeta(self,path): |
"""fragm xml zum path |
"""Finde im naechstgelegenden index.meta relativ zu path den entprechenden Eintrag fuer diesen Pfad. |
@param path: Pfad auf das Object relativ zum rootFolderName |
@param path: Pfad auf das Object relativ zum rootFolderName |
@return: den Teil von Index.meta der Informationen zu path enthaelt, None wenn error. |
@return: den Teil von Index.meta der Informationen zu path enthaelt, None wenn error. |
""" |
""" |
|
|
indexMeta=self.findIndexMeta(path) |
server=xmlrpclib.Server(self.serverUrl) |
|
indexMeta=server.findIndexMeta(path) # suche index.meta |
|
|
if not indexMeta: |
if not indexMeta: |
return None |
return None |
|
|
realPath=os.path.split(indexMeta)[0] |
realPath=os.path.split(indexMeta)[0] |
path=os.path.normpath(os.path.join(self.rootFolderName,path)) |
path=os.path.normpath(path) |
|
|
dom=xml.dom.minidom.parse(indexMeta) |
try: |
|
|
#ist path ein directory? |
dom=xml.dom.minidom.parseString(server.getFile(indexMeta)) |
dirs=dom.getElementsByTagName('dir') |
except: |
for dir in dirs: |
zLOG.LOG("OSAS_browser (findEntryInIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta) |
pathes=dir.getElementsByTagName('path') |
return None |
if pathes: |
|
pathX=OSAS_helpers.getText(pathes[0].childNodes) |
path=path.replace(realPath,'') |
else: |
(searchPath,name)=os.path.split(path) |
pathX="" |
if (len(searchPath)>0) and (searchPath[0]=="/"): |
names=dir.getElementsByTagName('name') |
if len(searchPath)<=1: |
if names: |
searchPath="" |
name=OSAS_helpers.getText(names[0].childNodes) |
|
else: |
else: |
name="" |
searchPath=searchPath[1:] |
|
#ist path ein directory? |
|
xpath="/resource/dir[name='%s' and path='%s']"%(name,searchPath) |
|
|
checkpath=os.path.normpath(os.path.join(realPath,pathX,name)) |
dirs=xml.xpath.Evaluate(xpath,dom) |
if checkpath==path: |
|
|
|
return dir.toxml() |
if len(dirs)>0: |
|
return dirs[0].toxml |
|
|
#ist path ein file? |
#ist path ein file? |
files=dom.getElementsByTagName('file') |
xpath="/resource/file[name='%s' and path='%s']"%(name,searchPath) |
for dir in dirs: |
|
pathes=dir.getElementsByTagName('path') |
|
if pathes: |
|
pathX=OSAS_helpers.getText(pathes[0].childNodes) |
|
else: |
|
pathX="" |
|
names=dir.getElementsByTagName('name') |
|
if names: |
|
name=OSAS_helpers.getText(names[0].childNodes) |
|
else: |
|
name="" |
|
|
|
checkpath=os.path.normpath(os.path.join(realPath,pathX,name)) |
dirs=xml.xpath.Evaluate(xpath,dom) |
if checkpath==path: |
|
|
|
return dir.toxml() |
|
|
|
|
if len(dirs)>0: |
|
return dirs[0].toxml() |
|
|
return None |
return None |
|
|
|
|
def getSubDirsFromIndexMeta(self,path): |
def getSubDirsFromIndexMeta(self,path): |
|
|
"""Gebe alle path untergeordenten Objekte aus |
"""Gebe alle path untergeordenten Objekte aus |
@param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName |
@param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName |
@return: Directory [pfad auf das Objekt]->(fileType,''), fileType ist hierbei OSAS_dir_archive falls Object ein directory und OSAS_file_archive falls das Object ein File ist,der zweite Eintrag des Tupels ist zur Zeit immer '', spaeter wird hier die Beschreibung gemaess Metadaten stehen, wie bei readObjectsFromPath. |
@return: Directory [pfad auf das Objekt]->(fileType,''), fileType ist hierbei OSAS_dir_archive falls Object ein directory und OSAS_file_archive falls das Object ein File ist,der zweite Eintrag des Tupels ist zur Zeit immer '', spaeter wird hier die Beschreibung gemaess Metadaten stehen, wie bei readObjectsFromPath. |
|
@todo: Rueckgabe einer Beschreibung gemaess Metadaten |
""" |
""" |
ret={} |
ret={} |
indexMeta=self.findIndexMeta(path) |
startPath=path |
|
server=xmlrpclib.Server(self.serverUrl) |
|
indexMeta,stats=server.findIndexMetaWithStats(path)#findex index.meta zu path. |
|
|
if not indexMeta: |
if not indexMeta: |
return ret |
return ret |
|
|
realPath=os.path.split(indexMeta)[0] |
realPath=os.path.split(indexMeta)[0] |
path=path.replace(realPath,"") |
path=path.replace(realPath,"") |
if path and (path[0]==os.sep): |
if path and (path[0]==os.sep): #falls am Anfang os.sep steht lösche dieses. |
path=path[1:] |
path=path[1:] |
|
|
stats=os.stat(indexMeta) |
|
|
|
#teste ob schon im cache |
|
if self._v_metaFiles.has_key(path) and (self._v_metaFiles[path][0]==stats[stat.ST_MTIME]): |
|
#print "cache",path |
|
return self._v_metaFiles[path][1] |
|
|
|
dom=xml.dom.minidom.parse(indexMeta) |
#teste ob schon im cache zur Zeit kein chache wenn index.meta file nicht im selben ordner wie path. |
|
|
|
if self._v_metaFiles.has_key(startPath) and (self._v_metaFiles[realPath][0]==stats[stat.ST_MTIME]) and (path==""): |
|
|
|
return self._v_metaFiles[startPath][1] |
|
|
|
try: |
|
dom=xml.dom.minidom.parseString(server.getFile(indexMeta)) |
|
except: |
|
zLOG.LOG("OSAS_browser (getSubDirsFromIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta) |
|
return ret |
|
|
dirs=[] |
dirs=[] |
dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file') |
dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file') |
Line 158 class OSAS_storeOnline(SimpleItem):
|
Line 247 class OSAS_storeOnline(SimpleItem):
|
fileType="OSAS_file_archive" |
fileType="OSAS_file_archive" |
|
|
object=os.path.join(realPath,pathX,name) |
object=os.path.join(realPath,pathX,name) |
ret[object]=(fileType,'') |
ret[object.encode('utf-8')]=(fileType,'') |
|
|
|
self._v_metaFiles[startPath]=(stats[stat.ST_MTIME],ret) # speicher im chache |
|
|
self._v_metaFiles[path]=(stats[stat.ST_MTIME],ret) # speicher im chache |
|
return ret |
return ret |
|
|
|
|
def getMetaInfoFromIndexMeta(self,path): |
|
"""metadaten zu path als html aus dem index.meta file zu path |
def __init__(self,id,serverUrl): |
@param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName |
"""initialize a new instance |
@return: metadata als html |
@param id: Zope id""" |
""" |
self.id = id |
xmlInfos=self.findEntryInIndexMeta(path) |
self.serverUrl = serverUrl |
if xmlInfos: |
|
return OSAS_helpers.getMetaInfoFromXML(path,xmlInfos) |
|
|
security.declareProtected('View','index_html') |
|
def index_html(self): |
|
"""main view either standard template zpt/storeOnline_index_html.zpt or storeOnline_index.html in tree""" |
|
if hasattr(self,'storeOnline_index.html'): |
|
return getattr(self,'storeOnline_index.html')() |
else: |
else: |
return "" |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','storeOnline_index_html.zpt')).__of__(self) |
|
return pt() |
|
|
|
|
def readObjectsFromPath(self,path=""): |
def findIndexMeta(self,path=""): |
|
"""finde Rueckwaerts im Baum von Pfad ausgehend, dass erste index.meta file |
|
@keyword path: default ist "", Pfad auf das Object relativ zum rootFolderName |
|
@return: None falls kein index.meta existiert sonst Pfad auf das index.meta |
|
""" |
|
realPath=os.path.normpath(os.path.join(self.rootFolderName,path)) |
|
#suche index.meta |
|
server=xmlrpclib.Server(self.serverUrl) |
|
return server.findIndexMeta(realPath) |
|
|
|
|
|
|
|
def readObjectsFromPath(self,path="",metaDataId=None): |
"""Liest files aus dem path und speichert im cache _v_filesystem. |
"""Liest files aus dem path und speichert im cache _v_filesystem. |
|
|
@param path : path relativ zum root folder des Storagesystems |
@keyword path : path relativ zum root folder des Storagesystems |
|
@keyword metaDataId: Optional, id des OSAS_Metadata Object, dass benutzt werden soll, generisch wird das erste Object, dass in parent gefunden wird angezeigt. |
@return: directory der Form [pfad zum Objekt] -> (fileType,metadatum als String) |
@return: directory der Form [pfad zum Objekt] -> (fileType,metadatum als String) |
""" |
""" |
|
server=xmlrpclib.Server(self.serverUrl) |
realPath=os.path.normpath(os.path.join(self.rootFolderName,path)) |
realPath=os.path.normpath(os.path.join(self.rootFolderName,path)) |
metaData=self.testmd #test |
|
|
|
|
if metaDataId: |
|
metaData=getattr(self,metaDataId) |
|
if not (getattr(metaData,'meta_type','')=='OSAS_Metadata__neu'): |
|
zLOG.LOG('OSAS_browser (readObjectsFromPath)',zLOG.ERROR,"%s is not OSAS_Metadata") |
|
metaData=None |
|
else: |
|
metaDatas=self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_Metadata__neu'],search_sub=1) |
|
if metaDatas: |
|
metaData=metaDatas[0][1] |
|
else: |
|
zLOG.LOG('OSAS_browser (readObjectsFromPath)',zLOG.INFO,"There is no OSAS_Metadata Object") |
|
metaData=None |
|
|
|
#print "md",metaData |
if realPath.find(self.rootFolderName) <0: #versuch auf Pfad unterhalb des Rootfolder zuzugreifen |
if realPath.find(self.rootFolderName) <0: #versuch auf Pfad unterhalb des Rootfolder zuzugreifen |
return {} |
return {} |
|
|
|
|
if not os.path.exists(realPath): |
|
#return None,"(ERROR) path %s does not exist."%path |
|
return None |
|
|
|
stats=os.stat(realPath) |
|
|
stats=server.getStat(realPath) |
|
|
|
if not stats: |
|
return None |
|
|
#teste ob schon im cache |
#teste ob schon im cache |
if self._v_fileSystem.has_key(realPath) and (self._v_fileSystem[realPath][0]==stats[stat.ST_MTIME]): |
if self._v_fileSystem.has_key(realPath) and (self._v_fileSystem[realPath][0]==stats[stat.ST_MTIME]): |
|
|
return self._v_fileSystem[realPath][1] |
return self._v_fileSystem[realPath][1] |
|
|
dir=os.listdir(realPath) |
indexMetas=server.getAllIndexMetasOfSubDirs(realPath) |
|
dir=indexMetas.keys() |
|
|
ret={} |
ret={} |
for filename in dir: |
for filename in dir: |
|
|
object=os.path.join(realPath,filename) |
object=os.path.join(realPath,filename) |
fileType=OSAS_helpers.checkOSASFileType(object) |
fileType=indexMetas[filename][0] |
|
|
if fileType: |
if fileType: |
|
if (fileType=='OSAS_dir') and indexMetas.has_key(".") and indexMetas["."][1]: |
|
|
|
if(OSAS_helpers.isImageFolder(object,decodeRPC(indexMetas["."][1]))): |
|
fileType='OSAS_imageFolder' |
|
elif(OSAS_helpers.isVideoFolder(object,decodeRPC(indexMetas["."][1]))): |
|
fileType='OSAS_videoFolder' |
|
if metaData and indexMetas[filename][1]: |
|
|
ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object)) |
ret[object]=(fileType,metaData.getDisplayFieldsAsStr(decodeRPC(indexMetas[filename][1]))) |
|
else: |
|
metaDataStr=self.findEntryInIndexMeta(object) |
|
|
|
if metaDataStr: |
|
display=metaData.getDisplayFieldsAsStr(metaDataStr) |
|
dom=xml.dom.minidom.parseString(metaDataStr) |
|
|
|
if len(xml.xpath.Evaluate("/file/meta/video-file",dom))>0: |
|
fileType='OSAS_videoFile' |
|
|
|
else: |
|
display="" |
|
|
|
|
|
ret[object]=(fileType,display) |
|
|
self._v_fileSystem[realPath]=(stats[stat.ST_MTIME],ret) # speicher im chache |
self._v_fileSystem[realPath]=(stats[stat.ST_MTIME],ret) # speicher im chache |
|
|
return ret |
return ret |
|
|
def giveHandlers(self,path,type): |
def giveHandlers(self,path,type): |
"""teste ob fuer diesen Typ, handler definiert sind und gibt einen entsprechenden Link zurueck, der das Object mit diesem Handler ausfuehrt. |
"""teste ob fuer diesen Typ, handler definiert sind und gibt einen entsprechenden Link zurueck, der das Object mit diesem Handler ausfuehrt. Die Handler mussen im parent ordner des browser oder einem Subordner davon liegen. |
@param path: Pfad auf das Objekt |
@param path: Pfad auf das Objekt |
@param type: Typ des Objektes |
@param type: Typ des Objektes |
@return: (string) html-Fragment, link der das Objekt mit diesem Handler anzeigt. |
@return: (string) html-Fragment, link der das Objekt mit diesem Handler anzeigt. |
Line 224 class OSAS_storeOnline(SimpleItem):
|
Line 372 class OSAS_storeOnline(SimpleItem):
|
ret=[] |
ret=[] |
|
|
for handler in self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_HandlerObject__neu'],search_sub=1): |
for handler in self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_HandlerObject__neu'],search_sub=1): |
|
|
if type in handler[1].objectTypes: |
if type in handler[1].objectTypes: |
try: |
try: |
path=path.replace(getattr(handler[1],'ignorePath',''),'') |
path=path.replace(getattr(handler[1],'ignorePath',''),'') |
Line 238 class OSAS_storeOnline(SimpleItem):
|
Line 387 class OSAS_storeOnline(SimpleItem):
|
|
|
def generateTree(self,path=""): |
def generateTree(self,path=""): |
"""erzeuge liest die Objekte aus die im Pfad gespeichert sind |
"""erzeuge liest die Objekte aus die im Pfad gespeichert sind |
@param path: optional mit default='', Pfad relativ zu rootFolderName |
|
|
@keyword path: optional mit default='', Pfad relativ zu rootFolderName |
@return: List von Tripeln, (link_html,array of handlers,metainformationen) hierbei ist |
@return: List von Tripeln, (link_html,array of handlers,metainformationen) hierbei ist |
- (string) link_html ein html-Fragement, falls das Objekt vom Typ OSAS_dir ist, ist dies ein Link auf dieses Verzeichnis, sonst der Dateiname |
- (string) link_html ein html-Fragement, falls das Objekt vom Typ OSAS_dir ist, ist dies ein Link auf dieses Verzeichnis, sonst der Dateiname |
- (string) handler sind die Ergebnisse von giveHandlers fuer dieses Objekt |
- (string) handler sind die Ergebnisse von giveHandlers fuer dieses Objekt |
- (string) metainformationen die Metainformationen zum Objekt als Ergebnis von readObjectsFromPath |
- (string) metainformationen die Metainformationen zum Objekt als Ergebnis von readObjectsFromPath |
""" |
""" |
objects=self.readObjectsFromPath(path) |
|
if not objects: |
objects=self.getSubDirsFromIndexMeta(path) |
objects={} |
|
im=self.getSubDirsFromIndexMeta(path) |
|
|
|
|
im=self.readObjectsFromPath(path) |
|
if not im: |
|
im={} |
|
|
|
|
|
|
|
|
for key in im.keys(): |
for key in im.keys(): |
#virtuelle pfade hinzufuegen |
#relle pfade hinzufuegen, virtueller wird ueberschrieben |
|
|
if not objects.has_key(key): |
|
objects[key]=im[key] |
objects[key]=im[key] |
|
|
|
|
|
|
def sortLow(x,y): |
def sortLow(x,y): |
return cmp(x.lower(),y.lower()) |
return cmp(x.lower(),y.lower()) |
|
|
Line 263 class OSAS_storeOnline(SimpleItem):
|
Line 421 class OSAS_storeOnline(SimpleItem):
|
objectSorted=objects.keys() |
objectSorted=objects.keys() |
objectSorted.sort(sortLow) |
objectSorted.sort(sortLow) |
for object in objectSorted: |
for object in objectSorted: |
|
|
handler=self.giveHandlers(object,objects[object][0]) |
handler=self.giveHandlers(object,objects[object][0]) |
if objects[object][0]=="OSAS_dir": |
if not(os.path.split(object)[1]=="."): |
|
if objects[object][0] in OSASDirObjects: |
|
|
string="""<a href="?path=%s">%s</a>"""%(object,os.path.split(object)[1]) |
string="""<a href="?path=%s">%s</a>"""%(object,os.path.split(object)[1]) |
|
|
Line 274 class OSAS_storeOnline(SimpleItem):
|
Line 434 class OSAS_storeOnline(SimpleItem):
|
|
|
ret.append((string,handler,objects[object][1])) |
ret.append((string,handler,objects[object][1])) |
else: |
else: |
|
|
ret.append((os.path.split(object)[1],handler,objects[object][1])) |
ret.append((os.path.split(object)[1],handler,objects[object][1])) |
|
|
|
|
Line 281 class OSAS_storeOnline(SimpleItem):
|
Line 442 class OSAS_storeOnline(SimpleItem):
|
|
|
|
|
def path_to_link(self,pathTmp=""): |
def path_to_link(self,pathTmp=""): |
"""generates navigation bar for viewfiles""" |
"""generates navigation bar for viewfiles |
|
@keyword pathTmp: optional, generisch="", pfad der erstellt werden soll |
|
@return: html Fragment, pathTmp zerlegt, dass jeder Teil von Pfad unterhalb von rootFolderName direkt angesprungen werden kann. |
|
""" |
|
|
path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp)) |
path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp)) |
|
|
Line 309 class OSAS_storeOnline(SimpleItem):
|
Line 473 class OSAS_storeOnline(SimpleItem):
|
i=i-1 |
i=i-1 |
return string |
return string |
|
|
def getMetaFile(self,path): |
|
"""Lese Metafile ein""" |
|
tmp=OSAS_helpers.getMetaFile(self,path) |
|
#zLOG.LOG("EE",zLOG.INFO,type(tmp)) |
|
|
|
return tmp |
|
|
|
InitializeClass(OSAS_storeOnline) |
InitializeClass(OSAS_storeOnline) |
|
|
def manage_addOSAS_storeOnlineForm(self): |
def manage_addOSAS_storeOnlineForm(self): |
"""interface for adding the OSAS_root""" |
"""interface for adding the OSAS_storeOnline""" |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addStoreOnline.zpt')).__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addStoreOnline.zpt')).__of__(self) |
return pt() |
return pt() |
|
|
def manage_addOSAS_storeOnline(self,id,RESPONSE=None): |
def manage_addOSAS_storeOnline(self,id,RESPONSE=None): |
"""add the OSAS_root""" |
"""add the OSAS_storeOnline |
|
@param id: id |
|
""" |
newObj=OSAS_storeOnline(id) |
newObj=OSAS_storeOnline(id) |
self._setObject(id,newObj) |
self._setObject(id,newObj) |
if RESPONSE is not None: |
if RESPONSE is not None: |