version 1.187, 2004/10/28 13:38:40
|
version 1.193, 2004/11/29 21:55:29
|
Line 9 class ECHO_externalLink contains informa
|
Line 9 class ECHO_externalLink contains informa
|
|
|
|
|
""" |
""" |
|
from reportlab.pdfgen import canvas |
|
from reportlab.lib.pagesizes import A4 |
|
|
|
|
|
|
import string |
import string |
|
import tempfile |
import re |
import re |
import os |
import os |
import OFS.Image |
import OFS.Image |
Line 29 from Products.PageTemplates.PageTemplate
|
Line 35 from Products.PageTemplates.PageTemplate
|
from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate |
from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate |
from Globals import Persistent, package_home |
from Globals import Persistent, package_home |
from Acquisition import Implicit |
from Acquisition import Implicit |
from ECHO_helpers import * |
|
import urllib |
import urllib |
import smtplib |
import smtplib |
import time |
import time |
Line 55 import urllib
|
Line 61 import urllib
|
import xml.dom.minidom |
import xml.dom.minidom |
from ECHO_graphicalOverview import javaHandler,javaScriptMain |
from ECHO_graphicalOverview import javaHandler,javaScriptMain |
import ECHO_helpers |
import ECHO_helpers |
|
from ECHO_helpers import * |
|
from ECHO_language import * |
|
|
def donatus(txt2): |
|
import xmlrpclib |
|
|
|
server = xmlrpclib.ServerProxy("http://archimedes.fas.harvard.edu/cgi-bin/donatus-rpc") |
|
|
|
txt=txt2.encode('utf-8') |
|
bin=xmlrpclib.Binary(txt) |
|
|
|
|
|
|
|
ret=server.donatus.analyze(bin) |
|
|
|
|
|
return ret['morphData'].data |
|
|
|
|
|
def donatusVariant2Lemma(morphData): |
|
"""creates hash variant -> morphdata""" |
|
ret={} |
|
dom=xml.dom.minidom.parseString(morphData) |
|
lemmas=dom.getElementsByTagName('lemma') |
|
for lemma in lemmas: |
|
variants=lemma.getElementsByTagName('variant') |
|
for variant in variants: |
|
atr=variant.getAttribute('form') |
|
if ret.has_key(atr): |
|
ret[atr].append=lemma.getAttribute('form') |
|
else: |
|
ret[atr]=[lemma.getAttribute('form')] |
|
|
|
return ret |
|
|
|
#regexp for extracting elements from xml |
#regexp for extracting elements from xml |
patternTXT=r"<\s*txt.*?>(.*?)</txt>" |
patternTXT=r"<\s*txt.*?>(.*?)</txt>" |
Line 95 patternPage=r"<\s*page.*?>(.*?)</page>"
|
Line 72 patternPage=r"<\s*page.*?>(.*?)</page>"
|
regexpPage = re.compile(patternPage, re.IGNORECASE + re.DOTALL) |
regexpPage = re.compile(patternPage, re.IGNORECASE + re.DOTALL) |
|
|
|
|
def ECHO_rerenderLinksMD(self,obj=None,types=['title','label']): |
|
"""Rerender all Links""" |
|
ret="" |
|
|
|
if not obj: |
|
obj = self |
|
|
|
entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_resource'],search_sub=1) |
|
|
|
for entry in entries: |
|
if entry[1].meta_type == 'ECHO_resource': |
|
try: |
|
entry[1].ECHO_getResourceMD(template="no") |
|
if "title" in types: |
|
entry[1].generate_title() |
|
if "label" in types: |
|
entry[1].generate_label() |
|
ret+="OK:"+entry[0]+"-- "+entry[1].getTitle().decode('utf-8')+"-- "+entry[1].getTitle().decode('utf-8')+"<br>" |
|
except: |
|
ret+="Error:"+entry[0]+"<br>" |
|
|
|
|
|
|
|
|
|
return "<html><body>"+ret+"Rerenderd all links to resources in: "+self.title+"</html></body>" |
|
|
|
def reloadMetaDataFromStorage(self,RESPONSE=None): |
|
"""copy metadata from the storage to ECHO""" |
|
ret="" |
|
resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'],search_sub=1) |
|
|
|
for resource in resources: |
|
x=str(resource[1].copyIndex_meta2echo_resource())+"<br>" |
|
ret+=x |
|
#print x |
|
|
|
|
|
if RESPONSE is not None: |
|
#RESPONSE.redirect('./manage_main') |
|
return "<html><body>"+ret+"</html></body>" |
|
|
|
return ret |
|
|
|
def getRDFDescription(self,linkURL,urn=None,nameDef=None,typeName=None): |
|
"""rdf""" |
|
|
|
ret="" |
|
about="""<RDF:Description RDF:about="%s">""" |
|
name="""<ECHONAVIGATION:name>%s</ECHONAVIGATION:name>""" |
|
link="""<ECHONAVIGATION:link xlink:href="%s">%s</ECHONAVIGATION:link>""" |
|
clickable="""<ECHONAVIGATION:linkClickable>%s</ECHONAVIGATION:linkClickable>""" |
|
#link="""<ECHONAVIGATION:link RDF:about="%s"/>""" |
|
type="""<ECHONAVIGATION:type>%s</ECHONAVIGATION:type>""" |
|
#xlink="""<ECHONAVIGATION:xlink xlink:href="%s"/>""" |
|
if not urn: |
|
#urn="urn:"+re.sub('/',':',self.absolute_url()) |
|
urn=self.absolute_url() |
|
about2=about%urn |
|
if not nameDef: |
|
if hasattr(self,'label') and not (self.label==""): |
|
name2=name%self.label |
|
elif not self.title=="": |
|
name2=name%self.title |
|
else: |
|
name2=name%self.getId() |
|
|
|
name2=re.sub('&','&',name2) |
|
else: |
|
name2=name%nameDef |
|
|
|
linkURL=re.sub('http:','',linkURL) |
|
linkURL2=re.sub('&','&',linkURL) |
|
link2=link%(("http:"+linkURL2),("http:"+urllib.quote(linkURL))) |
|
clickable2=clickable%"true" |
|
|
|
if not typeName: |
|
type2=type%self.meta_type |
|
else: |
|
type2=type%typeName |
|
|
|
#ret=about2+"\n"+name2+"\n"+link2+"\n"+type2+"\n"+clickable2+"\n</RDF:Description>" |
|
ret=about2+"\n"+name2+"\n"+type2+"\n"+clickable2+"\n</RDF:Description>" |
|
return ret |
|
|
|
def getCopyrightsFromForm(self,argv): |
|
medias={} |
|
partners={} |
|
copyrights={} |
|
|
|
copyrightsFinal=[] |
|
for arg in argv.keys(): |
|
|
|
if arg[0:5]=='media': |
|
nm=int(arg[5:]) |
|
medias[nm]=argv[arg] |
|
elif arg[0:5]=='partn': |
|
nm=int(arg[5:]) |
|
partners[nm]=argv[arg] |
|
elif arg[0:5]=='copyr': |
|
nm=int(arg[5:]) |
|
copyrights[nm]=argv[arg] |
|
|
|
|
|
|
|
copyrightsList=[(medias[nm],partners[nm],copyrights[nm]) for nm in medias.keys()] |
|
for copyright in copyrightsList: |
|
|
|
if copyright[2]=='institution0000': |
|
copyrightsFinal.append((copyright[0],copyright[1],self.getPartnerCopyright(copyright[1],''))) |
|
else: |
|
if not copyright[0]=='': |
|
copyrightsFinal.append(copyright) |
|
|
|
|
|
return copyrightsFinal |
|
|
|
#List of different types for the graphical linking viewer |
|
viewClassificationListMaster=['view point','area'] |
|
|
|
|
|
def checkDiffs(self,metadict): |
|
"""check differences""" |
|
|
|
|
|
|
|
|
|
def NoneToEmpty(obj): |
|
if obj: |
|
return obj |
|
else: |
|
return "" |
|
|
|
|
|
|
|
diffs={} |
|
|
|
tags=self.findTagsFromMapping(self.contentType) |
|
self.referencetypes=tags[2] |
|
self.fields=tags[3] |
|
|
|
|
|
for field in tags[1]: |
|
try: |
|
if (NoneToEmpty(self.getFieldValue(self.getFieldTag(tags,field)))==metadict[self.getFieldTag(tags,field)]): |
|
diffs[self.getFieldTag(tags,field)]=1 |
|
else: |
|
|
|
diffs[self.getFieldTag(tags,field)]=0 |
|
except: |
|
diffs[self.getFieldTag(tags,field)]=0 |
|
|
|
return diffs |
|
|
|
def content_html(self,type): |
|
"""template fuer content""" |
|
#templates = self.ZopeFind(self.aq_parent,obj_ids=[type+"_template"]) |
|
# |
|
#if templates: |
|
# return templates[0][1]() |
|
|
|
if hasattr(self,type+"_template"): |
|
obj=getattr(self,type+"_template") |
|
return obj() |
|
else: |
|
pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_%s_template_standard.zpt'%type).__of__(self) |
|
pt.content_type="text/html" |
|
return pt() |
|
|
|
|
|
|
|
|
|
def getTextFromNode(nodename): |
|
nodelist=nodename.childNodes |
|
rc = "" |
|
for node in nodelist: |
|
if node.nodeType == node.TEXT_NODE: |
|
rc = rc + node.data |
|
return rc |
|
|
|
def sendFile(self, filename, type): |
|
"""sends an object or a local file (in the product) as response""" |
|
paths = filename.split('/') |
|
object = self |
|
# look for an object called filename |
|
for path in paths: |
|
if hasattr(object, path): |
|
object = getattr(object, path) |
|
else: |
|
object = None |
|
break |
|
if object: |
|
# if the object exists then send it |
|
return object.index_html(self.REQUEST.REQUEST, self.REQUEST.RESPONSE) |
|
else: |
|
# send a local file with the given content-type |
|
fn = os.path.join(package_home(globals()), filename) |
|
self.REQUEST.RESPONSE.setHeader("Content-Type", type) |
|
self.REQUEST.RESPONSE.write(file(fn).read()) |
|
return |
|
|
|
class BrowserCheck: |
|
"""check the browsers request to find out the browser type""" |
|
|
|
def __init__(self, zope): |
|
self.ua = zope.REQUEST.get_header("HTTP_USER_AGENT") |
|
self.isN4 = (string.find(self.ua, 'Mozilla/4.') > -1) and (string.find(self.ua, 'MSIE') < 0) |
|
self.isIE = string.find(self.ua, 'MSIE') > -1 |
|
self.nav = self.ua[string.find(self.ua, '('):] |
|
ie = string.split(self.nav, "; ")[1] |
|
if string.find(ie, "MSIE") > -1: |
|
self.versIE = string.split(ie, " ")[1] |
|
self.isMac = string.find(self.ua, 'Macintosh') > -1 |
|
self.isWin = string.find(self.ua, 'Windows') > -1 |
|
self.isIEWin = self.isIE and self.isWin |
|
self.isIEMac = self.isIE and self.isMac |
|
|
|
|
|
|
|
|
|
def writeMetadata(url,metadict,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None,xmlfrag=None,digiliburlprefix=None): |
|
"""Einlesen der Metadaten und und erstellen des geaenderten XML file""" |
|
|
|
def updateTextToolNode(tag,value): |
|
#print dom,tag,value |
|
metanode=dom.getElementsByTagName('texttool')[0] |
|
try: |
|
nodeOld=metanode.getElementsByTagName(tag) |
|
except: |
|
nodeOld=None |
|
|
|
if nodeOld: |
|
metanode.removeChild(nodeOld[0]).unlink() |
|
|
|
node=dom.createElement(tag) |
|
nodetext=dom.createTextNode(value) |
|
node.appendChild(nodetext) |
|
metanode.appendChild(node) |
|
|
|
if xmlfrag: |
|
geturl="""<?xml version="1.0" ?> |
|
<resource type="MPIWG"> |
|
<meta> |
|
<bib type="Book"> |
|
</bib> |
|
</meta> |
|
</resource>""" |
|
dom=xml.dom.minidom.parseString(geturl) |
|
else: |
|
try: |
|
geturl="" |
|
for line in ECHO_helpers.urlopen(url).readlines(): |
|
geturl=geturl+line |
|
|
|
|
|
except: |
|
return (None,"Cannot open: "+url) |
|
|
|
try: |
|
dom=xml.dom.minidom.parseString(geturl) |
|
except: |
|
return (None,"Cannot parse: "+url+"<br>"+geturl) |
|
|
|
|
|
|
|
metanodes=dom.getElementsByTagName('bib') |
|
|
|
if not metanodes: |
|
metanodes=dom.getElementsByTagName('archimedes') |
|
|
|
metanode=metanodes[0] |
|
|
|
for metaData in metadict.keys(): |
|
|
|
try: |
|
nodeOld=metanode.getElementsByTagName(metaData) |
|
except: |
|
nodeOld=None |
|
|
|
if nodeOld: |
|
metanode.removeChild(nodeOld[0]).unlink() |
|
else: |
|
# try also old writing rule - instead of _: |
|
try: |
|
nodeOld=metanode.getElementsByTagName(re.sub('_','-',metaData)) |
|
except: |
|
nodeOld=None |
|
|
|
if nodeOld: |
|
metanode.removeChild(nodeOld[0]).unlink() |
|
|
|
metanodeneu=dom.createElement(metaData) |
|
metanodetext=dom.createTextNode(metadict[metaData]) |
|
#try: |
|
#metanodetext=dom.createTextNode(unicode(metadict[metaData],"utf-8")) |
|
#except: |
|
#metanodetext=dom.createTextNode(metadict[metaData].encode('utf-8')) |
|
metanodeneu.appendChild(metanodetext) |
|
metanode.appendChild(metanodeneu) |
|
|
|
|
|
|
|
|
|
|
|
if project: |
|
updateTextToolNode('project',project) |
|
|
|
if startpage: |
|
updateTextToolNode('startpage',startpage) |
|
|
|
if topbar: |
|
updateTextToolNode('toptemplate',topbar) |
|
|
|
if thumbtemplate: |
|
updateTextToolNode('thumbtemplate',thumbtemplate) |
|
|
|
if xslt: |
|
updateTextToolNode('xslt',xslt) |
|
|
|
|
|
if digiliburlprefix: |
|
updateTextToolNode('digiliburlprefix',digiliburlprefix) |
|
|
|
try: |
|
return dom.toxml().encode('utf-8') |
|
except: |
|
return dom.toxml('utf-8') |
|
|
|
|
|
|
|
def readMetadata(url): |
|
"""Methode zum Auslesen der Metadateninformation zu einer Resource |
|
Vorerst noch Typ bib""" |
|
|
|
metadict={} |
|
try: |
|
geturl="" |
|
for line in ECHO_helpers.urlopen(url).readlines(): |
|
geturl=geturl+line |
|
|
|
|
|
except: |
|
return (None,"Cannot open: "+url) |
|
|
|
try: |
|
dom=xml.dom.minidom.parseString(geturl) |
|
except: |
|
return (None,"Cannot parse: "+url+"<br>"+geturl) |
|
|
|
metanode=dom.getElementsByTagName('bib') |
|
metadict['bib_type']='Book' |
|
if len(metanode)==0: |
|
metanode=dom.getElementsByTagName('archimedes') |
|
metadict['bib_type']='Archimedes' |
|
|
|
|
|
if not len(metanode)==0: |
|
metacontent=metanode[0].childNodes |
|
|
|
try: |
|
metadict['bib_type']=getText(dom.getElementsByTagName('bib')[0].attributes['type'].childNodes) |
|
except: |
|
"""nothing""" |
|
|
|
for node in metacontent: |
|
try: |
|
#print urllib.unquote(getText(node.childNodes)),getText(node.childNodes) |
|
metadict[re.sub('-','_',node.tagName.lower())]=urllib.unquote(getText(node.childNodes)) |
|
except: |
|
"""nothing""" |
|
|
|
|
|
return metadict,"" |
|
|
|
|
|
def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs,viewClassification=""): |
def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs,viewClassification=""): |
|
|
Line 500 def setECHO_collectionInformation(self,t
|
Line 104 def setECHO_collectionInformation(self,t
|
|
|
self.coords=coords[0:] |
self.coords=coords[0:] |
|
|
class ECHO_copyright(Folder): |
class ECHO_copyright(Folder,ECHO_basis): |
"""Copyright informationen""" |
"""Copyright informationen""" |
meta_type="ECHO_copyright" |
meta_type="ECHO_copyright" |
|
|
Line 556 def manage_addECHO_copyright(self, id,ti
|
Line 160 def manage_addECHO_copyright(self, id,ti
|
if RESPONSE is not None: |
if RESPONSE is not None: |
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
class ECHO_layoutTemplate(ZopePageTemplate): |
class ECHO_layoutTemplate(ZopePageTemplate,ECHO_basis): |
"""Create a layout Template for different purposes""" |
"""Create a layout Template for different purposes""" |
|
|
meta_type="ECHO_layoutTemplate" |
meta_type="ECHO_layoutTemplate" |
Line 624 def manage_addECHO_layoutTemplate(self,
|
Line 228 def manage_addECHO_layoutTemplate(self,
|
REQUEST.RESPONSE.redirect(u+'/manage_main') |
REQUEST.RESPONSE.redirect(u+'/manage_main') |
return '' |
return '' |
|
|
class ECHO_fullText(ZopePageTemplate): |
class ECHO_fullText(ZopePageTemplate,ECHO_basis,ECHO_language): |
"""echo fulltext in xml""" |
"""echo fulltext in xml""" |
|
|
meta_type="ECHO_fullText" |
meta_type="ECHO_fullText" |
|
|
def donatusVariant2Lemma(self,nr='1'): |
|
"""analyze by donatus""" |
|
return donatusVariant2Lemma(donatus(self.lemmatize(nr))) |
|
|
|
def tagLex(self,nr="1"): |
|
"""generate Links""" |
|
global retLex |
|
global toggle |
|
|
|
toggle=0 |
|
retLex="" |
|
|
|
lemmatized=self.lemmatize(nr)[0:] |
|
#print "ho",repr(lemmatized) |
|
variants=donatusVariant2Lemma(donatus(lemmatized)) |
|
|
|
def createTag(name,attrs): |
|
global toggle |
|
|
|
if name=="w": |
|
toggle=1 |
|
return "" |
|
else: |
|
tag="<" |
|
tag+=name |
|
for attr in attrs.keys(): |
|
tag+=""" %s="%s" """%(attr,attrs[attr]) |
|
tag+=">" |
|
return tag |
|
|
|
def createData(data): |
|
global toggle |
|
astring="""<a href="http://141.14.236.86/cgi-bin/toc/dict?step=remotetable;word=%s;lang=de" target="_blank">%s</a> """ |
|
if toggle: # tag war ein w |
|
toggle=0 |
|
if variants.has_key(data): |
|
return astring%(variants[data][0],data) |
|
else: |
|
return astring%(data,data) |
|
|
|
|
|
|
|
# 3 handler functions |
|
def start_element(name, attrs): |
|
global retLex |
|
|
|
retLex+=createTag(name,attrs) |
|
def end_element(name): |
|
global retLex |
|
if not name=="w": |
|
retLex+="</%s>"%(name.encode('utf-8')) |
|
|
|
|
|
def char_data(data): |
|
global retLex |
|
if data: |
|
try: |
|
retLex+=createData(data) |
|
except: |
|
"""no""" |
|
|
|
p = xml.parsers.expat.ParserCreate() |
|
|
|
p.StartElementHandler = start_element |
|
p.EndElementHandler = end_element |
|
p.CharacterDataHandler = char_data |
|
|
|
p.Parse(lemmatized.encode('utf-8'),1) |
|
#print repr(lemmatized.encode('utf-8')) |
|
|
|
return retLex |
|
|
|
|
|
def lemmatize(self,nr='1',lang="de"): |
|
"""lemmatize""" |
|
global ret |
|
ret="" |
|
|
|
def createTag(name,attrs): |
|
tag="<" |
|
tag+=name |
|
for attr in attrs.keys(): |
|
tag+=""" %s="%s" """%(attr,attrs[attr]) |
|
tag+=">" |
|
return tag |
|
|
|
def insertW(str): |
|
splitted=str.split() |
|
wordlist=["<w>%s</w>"%split for split in splitted] |
|
return string.join(wordlist,'\n') |
|
|
|
# 3 handler functions |
|
def start_element(name, attrs): |
|
global ret |
|
ret+=createTag(name,attrs) |
|
def end_element(name): |
|
global ret |
|
ret+="</%s>"%(name.encode('utf-8')) |
|
|
|
def char_data(data): |
|
global ret |
|
ret+=insertW(data) |
|
|
|
p = xml.parsers.expat.ParserCreate() |
|
|
|
p.StartElementHandler = start_element |
|
p.EndElementHandler = end_element |
|
p.CharacterDataHandler = char_data |
|
|
|
p.Parse(self.getPage(nr), 1) |
|
txt="""<wtag locator="xxx"> |
|
<section lang="%s"><s>%s</s></section> |
|
</wtag>""" |
|
ret=txt%(lang,ret) |
|
|
|
return ret |
|
|
|
def getPage(self,nr='1'): |
def getPage(self,nr='1'): |
"""get page n""" |
"""get page n""" |
Line 790 def manage_addECHO_fullText(self, id, ti
|
Line 278 def manage_addECHO_fullText(self, id, ti
|
REQUEST.RESPONSE.redirect(u+'/manage_main') |
REQUEST.RESPONSE.redirect(u+'/manage_main') |
return '' |
return '' |
|
|
class ECHO_resource(Folder,Persistent): |
|
|
class ECHO_resource(Folder,Persistent,ECHO_basis): |
"""ECHO Ressource""" |
"""ECHO Ressource""" |
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
meta_type='ECHO_resource' |
meta_type='ECHO_resource' |
Line 801 class ECHO_resource(Folder,Persistent):
|
Line 290 class ECHO_resource(Folder,Persistent):
|
|
|
security.declareProtected('View','index_html') |
security.declareProtected('View','index_html') |
|
|
def showRDF(self): |
|
"""showrdf""" |
|
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
|
ret="""<?xml version="1.0" encoding="utf-8"?>\n<RDF:RDF xmlns:RDF="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:ECHONAVIGATION="http://www.echo.eu/rdf#">\n""" |
|
ret+=self.getRDF(urn="echo:colllectionroot")+"\n" |
|
|
|
ret+="""</RDF:RDF>""" |
|
return ret |
|
|
|
def getRDF(self,urn=None): |
security.declareProtected('View','createPDF') |
"""rdf""" |
def createPDF(self,RESPONSE=None,local=None,dpi=150): |
ret=getRDFDescription(self,self.link,urn=urn) |
"""erzeuge pdf file""" |
return ret+self.createSubElementRDF(urn=urn) |
pages=1 |
|
dpi=float(dpi) |
|
imagePath=self.getImagePath().replace("/mpiwg/online","") |
|
|
|
|
def createSubElementRDF(self,urn=None): |
image="http://nausikaa2.mpiwg-berlin.mpg.de/digitallibrary/servlet/Scaler?fn="+imagePath+"&dw=%i&dh=%i&pn=%i" |
"""rdf list""" |
xmlInfo="http://nausikaa2.mpiwg-berlin.mpg.de/digitallibrary/dlInfo-xml.jsp?fn="+imagePath |
if not urn: |
|
urn=self.absolute_url() |
dom=xml.dom.minidom.parse(urllib.urlopen(xmlInfo)) |
ret="" |
for parameter in dom.getElementsByTagName('parameter'): |
|
if parameter.getAttribute('name')=="pt": |
|
pages=int(parameter.getAttribute('value')) |
|
break |
|
|
rettemp="""<RDF:Seq RDF:about="%s">\n"""%urn |
tempdir="/tmp/archivesImageServer" |
flag=0 |
if not os.path.exists(tempdir): |
|
os.mkdir(tempdir) |
|
|
li="""<RDF:li RDF:resource="%s" />\n""" |
tmpPath=tempfile.mkdtemp(dir=tempdir) |
if not ('<error>' in self.getFullTextXML(noredirect='Yes')): |
|
nurn=self.absolute_url()+'/getFullTextXML' |
|
rettemp+=li%nurn |
tmpZip=tempfile.mktemp(dir=tempdir) |
flag=1 |
|
if not ('<error>' in self.getImageView(noredirect='Yes')): |
tmpFn=os.path.split(tmpZip)[1] |
nurn=self.absolute_url()+'/getImageView' |
|
rettemp+=li%nurn |
|
flag=1 |
|
|
|
|
|
if not ('<error>' in self.showMetaDataXML()): |
if RESPONSE: |
nurn=self.absolute_url()+'/showMetaDataXML' |
RESPONSE.setHeader("Content-Type","text/html") |
rettemp+=li%nurn |
RESPONSE.write("<h1>I am creating the pdf</h1>") |
flag=1 |
txt="<h3>1. step: getting the images( %i pages)</h3>"%pages |
|
RESPONSE.write(txt) |
rettemp+="</RDF:Seq>" |
|
|
c=canvas.Canvas(tmpZip) |
if flag==1: |
for i in range(1,pages+1): |
ret+=rettemp |
if RESPONSE: |
|
RESPONSE.write(str("<p>Get Page: %i<br>\n"%i)) |
if not ('<error>' in self.getFullTextXML(noredirect='Yes')): |
faktor=dpi/72.0 |
nurn=self.absolute_url()+'/getFullTextXML' |
|
ret+=getRDFDescription(self,self.absolute_url()+'/getFullTextXML',urn=nurn,nameDef="Fulltext",typeName="ECHO_fulltext") |
fn=tmpPath+"/%i"%i |
|
|
if not ('<error>' in self.getImageView(noredirect='Yes')): |
width,height=A4 |
nurn=self.absolute_url()+'/getImageView' |
#print image%(width*faktor,height*faktor,i) |
ret+=getRDFDescription(self,self.absolute_url()+'/getImageView',urn=nurn,nameDef="Image View",typeName="ECHO_imageview") |
url=urllib.urlopen(image%(width*faktor,height*faktor,i)).read() |
|
fh=file(fn,"w") |
if not ('<error>' in self.showMetaDataXML()): |
fh.write(url) |
nurn=self.absolute_url()+'/showMetaDataXML' |
fh.close() |
ret+=getRDFDescription(self,self.absolute_url()+'/showMetaDataXML',urn=nurn,nameDef="Metadata",typeName="ECHO_metaData") |
|
|
|
|
|
|
c.drawImage(fn,0,0,width=width,height=height) |
|
c.showPage() |
|
c.save() |
|
if RESPONSE: |
|
RESPONSE.write("<p>finished<br>\n") |
|
|
|
if RESPONSE: |
|
len=os.stat(tmpZip)[6] |
|
downloadUrl=self.absolute_url()+"/downloadPDF" |
|
RESPONSE.write("""<h1><a href="downloadPDF?fn=%s">Click here for download ( %i Byte)</a></h1>\n"""%(tmpFn,len)) |
|
RESPONSE.write("""<p>The file will be stored for a while, you can download it later, the URL is:</p> |
|
<p><a href="downloadPDF?fn=%s">%s?fn=%s</a></h1>\n"""%(tmpFn,downloadUrl,tmpFn)) |
|
RESPONSE.close() |
|
|
|
|
|
def downloadPDF(self,fn): |
|
"""download prepared set""" |
|
filename="/tmp/archivesImageServer/"+fn |
|
namePDF=self.getId()+".pdf" |
|
self.REQUEST.RESPONSE.setHeader("Content-Disposition","""attachement; filename="%s" """%namePDF) |
|
self.REQUEST.RESPONSE.setHeader("Content-Type","application/octet-stream") |
|
len=os.stat(filename)[6] |
|
self.REQUEST.RESPONSE.setHeader("Content-Length",len) |
|
images=file(filename).read() |
|
self.REQUEST.RESPONSE.write(images) |
|
self.REQUEST.RESPONSE.close() |
|
|
|
|
|
def getRDF(self,urn=None): |
|
"""rdf""" |
|
ret=getRDFDescription(self,self.link,urn=urn) |
|
return ret+self.createSubElementRDF(urn=urn) |
|
|
return ret |
|
|
|
def getAccessRightSelectorHTML(self,outlook="select"): |
def getAccessRightSelectorHTML(self,outlook="select"): |
"""htmlselector""" |
"""htmlselector""" |
Line 1159 class ECHO_resource(Folder,Persistent):
|
Line 680 class ECHO_resource(Folder,Persistent):
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
def getTitle(self): |
|
"""title""" |
|
try: |
|
return self.title.encode('utf-8','ignore') |
|
except: |
|
self.title=self.title.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.title.encode('utf-8','ignore') |
|
|
|
def getLabel(self): |
|
"""title""" |
|
try: |
|
return self.label.encode('utf-8','ignore') |
|
except: |
|
self.label=self.label.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.label.encode('utf-8','ignore') |
|
|
|
def content_html(self): |
def content_html(self): |
"""template fuer content""" |
"""template fuer content""" |
return content_html(self,'resource') |
return ECHO_basis.content_html(self,'resource') |
|
|
def getViewClassification(self): |
def getViewClassification(self): |
if hasattr(self,'viewClassification'): |
if hasattr(self,'viewClassification'): |
Line 1221 class ECHO_resource(Folder,Persistent):
|
Line 728 class ECHO_resource(Folder,Persistent):
|
else: |
else: |
return "<error>no fulltext available</error>" |
return "<error>no fulltext available</error>" |
|
|
|
def getImagePath(self): |
|
"""gibt pfad zum image aus""" |
|
return self.getImageView(noredirect="yes",onlyPath="yes") |
|
|
def getImageView(self,noredirect=None): |
def getImageView(self,noredirect=None,onlyPath=None): |
"""getImages; give Imageviewr and <error></error> if somthing goes wrong.""" |
"""getImages; give Imageviewr and <error></error> if somthing goes wrong.""" |
try: |
try: |
fh=ECHO_helpers.urlopen(self.metalink) |
fh=ECHO_helpers.urlopen(self.metalink) |
Line 1241 class ECHO_resource(Folder,Persistent):
|
Line 751 class ECHO_resource(Folder,Persistent):
|
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
self.REQUEST.RESPONSE.redirect(imageurl) |
self.REQUEST.RESPONSE.redirect(imageurl) |
else: |
else: |
|
if not onlyPath: |
return imageurl |
return imageurl |
|
else: |
|
return archivepath+"/"+imagetemp |
except: |
except: |
|
|
if not noredirect: |
if not noredirect: |
Line 1483 class ECHO_resource(Folder,Persistent):
|
Line 996 class ECHO_resource(Folder,Persistent):
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
def getMDValue(self,fieldName): |
def getMDValue(self,fieldName,empty=None): |
|
if empty: |
return self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType) |
return self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType) |
|
|
|
else: |
|
return self.metaDataHash.get(fieldName,empty) |
|
|
def newMetaXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None,digiliburlprefix=None): |
def newMetaXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None,digiliburlprefix=None): |
"""new index.meta""" |
"""new index.meta""" |
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
Line 1770 class ECHO_resource(Folder,Persistent):
|
Line 1287 class ECHO_resource(Folder,Persistent):
|
"""Ausgabe der MD""" |
"""Ausgabe der MD""" |
return getattr(self,item) |
return getattr(self,item) |
|
|
|
def checkRDF(self,path): |
|
"""check if pdf in the path""" |
|
try: |
|
for fileName in os.listdir(path): |
|
if os.path.splitext(fileName)[1]==".pdf": |
|
return os.path.join(path,fileName) |
|
return None |
|
except: |
|
return None |
|
|
|
|
def index_html(self): |
def index_html(self): |
"""standard page""" |
"""standard page""" |
|
pdf=self.checkRDF(self.link) |
|
if pdf: |
|
fh=file(pdf,'r').read() |
|
self.REQUEST.RESPONSE.setHeader('Content-Type','x-Application/pdf') |
|
self.REQUEST.RESPONSE.write(fh) |
|
self.REQUEST.RESPONSE.close() |
|
return |
return self.REQUEST.RESPONSE.redirect(self.link) |
return self.REQUEST.RESPONSE.redirect(self.link) |
|
|
def startpage_html(self): |
def startpage_html(self): |
Line 1842 def manage_addECHO_resource(self,id,titl
|
Line 1376 def manage_addECHO_resource(self,id,titl
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
class ECHO_externalLink(Folder): |
class ECHO_externalLink(Folder,ECHO_basis): |
"""Link zu einer externen Ressource""" |
"""Link zu einer externen Ressource""" |
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
meta_type='ECHO_externalLink' |
meta_type='ECHO_externalLink' |
|
|
def getTitle(self): |
|
"""title""" |
|
try: |
|
return self.title.encode('utf-8','ignore') |
|
except: |
|
self.title=self.title.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.title.encode('utf-8','ignore') |
|
|
|
def getLabel(self): |
|
"""title""" |
|
try: |
|
return self.label.encode('utf-8','ignore') |
|
except: |
|
self.label=self.label.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.label.encode('utf-8','ignore') |
|
|
|
def content_html(self): |
def content_html(self): |
"""template fuer content""" |
"""template fuer content""" |
return content_html(self,'externalLink') |
return ECHO_basis.content_html(self,'externalLink') |
|
|
def __init__(self,id,link,title,label,description,contentType,responsible,credits,weight,coords): |
def __init__(self,id,link,title,label,description,contentType,responsible,credits,weight,coords): |
|
|
Line 1949 class ECHO_link(ECHO_externalLink):
|
Line 1468 class ECHO_link(ECHO_externalLink):
|
def content_html(self): |
def content_html(self): |
"""template fuer link""" |
"""template fuer link""" |
if hasattr(self,"link_template"): |
if hasattr(self,"link_template"): |
return content_html(self,'link') |
return ECHO_basis.content_html(self,'link') |
else: |
else: |
return content_html(self,'collection') |
return ECHO_basis.content_html(self,'collection') |
|
|
def manage_addECHO_linkForm(self): |
def manage_addECHO_linkForm(self): |
"""Form for external Links""" |
"""Form for external Links""" |
Line 1970 def manage_addECHO_link(self,id,title,la
|
Line 1489 def manage_addECHO_link(self,id,title,la
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
class ECHO_collection(Folder, Persistent, Implicit, Cacheable): |
class ECHO_collection(Folder, Persistent, Implicit, Cacheable,ECHO_basis): |
"""ECHO Collection""" |
"""ECHO Collection""" |
|
|
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
Line 2003 class ECHO_collection(Folder, Persistent
|
Line 1522 class ECHO_collection(Folder, Persistent
|
return ret+"</RDF:Seq>" |
return ret+"</RDF:Seq>" |
|
|
|
|
def showRDF(self): |
|
"""showrdf""" |
|
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
|
ret="""<?xml version="1.0" encoding="utf-8"?>\n<RDF:RDF xmlns:RDF="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:ECHONAVIGATION="http://www.echo.eu/rdf#">\n""" |
|
ret+=self.getRDF(urn="echo:collectionroot")+"\n" |
|
|
|
ret+="""</RDF:RDF>""" |
|
|
|
return ret |
|
|
|
|
|
|
|
def changeLabels(self): |
def changeLabels(self): |
"""change form""" |
"""change form""" |
Line 2304 class ECHO_collection(Folder, Persistent
|
Line 1812 class ECHO_collection(Folder, Persistent
|
else: |
else: |
return "" |
return "" |
|
|
def getTitle(self): |
|
"""title""" |
|
try: |
|
return self.title.encode('utf-8','ignore') |
|
except: |
|
self.title=self.title.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.title.encode('utf-8','ignore') |
|
|
|
def getLabel(self): |
|
"""title""" |
|
try: |
|
return self.label.encode('utf-8','ignore') |
|
except: |
|
self.label=self.label.decode('iso-8859-1','ignore')[0:] #correnct conding error |
|
return self.label.encode('utf-8','ignore') |
|
|
|
def createRessourcesFromXMLForm(self): |
def createRessourcesFromXMLForm(self): |
"""form""" |
"""form""" |
Line 2714 class ECHO_collection(Folder, Persistent
|
Line 2207 class ECHO_collection(Folder, Persistent
|
self.ZCacheable_set(ret) |
self.ZCacheable_set(ret) |
return ret |
return ret |
|
|
def content_html(self): |
def content_html(self,**argv): |
"""template fuer content""" |
"""template fuer content""" |
return content_html(self,'collection') |
#print "NN",argv |
|
return ECHO_basis.content_html(self,'collection') |
|
|
def getCredits(self): |
def getCredits(self): |
"""Ausgabe der credits""" |
"""Ausgabe der credits""" |
Line 2810 class ECHO_group(ECHO_collection):
|
Line 2304 class ECHO_group(ECHO_collection):
|
|
|
security.declareProtected('View','index_html') |
security.declareProtected('View','index_html') |
|
|
def showRDF(self): |
|
"""showrdf""" |
|
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
|
ret="""<?xml version="1.0" encoding="utf-8"?>\n<RDF:RDF xmlns:RDF="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:ECHONAVIGATION="http://www.echo.eu/rdf#">\n""" |
|
ret+=self.getRDF(urn="echo:collectionroot")+"\n" |
|
|
|
ret+="""</RDF:RDF>""" |
|
|
|
return ret |
|
|
|
def getRDF(self,urn=None): |
def getRDF(self,urn=None): |
"""rdf of the collection""" |
"""rdf of the collection""" |
Line 2912 class ECHO_group(ECHO_collection):
|
Line 2397 class ECHO_group(ECHO_collection):
|
|
|
def content_html(self): |
def content_html(self): |
"""template fuer content""" |
"""template fuer content""" |
return content_html(self,'group') |
return ECHO_basis.content_html(self,'group') |
|
|
|
|
|
|
Line 3265 class ECHO_root(Folder,Persistent,Implic
|
Line 2750 class ECHO_root(Folder,Persistent,Implic
|
) |
) |
|
|
|
|
def showRDF(self): |
|
"""showrdf""" |
|
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
|
ret="""<?xml version="1.0" encoding="utf-8"?>\n<RDF:RDF xmlns:RDF="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:ECHONAVIGATION="http://www.echo.eu/rdf#">\n""" |
|
ret+=self.getRDF(urn="echo:collectionroot")+"\n" |
|
|
|
ret+="""</RDF:RDF>""" |
|
return ret |
|
|
|
|
|
def reloadMetaDataFromStorageWarning(self,RESPONSE=None): |
def reloadMetaDataFromStorageWarning(self,RESPONSE=None): |
"""warning""" |
"""warning""" |
Line 3618 class ECHO_root(Folder,Persistent,Implic
|
Line 3094 class ECHO_root(Folder,Persistent,Implic
|
|
|
if self.checkRef(ref): |
if self.checkRef(ref): |
if pn: |
if pn: |
link.setAttribute("href",self.aq_parent.absolute_url()+"/vlp_coll?id="+ref+"&p="+pn) |
link.setAttribute("href",self.aq_parent.absolute_url()+"/references?id="+ref+"&p="+pn) |
else: |
else: |
link.setAttribute("href",self.aq_parent.absolute_url()+"/vlp_coll?id="+ref) |
link.setAttribute("href",self.aq_parent.absolute_url()+"/references?id="+ref) |
|
|
|
|
newxml=dom.toxml('utf-8') |
newxml=dom.toxml('utf-8') |
Line 3703 class ECHO_root(Folder,Persistent,Implic
|
Line 3179 class ECHO_root(Folder,Persistent,Implic
|
|
|
def getPartners(self): |
def getPartners(self): |
"""Get list of Partners. Presently only from a subfolder partners""" |
"""Get list of Partners. Presently only from a subfolder partners""" |
|
if hasattr(self,'partners'): |
return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])] |
return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])] |
|
else: |
|
return [] |
|
|
def getInstitutions(self): |
def getInstitutions(self): |
"""Get list of Partners. Presently only from a subfolder partners""" |
"""Get list of Partners. Presently only from a subfolder partners""" |
Line 3899 def manage_addECHO_rootForm(self):
|
Line 3376 def manage_addECHO_rootForm(self):
|
pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_root.zpt').__of__(self) |
pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_root.zpt').__of__(self) |
return pt() |
return pt() |
|
|
class ECHO_copyrightType(Folder): |
class ECHO_copyrightType(Folder,ECHO_basis): |
"""copyright typ""" |
"""copyright typ""" |
|
|
meta_type="ECHO_copyrightType" |
meta_type="ECHO_copyrightType" |
Line 3948 def manage_addECHO_copyrightType(self,id
|
Line 3425 def manage_addECHO_copyrightType(self,id
|
|
|
|
|
|
|
class ECHO_partner(Image,Persistent): |
class ECHO_partner(Image,Persistent,ECHO_basis): |
"""ECHO Partner""" |
"""ECHO Partner""" |
|
|
meta_type="ECHO_partner" |
meta_type="ECHO_partner" |
Line 4032 def manage_addECHO_partner(self, id, url
|
Line 3509 def manage_addECHO_partner(self, id, url
|
REQUEST.RESPONSE.redirect('%s/manage_main' % url) |
REQUEST.RESPONSE.redirect('%s/manage_main' % url) |
return id |
return id |
|
|
class ECHO_linkList(ZopePageTemplate): |
class ECHO_linkList(ZopePageTemplate,ECHO_basis): |
"""LinkList Objekt""" |
"""LinkList Objekt""" |
meta_type="ECHO_linkList" |
meta_type="ECHO_linkList" |
|
|
Line 4044 class ECHO_linkList(ZopePageTemplate):
|
Line 3521 class ECHO_linkList(ZopePageTemplate):
|
|
|
def content_html(self): |
def content_html(self): |
"""content_html""" |
"""content_html""" |
return content_html(self,'pageTemplate') |
return ECHO_basis.content_html(self,'pageTemplate') |
|
|
def changeECHO_linkListWeightForm(self): |
def changeECHO_linkListWeightForm(self): |
"""change""" |
"""change""" |
Line 4128 def manage_addECHO_linkList(self, id, la
|
Line 3605 def manage_addECHO_linkList(self, id, la
|
return '' |
return '' |
|
|
|
|
class ECHO_support(Folder): |
class ECHO_support(Folder,ECHO_basis): |
"""gefÂrdert durch""" |
"""gefoerdert durch""" |
meta_type="ECHO_support" |
meta_type="ECHO_support" |
|
|
|
|
Line 4182 def manage_addECHO_support(self, id,inst
|
Line 3659 def manage_addECHO_support(self, id,inst
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
class ECHO_institution(Image,Persistent): |
class ECHO_institution(Image,Persistent,ECHO_basis): |
"""ECHO Institution""" |
"""ECHO Institution""" |
|
|
meta_type="ECHO_institution" |
meta_type="ECHO_institution" |
Line 4261 def manage_addECHO_institution(self, id,
|
Line 3738 def manage_addECHO_institution(self, id,
|
except: url=REQUEST['URL1'] |
except: url=REQUEST['URL1'] |
REQUEST.RESPONSE.redirect('%s/manage_main' % url) |
REQUEST.RESPONSE.redirect('%s/manage_main' % url) |
return id |
return id |
|
|