version 1.23, 2004/04/02 17:38:40
|
version 1.27, 2004/04/14 21:26:23
|
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 urllib |
import urllib |
import OSAS_add |
import OSAS_add |
import OSAS_show |
import OSAS_show |
Line 62 class OSAS_add_Document(Folder):
|
Line 62 class OSAS_add_Document(Folder):
|
security.declarePublic('index_html') |
security.declarePublic('index_html') |
def index_html(self): |
def index_html(self): |
"""stantard aufruf""" |
"""stantard aufruf""" |
return OSAS_add.add(self,no_upload=1) |
return OSAS_add.add(self.standardMD,no_upload=1) |
|
|
|
|
security.declarePublic('add2') |
security.declarePublic('add2') |
def add2(self): |
def add2(self): |
""" anlegen naechster schritt""" |
""" anlegen naechster schritt""" |
return OSAS_add.add2(self) |
return OSAS_add.add2(self.standardMD) |
|
|
def add3(self): |
def add3(self): |
"""Foldername""" |
"""Foldername""" |
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['path'])[0] |
|
#metadata['folder_name']=self.REQUEST.SESSION['folder_name'] |
|
metadata['folder_name']=os.path.split(self.REQUEST.SESSION['path'])[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['path']+"/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 184 class OSAS_add_contextData(Folder):
|
Line 215 class OSAS_add_contextData(Folder):
|
def startElement(self,name,attrs): |
def startElement(self,name,attrs): |
if name=="element": |
if name=="element": |
self.depth+=1 |
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" |
begin="" |
|
end="" |
|
if self.depth==1: |
|
print "hi" |
|
begin="<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" |
|
|
|
|
|
|
Line 254 class OSAS_add_contextData(Folder):
|
Line 292 class OSAS_add_contextData(Folder):
|
return pt() |
return pt() |
|
|
|
|
def addContextData2(self,path,collection,context,link,label,description,content_type,responsible,weight,credits=None): |
def addContextData2(self,path,collection,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 265 class OSAS_add_contextData(Folder):
|
Line 303 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}) |
params=urllib.urlencode({'id':id,'title':title,'link':link,'label':label,'description':description,'contentType':content_type,'responsible':responsible,'weight':weight,'credits':credits,'metalink':metalink}) |
|
|
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" |
|
|
Line 428 class OSAS_combineTextImage(Folder):
|
Line 467 class OSAS_combineTextImage(Folder):
|
except: |
except: |
filelanguage="" |
filelanguage="" |
|
|
self.REQUEST.SESSION['isolist']=getISO() |
self.REQUEST.SESSION['isolist']=OSAS_add.getISO() |
tmp=getISO().keys() |
print "DD",self.REQUEST.SESSION['isolist'] |
|
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 478 class OSAS_combineTextImage(Folder):
|
Line 518 class OSAS_combineTextImage(Folder):
|
linkViewerEnvironment="http://nausikaa2.mpiwg-berlin.mpg.de/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",unique="yes") |
|
|
pt=PageTemplateFile('Products/OSA_system/zpt/AddOSAS_combineTextImageFinal.zpt').__of__(self) |
pt=PageTemplateFile('Products/OSA_system/zpt/AddOSAS_combineTextImageFinal.zpt').__of__(self) |
|
|
Line 492 class OSAS_combineTextImage(Folder):
|
Line 532 class OSAS_combineTextImage(Folder):
|
else: |
else: |
return None |
return None |
|
|
def writeToContext(path,link,description): |
def writeToContext(path,link,description,unique="no"): |
"""Created an additional entry to the index.meta file of path""" |
"""Created an additional entry to the index.meta file of path""" |
dom=xml.dom.minidom.parse(path+"/index.meta") |
dom=xml.dom.minidom.parse(path+"/index.meta") |
node=dom.getElementsByTagName('resource')[0] |
node=dom.getElementsByTagName('resource')[0] |
|
|
|
if unique=="yes": |
|
|
|
contexts=node.getElementsByTagName('context') |
|
for context in contexts: |
|
nameTag=getText(context.getElementsByTagName('name')[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) |
|
if (nameTag==description) and (linkTag==link): |
|
node.removeChild(context).unlink() |
|
|
subnode=dom.createElement('context') |
subnode=dom.createElement('context') |
|
|
linknode=dom.createElement('link') |
linknode=dom.createElement('link') |