version 1.26, 2004/04/06 10:55:16
|
version 1.33, 2004/06/22 06:39:04
|
Line 1
|
Line 1
|
# Methoden und Classen zum Hinzufuegen von Dokumenten |
# Methoden und Classen zum Hinzufuegen von Dokumenten |
|
|
|
|
from OSAS_helpers import readArchimedesXML, getISO, getText |
from OSAS_helpers import readArchimedesXML, getText |
import os |
import os |
import xml.dom.minidom |
import xml.dom.minidom |
import re |
import re |
Line 86 class OSAS_add_Document(Folder):
|
Line 86 class OSAS_add_Document(Folder):
|
"""write new index.meta file""" |
"""write new index.meta file""" |
return OSAS_add.add6(self) |
return OSAS_add.add6(self) |
|
|
|
def addText2(self): |
|
"""add only a text""" |
|
metadata=OSAS_add.parse_query_string(self.REQUEST['QUERY_STRING']) |
|
metadata['archive-creation-date']=OSAS_add.date(self) |
|
metadata['creator']=self.REQUEST['creator'] |
|
metadata['description']=self.REQUEST['content_description'] |
|
metadata['archive-path']=os.path.split(self.REQUEST.SESSION['pathnew'])[0] |
|
#metadata['folder_name']=self.REQUEST.SESSION['folder_name'] |
|
metadata['folder_name']=os.path.split(self.REQUEST.SESSION['pathnew'])[1] |
|
metadata['content-type']="fulltext document" |
|
self.reftype=self.REQUEST.SESSION['reftype'] |
|
self.REQUEST.SESSION['add_metadata']=metadata |
|
self.add_metadata=metadata |
|
self.metadata=self.REQUEST.SESSION['metadata'] |
|
self.metadataprint="" |
|
for tag in self.metadata.keys(): |
|
self.metadataprint=self.metadataprint+"<"+tag+">"+self.metadata[tag]+"</"+tag+">\n" |
|
|
|
newtemplate=PageTemplateFile('Products/OSA_system/zpt/index_meta').__of__(self) |
|
newtemplate.content_type="text/plain" |
|
renderxml = newtemplate() |
|
metapath=self.REQUEST.SESSION['pathnew']+"/index.meta" |
|
|
|
|
|
f=open(metapath,'w') |
|
f.writelines(renderxml) |
|
f.close() |
|
os.chmod(metapath,0664) |
|
os.popen('chmod -R 0775 %s'%self.add_metadata['archive-path']+"/"+self.add_metadata['folder_name']) |
|
|
|
return OSAS_add.addText2(self) |
|
|
def addImages(self,path): |
def addImages(self,path): |
"""Hinzufügen eines neuen Imagesfolders""" |
"""Hinzufügen eines neuen Imagesfolders""" |
Line 187 class OSAS_add_contextData(Folder):
|
Line 218 class OSAS_add_contextData(Folder):
|
begin="" |
begin="" |
end="" |
end="" |
if self.depth==1: |
if self.depth==1: |
print "hi" |
|
begin="<b>" |
begin="<b>" |
end="</b>" |
end="</b>" |
|
|
self.retStr+=spaces(self.depth)+"<input type='radio' name='collection' value='%s'>%s</input>"%(attrs.get('url'),begin+attrs.get('name')+end)+"<br>\n" |
self.retStr+=spaces(self.depth)+"<input type='radio' name='collection' value='%s'>%s</input>"%(attrs.get('url'),begin+urllib.unquote(attrs.get('name'))+end)+"<br>\n" |
|
|
|
|
|
|
Line 209 class OSAS_add_contextData(Folder):
|
Line 239 class OSAS_add_contextData(Folder):
|
parser.parse(urllib.urlopen(URL)) |
parser.parse(urllib.urlopen(URL)) |
return curHandler.retStr |
return curHandler.retStr |
except: |
except: |
|
return URL |
return urllib.urlopen(URL).read() |
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 |
Line 240 class OSAS_add_contextData(Folder):
|
Line 272 class OSAS_add_contextData(Folder):
|
parser.parse(urllib.urlopen(URL)) |
parser.parse(urllib.urlopen(URL)) |
return curHandler.ret |
return curHandler.ret |
except: |
except: |
return [("",urllib.urlopen(URL).read())] |
return [("",URL)] |
|
|
|
|
def addContextData(self,path): |
def addContextData(self,path): |
"""Hinzufügen zu einer Sammlung""" |
"""Hinzufuegen zu einer Sammlung""" |
try: |
try: |
urllib.urlopen(self.REQUEST['SERVER_URL']+path+"/index.meta") |
urllib.urlopen(self.REQUEST['SERVER_URL']+path+"/index.meta") |
|
|
Line 253 class OSAS_add_contextData(Folder):
|
Line 285 class OSAS_add_contextData(Folder):
|
|
|
links=[(path,'standard storage')] |
links=[(path,'standard storage')] |
|
|
links+=OSAS_show.readContexts(path) # auslesen von contexten für den link |
links+=OSAS_show.readContexts(path) # auslesen von contexten fuer den link |
#print "LINK",links |
#print "LINK",links |
#return links |
#return links |
self.REQUEST.SESSION['links']=links |
self.REQUEST.SESSION['links']=links |
Line 274 class OSAS_add_contextData(Folder):
|
Line 306 class OSAS_add_contextData(Folder):
|
|
|
params=urllib.urlencode({'id':id,'title':title,'link':link,'label':label,'description':description,'contentType':content_type,'responsible':responsible,'weight':weight,'credits':credits,'metalink':metalink}) |
params=urllib.urlencode({'id':id,'title':title,'link':link,'label':label,'description':description,'contentType':content_type,'responsible':responsible,'weight':weight,'credits':credits,'metalink':metalink}) |
|
|
|
print params |
|
|
retStr=urllib.urlopen(collection+"/addResource",params).read() |
retStr=urllib.urlopen(collection+"/addResource",params).read() |
return retStr |
|
if not retStr: |
if not retStr: |
return "An Error occured adding the resource\n" |
return "An Error occured adding the resource\n" |
|
|
urllib.urlopen(collection+"/"+id+"/ECHO_getResourceMD").read() |
|
#exec("collection_object=self"+collection) |
|
|
|
|
|
|
print urllib.urlopen(collection+"/"+id+"/copyIndex_meta2echo_resource").read() |
|
print urllib.urlopen(collection+"/"+id+"/generate_label").read() |
|
print urllib.urlopen(collection+"/"+id+"/generate_title").read() |
|
|
#ECHO_collection.manage_addECHO_resource(collection_object,id,title,label,description,content_type,responsible,link,metalink,credits,weight,RESPONSE=None) |
|
#print "HI5" |
|
#try: |
|
# getattr(collection_object,id).ECHO_getResourceMD() |
|
#except: |
|
# """nothing""" |
|
#return "BLUByy" |
|
return self.REQUEST.RESPONSE.redirect(self.REQUEST['URL2']+'?path='+path) |
return self.REQUEST.RESPONSE.redirect(self.REQUEST['URL2']+'?path='+path) |
|
|
manage_options = Folder.manage_options+( |
manage_options = Folder.manage_options+( |
Line 436 class OSAS_combineTextImage(Folder):
|
Line 463 class OSAS_combineTextImage(Folder):
|
except: |
except: |
filelanguage="" |
filelanguage="" |
|
|
self.REQUEST.SESSION['isolist']=getISO() |
self.REQUEST.SESSION['isolist']=OSAS_add.getISO() |
tmp=getISO().keys() |
|
|
tmp=self.REQUEST.SESSION['isolist'].keys() |
tmp.sort() |
tmp.sort() |
self.REQUEST.SESSION['isolistsort']=tmp |
self.REQUEST.SESSION['isolistsort']=tmp |
self.REQUEST.SESSION['path']=path |
self.REQUEST.SESSION['path']=path |
Line 450 class OSAS_combineTextImage(Folder):
|
Line 478 class OSAS_combineTextImage(Folder):
|
newtemplate=PageTemplateFile('Products/OSA_system/zpt/ImageandText').__of__(self) |
newtemplate=PageTemplateFile('Products/OSA_system/zpt/ImageandText').__of__(self) |
return newtemplate() |
return newtemplate() |
|
|
def getProjects(self,obj_ids=None): |
def getViewerTemplateSets(self,obj_ids=None): |
"""Get the Project title for configuration""" |
"""Get the ViewerTemplateSet title for configuration""" |
ret=[] |
ret=[] |
print "HI" |
viewerTemplateSets=self.ZopeFind(self.viewerTemplateSets,obj_metatypes=['OSAS_viewerTemplateSet'],obj_ids=obj_ids)#assumes viewerTemplateSets folder somewhere in the hierarchie. |
|
|
try: |
try: |
projects=self.ZopeFind(self.projects,obj_metatypes=['OSAS_project'],obj_ids=obj_ids)#assumes projects folder somewhere in the hierarchie. |
viewerTemplateSets=self.ZopeFind(self.viewerTemplateSets,obj_metatypes=['OSAS_viewerTemplateSet'],obj_ids=obj_ids)#assumes viewerTemplateSets folder somewhere in the hierarchie. |
print "pr" |
|
for project in projects: |
for viewerTemplateSet in viewerTemplateSets: |
ret.append((project[1].title,project[0],project[1])) |
ret.append((viewerTemplateSet[1].title,viewerTemplateSet[0],viewerTemplateSet[1])) |
print ret |
|
return ret |
return ret |
|
|
except: |
except: |
return [('no Projectfolders','')] |
return [('no ViewerTemplateSetfolders','')] |
|
|
def getTextToolsField(self,path,name,default=''): |
def getTextToolsField(self,path,name,default=''): |
"""Lese Textoolsfelder aus index.meta im path aus""" |
"""Lese Textoolsfelder aus index.meta im path aus""" |
Line 472 class OSAS_combineTextImage(Folder):
|
Line 501 class OSAS_combineTextImage(Folder):
|
dom=xml.dom.minidom.parse(path+"/index.meta") |
dom=xml.dom.minidom.parse(path+"/index.meta") |
node=dom.getElementsByTagName('texttool')[0] #getNode |
node=dom.getElementsByTagName('texttool')[0] #getNode |
subnode=node.getElementsByTagName(name)[0] |
subnode=node.getElementsByTagName(name)[0] |
print getText(subnode.childNodes) |
|
|
# bei text wird nur der Folder gebraucht |
|
if name=="text": |
|
splitted=getText(subnode.childNodes).split("/") |
|
return splitted[len(splitted)-2] |
|
else: |
return getText(subnode.childNodes) |
return getText(subnode.childNodes) |
except: |
except: |
return default |
return default |
Line 483 class OSAS_combineTextImage(Folder):
|
Line 517 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/cgi-bin/toc/toc.x.cgi?dir=%s&step=thumb" % linkPath |
linkViewerEnvironmentImages="http://nausikaa2.mpiwg-berlin.mpg.de/cgi-bin/toc/toc.x.cgi?dir=%s&step=thumb" % linkPath |
|
linkViewerEnvironmentOnlyText="http://nausikaa2.mpiwg-berlin.mpg.de/cgi-bin/toc/toc.x.cgi?dir=%s&step=textonly" % linkPath |
|
|
|
if self.REQUEST.has_key('image'): # bilder vorhanden |
|
linkViewerEnvironment=linkViewerEnvironmentImages |
|
else: |
|
linkViewerEnvironment=linkViewerEnvironmentOnlyText |
|
|
self.REQUEST.SESSION['linkViewerEnvironment']=linkViewerEnvironment |
self.REQUEST.SESSION['linkViewerEnvironment']=linkViewerEnvironment |
|
|
writeToContext(path,linkViewerEnvironment,"ECHO standard environment",unique="yes") |
writeToContext(path,linkViewerEnvironment,"ECHO standard environment",unique="yes") |
Line 492 class OSAS_combineTextImage(Folder):
|
Line 533 class OSAS_combineTextImage(Folder):
|
|
|
return pt() |
return pt() |
|
|
def isSelectedProject(self,obj,id): |
def isSelectedViewerTemplateSet(self,obj,id): |
"""is ausgewählt""" |
"""is ausgewählt""" |
|
|
if self.REQUEST['project']==id: |
if self.REQUEST['viewerTemplateSet']==id: |
return 1 |
return 1 |
else: |
else: |
return None |
return None |
Line 512 def writeToContext(path,link,description
|
Line 553 def writeToContext(path,link,description
|
nameTag=getText(context.getElementsByTagName('name')[0].childNodes) |
nameTag=getText(context.getElementsByTagName('name')[0].childNodes) |
linkTag=getText(context.getElementsByTagName('link')[0].childNodes) |
linkTag=getText(context.getElementsByTagName('link')[0].childNodes) |
|
|
print "unique",context,nameTag,description,linkTag,link |
|
linkTag=re.sub("\:86","",linkTag) # alter port 86 gleich ohne port nummer (hack) |
linkTag=re.sub("\:86","",linkTag) # alter port 86 gleich ohne port nummer (hack) |
if (nameTag==description) and (linkTag==link): |
if (nameTag==description) and (linkTag==link): |
node.removeChild(context).unlink() |
node.removeChild(context).unlink() |