--- OSA_system2/OSAS_browser.py 2004/12/23 16:31:22 1.6 +++ OSA_system2/OSAS_browser.py 2005/01/21 14:03:24 1.7 @@ -27,7 +27,8 @@ class OSAS_storeOnline(SimpleItem): _v_metaFiles={} #chache fuer indexMeta def __init__(self,id): - """initialize a new instance""" + """initialize a new instance + @param id: Zope id""" self.id = id @@ -43,34 +44,42 @@ class OSAS_storeOnline(SimpleItem): def findIndexMeta(self,path=""): - """finde index_meta fuer diesen eventuell virtuellen Pfad - @param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName + """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 while (not os.path.exists(os.path.join(realPath,'index.meta'))) and (not ((realPath=="") or (realPath=="/"))): realPath=os.path.split(realPath)[0] + if realPath=='' or realPath=='/': - return None + if os.path.exists(os.path.join(realPath,'index.meta')): + return os.path.join(realPath,'index.meta') + else: + return None else: return os.path.join(realPath,'index.meta') 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 @return: den Teil von Index.meta der Informationen zu path enthaelt, None wenn error. """ - indexMeta=self.findIndexMeta(path) + indexMeta=self.findIndexMeta(path) # suche index.meta + if not indexMeta: return None + realPath=os.path.split(indexMeta)[0] path=os.path.normpath(os.path.join(self.rootFolderName,path)) - - dom=xml.dom.minidom.parse(indexMeta) - #ist path ein directory? + try: + dom=xml.dom.minidom.parse(indexMeta) + except: + zLOG.LOG("OSAS_browser (findEntryInIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta) + #ist path ein directory? dirs=dom.getElementsByTagName('dir') for dir in dirs: pathes=dir.getElementsByTagName('path') @@ -116,24 +125,31 @@ class OSAS_storeOnline(SimpleItem): """Gebe alle path untergeordenten Objekte aus @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. + @todo: Rueckgabe einer Beschreibung gemaess Metadaten """ ret={} - indexMeta=self.findIndexMeta(path) + indexMeta=self.findIndexMeta(path)#findex index.meta zu path. + if not indexMeta: return ret + realPath=os.path.split(indexMeta)[0] 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:] - stats=os.stat(indexMeta) + #teste ob schon im cache + stats=os.stat(indexMeta) 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) + try: + dom=xml.dom.minidom.parse(indexMeta) + except: + zLOG.LOG("OSAS_browser (getSubDirsFromIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta) + dirs=[] dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file') @@ -165,8 +181,8 @@ class OSAS_storeOnline(SimpleItem): def getMetaInfoFromIndexMeta(self,path): - """metadaten zu path als html aus dem index.meta file zu path - @param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName + """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 """ xmlInfos=self.findEntryInIndexMeta(path) @@ -176,16 +192,30 @@ class OSAS_storeOnline(SimpleItem): return "" - def readObjectsFromPath(self,path=""): + def readObjectsFromPath(self,path="",metaDataId=None): """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) """ 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 return {} @@ -208,15 +238,18 @@ class OSAS_storeOnline(SimpleItem): fileType=OSAS_helpers.checkOSASFileType(object) if fileType: - - ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object)) + if metaData: + + ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object)) + else: + ret[object]=(fileType,'') self._v_fileSystem[realPath]=(stats[stat.ST_MTIME],ret) # speicher im chache return ret 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 type: Typ des Objektes @return: (string) html-Fragment, link der das Objekt mit diesem Handler anzeigt. @@ -238,11 +271,12 @@ class OSAS_storeOnline(SimpleItem): def generateTree(self,path=""): """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 - - (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) metainformationen die Metainformationen zum Objekt als Ergebnis von readObjectsFromPath + - (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) metainformationen die Metainformationen zum Objekt als Ergebnis von readObjectsFromPath """ objects=self.readObjectsFromPath(path) if not objects: @@ -281,7 +315,10 @@ class OSAS_storeOnline(SimpleItem): 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 angesprunden werden kann. + """ path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp)) @@ -310,7 +347,10 @@ class OSAS_storeOnline(SimpleItem): return string def getMetaFile(self,path): - """Lese Metafile ein""" + """Lies Metafile ein + @param path: Pfad des index.met + @return: index.meta file + """ tmp=OSAS_helpers.getMetaFile(self,path) #zLOG.LOG("EE",zLOG.INFO,type(tmp)) @@ -319,12 +359,14 @@ class OSAS_storeOnline(SimpleItem): InitializeClass(OSAS_storeOnline) 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) return pt() def manage_addOSAS_storeOnline(self,id,RESPONSE=None): - """add the OSAS_root""" + """add the OSAS_storeOnline + @param id: id + """ newObj=OSAS_storeOnline(id) self._setObject(id,newObj) if RESPONSE is not None: