' in self.showMetaDataXML()):
- nurn=self.absolute_url()+'/showMetaDataXML'
- ret+=getRDFDescription(self,self.absolute_url()+'/showMetaDataXML',urn=nurn,nameDef="Metadata",typeName="ECHO_metaData")
+ width,height=A4
+ #print image%(width*faktor,height*faktor,i)
+ url=urllib.urlopen(image%(width*faktor,height*faktor,i)).read()
+ fh=file(fn,"w")
+ fh.write(url)
+ fh.close()
- return ret
-
+
+
+ c.drawImage(fn,0,0,width=width,height=height)
+ c.showPage()
+ c.save()
+ if RESPONSE:
+ RESPONSE.write("finished
\n")
+
+ if RESPONSE:
+ len=os.stat(tmpZip)[6]
+ downloadUrl=self.absolute_url()+"/downloadPDF"
+ RESPONSE.write("""
\n"""%(tmpFn,len))
+ RESPONSE.write("""The file will be stored for a while, you can download it later, the URL is:
+ %s?fn=%s\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)
+
+
def getAccessRightSelectorHTML(self,outlook="select"):
"""htmlselector"""
values=['free','mpiwg']
@@ -1198,25 +680,11 @@ class ECHO_resource(Folder,Persistent):
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):
"""template fuer content"""
- return content_html(self,'resource')
+ return ECHO_basis.content_html(self,'resource')
def getViewClassification(self):
if hasattr(self,'viewClassification'):
@@ -1260,8 +728,11 @@ class ECHO_resource(Folder,Persistent):
else:
return "no fulltext available"
-
- def getImageView(self,noredirect=None):
+ def getImagePath(self):
+ """gibt pfad zum image aus"""
+ return self.getImageView(noredirect="yes",onlyPath="yes")
+
+ def getImageView(self,noredirect=None,onlyPath=None):
"""getImages; give Imageviewr and if somthing goes wrong."""
try:
fh=ECHO_helpers.urlopen(self.metalink)
@@ -1280,7 +751,10 @@ class ECHO_resource(Folder,Persistent):
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
self.REQUEST.RESPONSE.redirect(imageurl)
else:
- return imageurl
+ if not onlyPath:
+ return imageurl
+ else:
+ return archivepath+"/"+imagetemp
except:
if not noredirect:
@@ -1522,9 +996,13 @@ class ECHO_resource(Folder,Persistent):
RESPONSE.redirect('manage_main')
- def getMDValue(self,fieldName):
- return self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType)
-
+ def getMDValue(self,fieldName,empty=None):
+ if empty:
+ 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):
"""new index.meta"""
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
@@ -1808,10 +1286,27 @@ class ECHO_resource(Folder,Persistent):
def ECHO_getMD(self,item):
"""Ausgabe der MD"""
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):
"""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)
def startpage_html(self):
@@ -1881,30 +1376,15 @@ def manage_addECHO_resource(self,id,titl
RESPONSE.redirect('manage_main')
-class ECHO_externalLink(Folder):
+class ECHO_externalLink(Folder,ECHO_basis):
"""Link zu einer externen Ressource"""
security=ClassSecurityInfo()
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):
"""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):
@@ -1988,9 +1468,9 @@ class ECHO_link(ECHO_externalLink):
def content_html(self):
"""template fuer link"""
if hasattr(self,"link_template"):
- return content_html(self,'link')
+ return ECHO_basis.content_html(self,'link')
else:
- return content_html(self,'collection')
+ return ECHO_basis.content_html(self,'collection')
def manage_addECHO_linkForm(self):
"""Form for external Links"""
@@ -2009,7 +1489,7 @@ def manage_addECHO_link(self,id,title,la
RESPONSE.redirect('manage_main')
-class ECHO_collection(Folder, Persistent, Implicit, Cacheable):
+class ECHO_collection(Folder, Persistent, Implicit, Cacheable,ECHO_basis):
"""ECHO Collection"""
security=ClassSecurityInfo()
@@ -2041,17 +1521,6 @@ class ECHO_collection(Folder, Persistent
ret+=li%nurn
return ret+""
-
- def showRDF(self):
- """showrdf"""
- self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
- ret="""\n\n"""
- ret+=self.getRDF(urn="echo:collectionroot")+"\n"
-
- ret+=""""""
-
- return ret
-
def changeLabels(self):
@@ -2343,21 +1812,6 @@ class ECHO_collection(Folder, Persistent
else:
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):
"""form"""
@@ -2753,9 +2207,10 @@ class ECHO_collection(Folder, Persistent
self.ZCacheable_set(ret)
return ret
- def content_html(self):
+ def content_html(self,**argv):
"""template fuer content"""
- return content_html(self,'collection')
+ #print "NN",argv
+ return ECHO_basis.content_html(self,'collection')
def getCredits(self):
"""Ausgabe der credits"""
@@ -2849,15 +2304,6 @@ class ECHO_group(ECHO_collection):
security.declareProtected('View','index_html')
- def showRDF(self):
- """showrdf"""
- self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
- ret="""\n\n"""
- ret+=self.getRDF(urn="echo:collectionroot")+"\n"
-
- ret+=""""""
-
- return ret
def getRDF(self,urn=None):
"""rdf of the collection"""
@@ -2951,7 +2397,7 @@ class ECHO_group(ECHO_collection):
def content_html(self):
"""template fuer content"""
- return content_html(self,'group')
+ return ECHO_basis.content_html(self,'group')
@@ -3304,15 +2750,6 @@ class ECHO_root(Folder,Persistent,Implic
)
- def showRDF(self):
- """showrdf"""
- self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
- ret="""\n\n"""
- ret+=self.getRDF(urn="echo:collectionroot")+"\n"
-
- ret+=""""""
- return ret
-
def reloadMetaDataFromStorageWarning(self,RESPONSE=None):
"""warning"""
@@ -3742,9 +3179,10 @@ class ECHO_root(Folder,Persistent,Implic
def getPartners(self):
"""Get list of Partners. Presently only from a subfolder partners"""
-
- return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])]
-
+ if hasattr(self,'partners'):
+ return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])]
+ else:
+ return []
def getInstitutions(self):
"""Get list of Partners. Presently only from a subfolder partners"""
@@ -3938,7 +3376,7 @@ def manage_addECHO_rootForm(self):
pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_root.zpt').__of__(self)
return pt()
-class ECHO_copyrightType(Folder):
+class ECHO_copyrightType(Folder,ECHO_basis):
"""copyright typ"""
meta_type="ECHO_copyrightType"
@@ -3987,7 +3425,7 @@ def manage_addECHO_copyrightType(self,id
-class ECHO_partner(Image,Persistent):
+class ECHO_partner(Image,Persistent,ECHO_basis):
"""ECHO Partner"""
meta_type="ECHO_partner"
@@ -4071,7 +3509,7 @@ def manage_addECHO_partner(self, id, url
REQUEST.RESPONSE.redirect('%s/manage_main' % url)
return id
-class ECHO_linkList(ZopePageTemplate):
+class ECHO_linkList(ZopePageTemplate,ECHO_basis):
"""LinkList Objekt"""
meta_type="ECHO_linkList"
@@ -4083,7 +3521,7 @@ class ECHO_linkList(ZopePageTemplate):
def content_html(self):
"""content_html"""
- return content_html(self,'pageTemplate')
+ return ECHO_basis.content_html(self,'pageTemplate')
def changeECHO_linkListWeightForm(self):
"""change"""
@@ -4167,8 +3605,8 @@ def manage_addECHO_linkList(self, id, la
return ''
-class ECHO_support(Folder):
- """gefÂrdert durch"""
+class ECHO_support(Folder,ECHO_basis):
+ """gefoerdert durch"""
meta_type="ECHO_support"
@@ -4221,7 +3659,7 @@ def manage_addECHO_support(self, id,inst
RESPONSE.redirect('manage_main')
-class ECHO_institution(Image,Persistent):
+class ECHO_institution(Image,Persistent,ECHO_basis):
"""ECHO Institution"""
meta_type="ECHO_institution"