version 1.20, 2004/03/25 09:57:47
|
version 1.23, 2004/04/02 17:38:40
|
Line 4
|
Line 4
|
from OSAS_helpers import readArchimedesXML, getISO, getText |
from OSAS_helpers import readArchimedesXML, getISO, getText |
import os |
import os |
import xml.dom.minidom |
import xml.dom.minidom |
try: |
|
from Products.ECHO_content import ECHO_collection |
|
except: |
|
print "Ignoring ECHO_collection import...." |
|
|
|
import urllib |
import urllib |
import OSAS_add |
import OSAS_add |
Line 20 from Products.PageTemplates.PageTemplate
|
Line 16 from Products.PageTemplates.PageTemplate
|
from Products.PageTemplates.PageTemplate import PageTemplate |
from Products.PageTemplates.PageTemplate import PageTemplate |
import archive # check if this is necessary |
import archive # check if this is necessary |
|
|
|
|
|
from xml.sax import make_parser |
|
from xml.sax.handler import ContentHandler |
|
|
|
def spaces(depth): |
|
"""needed in XMLtoTree""" |
|
tmp="" |
|
k=0 |
|
while k<2*depth: |
|
k+=1 |
|
tmp=tmp+" "+" " |
|
return tmp |
|
|
|
|
class OSAS_add_Document(Folder): |
class OSAS_add_Document(Folder): |
"""Hinzufuegen eines Dokumentes zum Storage""" |
"""Hinzufuegen eines Dokumentes zum Storage""" |
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
Line 153 def manage_AddOSAS_add_Text(self,id,RESP
|
Line 163 def manage_AddOSAS_add_Text(self,id,RESP
|
|
|
InitializeClass(OSAS_add_Text) |
InitializeClass(OSAS_add_Text) |
|
|
|
|
class OSAS_add_contextData(Folder): |
class OSAS_add_contextData(Folder): |
"""Einfuegen eines Documentes in eine Collection""" |
"""Einfuegen eines Documentes in eine Collection""" |
|
|
Line 161 class OSAS_add_contextData(Folder):
|
Line 172 class OSAS_add_contextData(Folder):
|
|
|
meta_type='OSAS_add_contextData' |
meta_type='OSAS_add_contextData' |
|
|
|
def XmlToTree(self,URL): |
|
"""Collection XML to Tree""" |
|
|
|
|
|
class requestHandler(ContentHandler): |
|
def __init__(self): |
|
self.depth=0 |
|
self.retStr="" |
|
|
|
def startElement(self,name,attrs): |
|
if name=="element": |
|
self.depth+=1 |
|
self.retStr+=spaces(self.depth)+"<input type='checkbox' name='collection' value='%s'>%s</input>"%(attrs.get('url'),attrs.get('name'))+"<br>\n" |
|
|
|
|
|
|
|
def endElement(self,name): |
|
if name=="element": |
|
self.depth-=1 |
|
|
|
|
|
try: |
|
URL+="/getCollectionTreeXML" |
|
parser=make_parser() |
|
curHandler=requestHandler() |
|
parser.setContentHandler(curHandler) |
|
|
|
parser.parse(urllib.urlopen(URL)) |
|
return curHandler.retStr |
|
except: |
|
return urllib.urlopen(URL).read() |
|
|
def __init__(self,id,collection): |
def __init__(self,id,collection): |
self.id=id |
self.id=id |
self.collection=collection |
self.collection=collection |
|
|
def getChilds(self,id,depth,items): |
|
list=[] |
|
for object in items: |
|
if (depth==object[2])&(id==object[0]): |
|
list.append(object) |
|
return list |
|
|
|
def printChilds(self,startItem,depth,items,enddepth): |
|
|
|
def spaces(depth): |
|
tmp="" |
|
k=0 |
|
while k<2*depth: |
|
k+=1 |
|
tmp=tmp+" "+" " |
|
return tmp |
|
|
|
def retLink(object): |
def getPartners(self,URL): |
return "<input type='checkbox' name='collection' value='%s'>%s</input>"% (string.join(object.getPhysicalPath(),"."),object.title) |
"""Zeige Partnerliste""" |
|
class requestHandler(ContentHandler): |
|
def __init__(self): |
|
self.ret=[] |
|
|
|
def startElement(self,name,attrs): |
|
if name=="partner": |
|
self.ret.append((attrs.get('id'),attrs.get('title'))) |
|
|
depth+=1 |
|
childs=self.getChilds(startItem,depth,items) |
|
tmp="" |
|
for child in childs: |
|
if depth < enddepth: |
|
tmp=tmp+spaces(depth) |
|
|
|
tmp= tmp+retLink(child[1])+"<br>"+self.printChilds(child[1],depth,items,enddepth) |
|
else: |
|
tmp=tmp+spaces(2*depth) |
|
tmp = tmp+retLink(child[1]) |
|
|
|
return tmp |
URL+="/getPartnersXML" |
|
|
def generateTree(self,depth=10): |
try: |
"""Erzeugt HTML-Tree der Collection""" |
|
|
|
exec("items=self.getPhysicalRoot()."+self.collection+".getCollectionTree()") |
parser=make_parser() |
#print items[0][0] |
curHandler=requestHandler() |
|
parser.setContentHandler(curHandler) |
|
|
childs=self.printChilds(items[0][0],0,items,depth) |
parser.parse(urllib.urlopen(URL)) |
|
return curHandler.ret |
|
except: |
|
return [("",urllib.urlopen(URL).read())] |
|
|
return childs |
|
|
|
def getPartners(self): |
|
"""Zeige Partnerliste""" |
|
exec("items=self.getPhysicalRoot()."+self.collection+".partners.getPartners()") |
|
return items |
|
def addContextData(self,path): |
def addContextData(self,path): |
"""Hinzufügen zu einer Sammlung""" |
"""Hinzufügen zu einer Sammlung""" |
try: |
try: |
Line 231 class OSAS_add_contextData(Folder):
|
Line 254 class OSAS_add_contextData(Folder):
|
return pt() |
return pt() |
|
|
|
|
def addContextData2(self,path,collection,context,science,practice,source_type,period,link,label,description,content_type,responsible,weight,credits=None): |
def addContextData2(self,path,collection,context,link,label,description,content_type,responsible,weight,credits=None): |
"""Hinzufuegen der Resource""" |
"""Hinzufuegen der Resource""" |
splitted=path.split("/") |
splitted=path.split("/") |
#print "BLU" |
#print "BLU" |
Line 242 class OSAS_add_contextData(Folder):
|
Line 265 class OSAS_add_contextData(Folder):
|
#link=TOBEDONE" |
#link=TOBEDONE" |
"""Hinzufügen der Ressource""" |
"""Hinzufügen der Ressource""" |
|
|
|
params=urllib.urlencode({'id':id,'title':title,'link':link,'label':label,'description':description,'content_type':content_type,'responsible':responsible,'weight':weight,'credits':credits,'metalink':metalink}) |
|
|
exec("collection_object=self"+collection) |
retStr=urllib.urlopen(collection+"/addResource",params).read() |
|
if not retStr: |
|
return "An Error occured adding the resource\n" |
|
|
ECHO_collection.manage_addECHO_resource(collection_object,id,title,label,description,content_type,responsible,link,metalink,credits,weight,RESPONSE=None) |
urllib.urlopen(collection+"/"+id+"/ECHO_getResourceMD").read() |
|
#exec("collection_object=self"+collection) |
|
|
|
|
|
|
|
#ECHO_collection.manage_addECHO_resource(collection_object,id,title,label,description,content_type,responsible,link,metalink,credits,weight,RESPONSE=None) |
#print "HI5" |
#print "HI5" |
try: |
#try: |
getattr(collection_object,id).ECHO_getResourceMD() |
# getattr(collection_object,id).ECHO_getResourceMD() |
except: |
#except: |
"""nothing""" |
# """nothing""" |
#return "BLUByy" |
#return "BLUByy" |
return self.REQUEST.RESPONSE.redirect(self.REQUEST['URL2']+'?path='+path) |
return self.REQUEST.RESPONSE.redirect(self.REQUEST['URL2']+'?path='+path) |
|
|
Line 444 class OSAS_combineTextImage(Folder):
|
Line 475 class OSAS_combineTextImage(Folder):
|
OSAS_add.combineTextImage2(self,path) # Add images |
OSAS_add.combineTextImage2(self,path) # Add images |
splitted=path.split("/") |
splitted=path.split("/") |
linkPath=splitted[len(splitted)-1] |
linkPath=splitted[len(splitted)-1] |
linkViewerEnvironment="http://nausikaa2.mpiwg-berlin.mpg.de:86/cgi-bin/toc/toc.x.cgi?dir=%s&step=thumb" % linkPath |
linkViewerEnvironment="http://nausikaa2.mpiwg-berlin.mpg.de/cgi-bin/toc/toc.x.cgi?dir=%s&step=thumb" % linkPath |
self.REQUEST.SESSION['linkViewerEnvironment']=linkViewerEnvironment |
self.REQUEST.SESSION['linkViewerEnvironment']=linkViewerEnvironment |
|
|
writeToContext(path,linkViewerEnvironment,"ECHO standard environment") |
writeToContext(path,linkViewerEnvironment,"ECHO standard environment") |