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