version 1.1, 2004/11/29 09:48:07
|
version 1.8, 2005/02/10 19:50:18
|
Line 12 import zLOG
|
Line 12 import zLOG
|
import os |
import os |
import os.path |
import os.path |
import stat |
import stat |
|
import xml.dom.minidom |
|
from types import * |
|
import xmlrpclib |
|
|
|
|
|
|
class OSAS_storeOnline(SimpleItem): |
class OSAS_storeOnline(SimpleItem): |
"""Webfrontend für das Storagesystem |
"""Webfrontend für das Storagesystem |
Line 22 class OSAS_storeOnline(SimpleItem):
|
Line 27 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): |
|
"""initialize a new instance""" |
|
self.id = id |
|
|
|
|
|
|
def __init__(self,id,serverUrl): |
|
"""initialize a new instance |
|
@param id: Zope id""" |
|
self.id = id |
|
self.serverUrl = serverUrl |
|
|
|
|
security.declareProtected('View','index_html') |
security.declareProtected('View','index_html') |
def index_html(self): |
def index_html(self): |
"""main view either standard template or storeOnline_index.html in tree""" |
"""main view either standard template zpt/storeOnline_index_html.zpt or storeOnline_index.html in tree""" |
if hasattr(self,'storeOnline_index.html'): |
if hasattr(self,'storeOnline_index.html'): |
return getattr(self,'storeOnline_index.html')() |
return getattr(self,'storeOnline_index.html')() |
else: |
else: |
Line 39 class OSAS_storeOnline(SimpleItem):
|
Line 48 class OSAS_storeOnline(SimpleItem):
|
return pt() |
return pt() |
|
|
|
|
|
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=""): |
|
"""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 |
|
|
def getSubDirsFromIndexMeta(self,path): |
|
|
|
"""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={} |
|
server=xmlrpclib.Server(self.serverUrl) |
|
indexMeta,stats=server.findIndexMetaWithStats(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): #falls am Anfang os.sep steht lösche dieses. |
|
path=path[1:] |
|
|
|
|
|
|
|
#teste ob schon im cache |
|
|
|
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) |
|
except: |
|
zLOG.LOG("OSAS_browser (getSubDirsFromIndexMeta)",zLOG.ERROR,"Cannot parse: %s"%indexMeta) |
|
|
|
|
|
dirs=[] |
|
dirs=dom.getElementsByTagName('dir')+dom.getElementsByTagName('file') |
|
|
|
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="" |
|
|
|
#print "PP",pathX,path |
|
if pathX==path: |
|
if dir.tagName=="dir": |
|
fileType="OSAS_dir_archive" |
|
else: |
|
fileType="OSAS_file_archive" |
|
|
|
object=os.path.join(realPath,pathX,name) |
|
ret[object]=(fileType,'') |
|
|
|
self._v_metaFiles[path]=(stats[stat.ST_MTIME],ret) # speicher im chache |
|
return ret |
|
|
|
|
|
|
|
|
|
def readObjectsFromPath(self,path="",metaDataId=None): |
|
"""Liest files aus dem path und speichert im cache _v_filesystem. |
|
|
|
@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) |
|
""" |
|
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 |
|
|
|
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) |
dir=server.listdir(realPath) |
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=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 für diese Typ, viewer definiert sind""" |
"""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. |
|
""" |
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 |
|
|
|
|
def generateTree(self,path=""): |
def generateTree(self,path=""): |
"""erzeuge navigations elemente""" |
"""erzeuge liest die Objekte aus die im Pfad gespeichert sind |
|
|
|
@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 |
|
""" |
objects=self.readObjectsFromPath(path) |
objects=self.readObjectsFromPath(path) |
|
if not objects: |
|
objects={} |
|
im=self.getSubDirsFromIndexMeta(path) |
|
for key in im.keys(): |
|
#virtuelle pfade hinzufuegen |
|
|
|
if not objects.has_key(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 109 class OSAS_storeOnline(SimpleItem):
|
Line 236 class OSAS_storeOnline(SimpleItem):
|
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]) |
|
|
ret.append((string,handler,objects[object][1])) |
ret.append((string,handler,objects[object][1])) |
|
elif objects[object][0]=="OSAS_dir_archive": |
|
string="""<a href="?path=%s">%s (A)</a>"""%(object,os.path.split(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 117 class OSAS_storeOnline(SimpleItem):
|
Line 248 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 146 class OSAS_storeOnline(SimpleItem):
|
Line 280 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(path) |
@param path: Pfad des index.met |
|
@return: index.meta file |
|
""" |
|
server=xmlrpclib.Server(self.serverUrl) |
|
tmp=server.getMetaFile(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: |