Diff for /OSA_system2/OSAS_browser.py between versions 1.2 and 1.7

version 1.2, 2004/12/23 08:30:55 version 1.7, 2005/01/21 14:03:24
Line 13  import os Line 13  import os
 import os.path  import os.path
 import stat  import stat
 import xml.dom.minidom  import xml.dom.minidom
   from types import *
   
 class OSAS_storeOnline(SimpleItem):  class OSAS_storeOnline(SimpleItem):
     """Webfrontend für das Storagesystem      """Webfrontend für das Storagesystem
Line 23  class OSAS_storeOnline(SimpleItem): Line 24  class OSAS_storeOnline(SimpleItem):
     security=ClassSecurityInfo()      security=ClassSecurityInfo()
   
     _v_fileSystem={} #chache fuer filesystem      _v_fileSystem={} #chache fuer filesystem
       _v_metaFiles={} #chache fuer indexMeta
           
     def __init__(self,id):      def __init__(self,id):
         """initialize a new instance"""          """initialize a new instance
           @param id: Zope id"""
         self.id = id          self.id = id
   
           
Line 41  class OSAS_storeOnline(SimpleItem): Line 44  class OSAS_storeOnline(SimpleItem):
   
   
     def findIndexMeta(self,path=""):      def findIndexMeta(self,path=""):
         """finde index_meta fuer diesen eventuell virtuellen Pfad          """finde Rueckwaerts im Baum von Pfad ausgehend, dass erste index.meta file
         @param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName          @keyword path: default ist "", Pfad auf das Object relativ zum rootFolderName
         @return: None falls kein index.meta existiert sonst Pfad auf das index.meta          @return: None falls kein index.meta existiert sonst Pfad auf das index.meta
         """          """
         realPath=os.path.normpath(os.path.join(self.rootFolderName,path))          realPath=os.path.normpath(os.path.join(self.rootFolderName,path))
         #suche index.meta          #suche index.meta
         while (not os.path.exists(os.path.join(realPath,'index.meta'))) and (not ((realPath=="") or (realPath=="/"))):          while (not os.path.exists(os.path.join(realPath,'index.meta'))) and (not ((realPath=="") or (realPath=="/"))):
             realPath=os.path.split(realPath)[0]              realPath=os.path.split(realPath)[0]
               
         if realPath=='' or realPath=='/':          if realPath=='' or realPath=='/':
               if os.path.exists(os.path.join(realPath,'index.meta')):
                   return os.path.join(realPath,'index.meta')
               else:
             return None              return None
         else:          else:
             return os.path.join(realPath,'index.meta')              return os.path.join(realPath,'index.meta')
   
     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.          @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]          realPath=os.path.split(indexMeta)[0]
         path=os.path.normpath(os.path.join(self.rootFolderName,path))          path=os.path.normpath(os.path.join(self.rootFolderName,path))
                   
           try:
         dom=xml.dom.minidom.parse(indexMeta)          dom=xml.dom.minidom.parse(indexMeta)
           except:
               zLOG.LOG("OSAS_browser (findEntryInIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta)
         #ist path ein directory?          #ist path ein directory?
         dirs=dom.getElementsByTagName('dir')          dirs=dom.getElementsByTagName('dir')
         for dir in dirs:          for dir in dirs:
Line 113  class OSAS_storeOnline(SimpleItem): Line 125  class OSAS_storeOnline(SimpleItem):
         """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)          indexMeta=self.findIndexMeta(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:]
   
                           
   
           #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]):
               return self._v_metaFiles[path][1]
   
           try:
         dom=xml.dom.minidom.parse(indexMeta)          dom=xml.dom.minidom.parse(indexMeta)
           except:
               zLOG.LOG("OSAS_browser (getSubDirsFromIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta)
   
   
         dirs=[]          dirs=[]
         dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file')          dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file')
Line 141  class OSAS_storeOnline(SimpleItem): Line 166  class OSAS_storeOnline(SimpleItem):
             else:              else:
                 name=""                  name=""
   
                       #print "PP",pathX,path
             if pathX==path:              if pathX==path:
                 if dir.tagName=="dir":                  if dir.tagName=="dir":
                     fileType="OSAS_dir_archive"                      fileType="OSAS_dir_archive"
Line 151  class OSAS_storeOnline(SimpleItem): Line 176  class OSAS_storeOnline(SimpleItem):
                 object=os.path.join(realPath,pathX,name)                  object=os.path.join(realPath,pathX,name)
                 ret[object]=(fileType,'')                  ret[object]=(fileType,'')
   
           self._v_metaFiles[path]=(stats[stat.ST_MTIME],ret) # speicher im chache
         return ret          return ret
   
                   
     def getMetaInfoFromIndexMeta(self,path):      def getMetaInfoFromIndexMeta(self,path):
         """metadaten zu path als html aus dem index.meta file zu path          """metadaten zu path als html aus dem index.meta file zu path (meta tag im file bzw. dir container)
         @param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName          @param path: Pfad auf das Object relativ zum rootFolderName
         @return: metadata als html          @return: metadata als html
         """          """
         xmlInfos=self.findEntryInIndexMeta(path)          xmlInfos=self.findEntryInIndexMeta(path)
           if xmlInfos:
         return OSAS_helpers.getMetaInfoFromXML(path,xmlInfos)          return OSAS_helpers.getMetaInfoFromXML(path,xmlInfos)
           else:
               return ""
                                   
         
       def readObjectsFromPath(self,path="",metaDataId=None):
     def readObjectsFromPath(self,path=""):  
         """Liest files aus dem path und speichert im cache _v_filesystem.          """Liest files aus dem path und speichert im cache _v_filesystem.
          - to do: files aus metadaten  
   
         @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)
         """          """
                                                 
         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 {}
                           
Line 187  class OSAS_storeOnline(SimpleItem): Line 227  class OSAS_storeOnline(SimpleItem):
         stats=os.stat(realPath)          stats=os.stat(realPath)
   
         # 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)          dir=os.listdir(realPath)
         ret={}          ret={}
Line 198  class OSAS_storeOnline(SimpleItem): Line 238  class OSAS_storeOnline(SimpleItem):
             fileType=OSAS_helpers.checkOSASFileType(object)              fileType=OSAS_helpers.checkOSASFileType(object)
                           
             if fileType:              if fileType:
                   if metaData:
                                   
                 ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object))                  ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object))
                   else:
                       ret[object]=(fileType,'')
                           
         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, viewer 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.
         """          """
         ret=[]          ret=[]
                   
         for viewer in self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_ViewerObject__neu'],search_sub=1):          for handler in self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_HandlerObject__neu'],search_sub=1):
             if type in viewer[1].objectTypes:              if type in handler[1].objectTypes:
                 path=path.replace(getattr(viewer[1],'ignorePath',''),'')          try:
                 url=viewer[1].prefix%path                   path=path.replace(getattr(handler[1],'ignorePath',''),'')
                 text=viewer[1].title                  except:
              pass
                   url=handler[1].prefix%path
                   text=handler[1].title
                 string="""<a target="_blank" href="%s">%s</a>"""%(url,text)                  string="""<a target="_blank" href="%s">%s</a>"""%(url,text)
                 ret.append(string)                  ret.append(string)
         return ret          return ret
Line 225  class OSAS_storeOnline(SimpleItem): Line 271  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
Line 268  class OSAS_storeOnline(SimpleItem): Line 315  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 angesprunden werden kann.
           """
   
         path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp))          path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp))
                   
Line 297  class OSAS_storeOnline(SimpleItem): Line 347  class OSAS_storeOnline(SimpleItem):
         return string          return string
   
     def getMetaFile(self,path):      def getMetaFile(self,path):
         """Lese Metafile ein"""          """Lies Metafile ein
         return OSAS_helpers.getMetaFile(self,path)          @param path: Pfad des index.met        
           @return: index.meta file
           """
           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:

Removed from v.1.2  
changed lines
  Added in v.1.7


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>