File:  [Repository] / OSA_system2 / OSAS_browser.py
Revision 1.8: download - view: text, annotated - select for diffs - revision graph
Thu Feb 10 19:50:18 2005 UTC (19 years, 4 months ago) by dwinter
Branches: MAIN
CVS tags: HEAD
server client solution per xmlrpc

    1: """ Classes for displaying, browsing and organizing the archive
    2: """
    3: 
    4: 
    5: import OSAS_helpers
    6: from AccessControl import ClassSecurityInfo
    7: from Products.PageTemplates.PageTemplateFile import PageTemplateFile
    8: from OFS.Folder import Folder
    9: from OFS.SimpleItem import SimpleItem
   10: from Globals import InitializeClass,package_home
   11: import zLOG
   12: import os
   13: import os.path
   14: import stat
   15: import xml.dom.minidom
   16: from types import *
   17: import xmlrpclib
   18: 
   19: 
   20: 
   21: class OSAS_storeOnline(SimpleItem):
   22:     """Webfrontend für das Storagesystem
   23:     liefert Browserumgebung 
   24:     """
   25:     meta_type="OSAS_StoreOnline__neu"
   26:     
   27:     security=ClassSecurityInfo()
   28: 
   29:     _v_fileSystem={} #chache fuer filesystem
   30:     _v_metaFiles={} #chache fuer indexMeta
   31: 
   32:    
   33:     
   34:     def __init__(self,id,serverUrl):
   35:         """initialize a new instance
   36:         @param id: Zope id"""
   37:         self.id = id
   38:         self.serverUrl = serverUrl
   39:     
   40: 
   41:     security.declareProtected('View','index_html')
   42:     def index_html(self):
   43:         """main view either standard template zpt/storeOnline_index_html.zpt or storeOnline_index.html in tree"""
   44:         if hasattr(self,'storeOnline_index.html'):
   45:             return getattr(self,'storeOnline_index.html')()
   46:         else:
   47:             pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','storeOnline_index_html.zpt')).__of__(self)
   48:             return pt()
   49: 
   50: 
   51:     def findIndexMeta(self,path=""):
   52:         """finde Rueckwaerts im Baum von Pfad ausgehend, dass erste index.meta file
   53:         @keyword path: default ist "", Pfad auf das Object relativ zum rootFolderName
   54:         @return: None falls kein index.meta existiert sonst Pfad auf das index.meta
   55:         """
   56:         realPath=os.path.normpath(os.path.join(self.rootFolderName,path))
   57:         #suche index.meta
   58:         server=xmlrpclib.Server(self.serverUrl)
   59:         return server.findIndexMeta(realPath)
   60:         
   61: 
   62:   
   63: 
   64:     def getSubDirsFromIndexMeta(self,path):
   65:         
   66:         """Gebe alle path untergeordenten Objekte aus
   67:         @param path: optional, default ist "", Pfad auf das Object relativ zum rootFolderName
   68:         @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.
   69:         @todo: Rueckgabe einer Beschreibung gemaess Metadaten
   70:         """
   71:         ret={}
   72:         server=xmlrpclib.Server(self.serverUrl)
   73:         indexMeta,stats=server.findIndexMetaWithStats(path)#findex index.meta zu path.
   74: 
   75:         if not indexMeta:
   76:             return ret
   77: 
   78:         realPath=os.path.split(indexMeta)[0]
   79:         path=path.replace(realPath,"")
   80:         if path and (path[0]==os.sep): #falls am Anfang os.sep steht lösche dieses.
   81:             path=path[1:]
   82: 
   83: 
   84: 
   85:         #teste ob schon im cache
   86:         
   87:         if self._v_metaFiles.has_key(path) and (self._v_metaFiles[path][0]==stats[stat.ST_MTIME]):
   88:             return self._v_metaFiles[path][1]
   89: 
   90:         try:
   91:             dom=xml.dom.minidom.parse(indexMeta)
   92:         except:
   93:             zLOG.LOG("OSAS_browser (getSubDirsFromIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta)
   94: 
   95: 
   96:         dirs=[]
   97:         dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file')
   98:     
   99:         for dir in dirs:
  100:             pathes=dir.getElementsByTagName('path')
  101:             if pathes:
  102:                 pathX=OSAS_helpers.getText(pathes[0].childNodes)
  103:             else:
  104:                 pathX=""
  105:             names=dir.getElementsByTagName('name')
  106:             if names:
  107:                 name=OSAS_helpers.getText(names[0].childNodes)
  108:             else:
  109:                 name=""
  110: 
  111:             #print "PP",pathX,path
  112:             if pathX==path:
  113:                 if dir.tagName=="dir":
  114:                     fileType="OSAS_dir_archive"
  115:                 else:
  116:                     fileType="OSAS_file_archive"
  117: 
  118:                 object=os.path.join(realPath,pathX,name)
  119:                 ret[object]=(fileType,'')
  120: 
  121:         self._v_metaFiles[path]=(stats[stat.ST_MTIME],ret) # speicher im chache
  122:         return ret
  123: 
  124:         
  125:   
  126: 
  127:     def readObjectsFromPath(self,path="",metaDataId=None):
  128:         """Liest files aus dem path und speichert im cache _v_filesystem.
  129: 
  130:         @keyword path : path relativ zum root folder des Storagesystems
  131:         @keyword metaDataId: Optional, id des OSAS_Metadata Object, dass benutzt werden soll, generisch wird das erste Object, dass in parent gefunden wird angezeigt.
  132:         @return: directory der Form [pfad zum Objekt] -> (fileType,metadatum als String)
  133:         """
  134:         server=xmlrpclib.Server(self.serverUrl)             
  135:         realPath=os.path.normpath(os.path.join(self.rootFolderName,path))
  136: 
  137:         if metaDataId:
  138:             metaData=getattr(self,metaDataId)
  139:             if not (getattr(metaData,'meta_type','')=='OSAS_Metadata__neu'):
  140:                 zLOG.LOG('OSAS_browser (readObjectsFromPath)',zLOG.ERROR,"%s is not OSAS_Metadata")
  141:                 metaData=None
  142:         else:
  143:             metaDatas=self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_Metadata__neu'],search_sub=1)
  144:             if metaDatas:
  145:                 metaData=metaDatas[0][1]
  146:             else:
  147:                 zLOG.LOG('OSAS_browser (readObjectsFromPath)',zLOG.INFO,"There is no OSAS_Metadata Object")
  148:                 metaData=None
  149:                 
  150:         #print "md",metaData
  151:         if realPath.find(self.rootFolderName) <0: #versuch auf Pfad unterhalb des Rootfolder zuzugreifen
  152:             return {}
  153:             
  154:         
  155:        
  156:         
  157:         stats=server.getStat(realPath)
  158: 
  159:         if not stats:
  160:             return None
  161:         
  162:         #teste ob schon im cache
  163:         if self._v_fileSystem.has_key(realPath) and (self._v_fileSystem[realPath][0]==stats[stat.ST_MTIME]):
  164:             
  165:             return self._v_fileSystem[realPath][1]
  166: 
  167:         dir=server.listdir(realPath)
  168:         ret={}
  169:         for filename in dir:
  170:             object=os.path.join(realPath,filename)
  171:             fileType=OSAS_helpers.checkOSASFileType(object)
  172:             
  173:             if fileType:
  174:                 if metaData:
  175:                  
  176:                     ret[object]=(fileType,metaData.getDisplayFieldsAsStr(object))
  177:                 else:
  178:                     ret[object]=(fileType,'')
  179:             
  180:         self._v_fileSystem[realPath]=(stats[stat.ST_MTIME],ret) # speicher im chache
  181:         
  182:         return ret
  183: 
  184:     def giveHandlers(self,path,type):
  185:         """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. 
  186:         @param path: Pfad auf das Objekt
  187:         @param type: Typ des Objektes
  188:         @return: (string) html-Fragment, link der das Objekt mit diesem Handler anzeigt.
  189:         """
  190:         ret=[]
  191:         
  192:         for handler in self.ZopeFind(self.aq_parent,obj_metatypes=['OSAS_HandlerObject__neu'],search_sub=1):
  193:             if type in handler[1].objectTypes:
  194: 		try:
  195:                  path=path.replace(getattr(handler[1],'ignorePath',''),'')
  196:                 except:
  197: 	 	   pass
  198:                 url=handler[1].prefix%path
  199:                 text=handler[1].title
  200:                 string="""<a target="_blank" href="%s">%s</a>"""%(url,text)
  201:                 ret.append(string)
  202:         return ret
  203:                       
  204:         
  205:     def generateTree(self,path=""):
  206:         """erzeuge liest die Objekte aus die im Pfad gespeichert sind
  207:         
  208:         @keyword path: optional mit default='', Pfad relativ zu rootFolderName
  209:         @return: List von Tripeln, (link_html,array of handlers,metainformationen) hierbei ist
  210:          - (string) link_html ein html-Fragement, falls das Objekt vom Typ OSAS_dir ist, ist dies ein Link auf dieses Verzeichnis, sonst der Dateiname
  211:          - (string) handler sind die Ergebnisse von giveHandlers fuer dieses Objekt
  212:          - (string) metainformationen die Metainformationen zum Objekt als Ergebnis von readObjectsFromPath
  213:         """
  214:         objects=self.readObjectsFromPath(path)
  215:         if not objects:
  216:             objects={}
  217:         im=self.getSubDirsFromIndexMeta(path)
  218:         for key in im.keys():
  219:             #virtuelle pfade hinzufuegen
  220:             
  221:             if not objects.has_key(key):
  222:                 objects[key]=im[key]
  223:                 
  224:         
  225:         def sortLow(x,y):
  226:             return cmp(x.lower(),y.lower())
  227:         
  228:         ret=[]
  229:         
  230:         objectSorted=objects.keys()
  231:         objectSorted.sort(sortLow)
  232:         for object in objectSorted:
  233:             handler=self.giveHandlers(object,objects[object][0])
  234:             if objects[object][0]=="OSAS_dir":
  235:                 
  236:                 string="""<a href="?path=%s">%s</a>"""%(object,os.path.split(object)[1])
  237:                 
  238:                 ret.append((string,handler,objects[object][1]))
  239:             elif objects[object][0]=="OSAS_dir_archive":
  240:                 string="""<a href="?path=%s">%s (A)</a>"""%(object,os.path.split(object)[1])
  241:                 
  242:                 ret.append((string,handler,objects[object][1]))
  243:             else:
  244:                 ret.append((os.path.split(object)[1],handler,objects[object][1]))
  245: 
  246:                      
  247:         return ret
  248: 
  249: 
  250:     def path_to_link(self,pathTmp=""):
  251:         """generates navigation bar for viewfiles
  252:         @keyword pathTmp: optional, generisch="", pfad der erstellt werden soll
  253:         @return: html Fragment, pathTmp zerlegt, dass jeder Teil von Pfad unterhalb von rootFolderName direkt angesprunden werden kann.
  254:         """
  255: 
  256:         path=os.path.normpath(os.path.join(self.rootFolderName,pathTmp))
  257:         
  258:         URL=self.absolute_url()
  259:         string=""
  260:         
  261:         tmppath=os.path.dirname(path)
  262:         i=0
  263:         pathes=[[path, os.path.basename(path)]]
  264: 
  265:         while not (len(tmppath)==1):
  266: 
  267:               i=i+1
  268:               if i>20: break
  269: 
  270:               pathes.append([tmppath, os.path.basename(tmppath)])
  271:               tmppath=os.path.dirname(tmppath)
  272: 
  273:         while i>=0:
  274:             if pathes[i][0].find(self.rootFolderName) <0: #versuch auf Pfad unterhalb des Rootfolder zuzugreifen
  275:                 string=string+"<a>"+pathes[i][1]+"</a>/"
  276:             else:
  277:                 string=string+"<a href="+URL+"?path="+pathes[i][0]+">"+pathes[i][1]+"</a>/"
  278:             
  279:             i=i-1
  280:         return string
  281: 
  282:     def getMetaFile(self,path):
  283:         """Lies Metafile ein
  284:         @param path: Pfad des index.met        
  285:         @return: index.meta file
  286:         """
  287:         server=xmlrpclib.Server(self.serverUrl)
  288:         tmp=server.getMetaFile(path)
  289:         #zLOG.LOG("EE",zLOG.INFO,type(tmp))
  290:         
  291:         return tmp
  292: 
  293: InitializeClass(OSAS_storeOnline)
  294: 	
  295: def manage_addOSAS_storeOnlineForm(self):
  296:     """interface for adding the OSAS_storeOnline"""
  297:     pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addStoreOnline.zpt')).__of__(self)
  298:     return pt()
  299: 
  300: def manage_addOSAS_storeOnline(self,id,RESPONSE=None):
  301:     """add the OSAS_storeOnline
  302:     @param id: id
  303:     """
  304:     newObj=OSAS_storeOnline(id)
  305:     self._setObject(id,newObj)
  306:     if RESPONSE is not None:
  307:         RESPONSE.redirect('manage_main')
  308: 

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