\n"""
- ret+=self.getRDF(urn="echo:colllectionroot")+"\n"
+ self.fullTextUrl=self.getFullTextXML(noredirect="yes")
+
+ #TODO: korrigieren relative url to absoluter url volltexten, konfigurierbar?
+ splitted= [x for x in urlparse.urlparse(self.fullTextUrl)]
+ if splitted[0]=="":
+ splitted[0]="http"
+ splitted[1]="foxridge.mpiwg-berlin.mpg.de"[0:]
+
+ self.fullTextUrl=urlparse.urlunparse(splitted)
+
+ self.imagePath=self.getImagePath()
+
+ self.reindex_object()
+
+
+ security.declareProtected('View','createPDF')
+ def createPDF(self,RESPONSE=None,local=None,dpi=150):
+ """erzeuge pdf file"""
+ pages=1
+ dpi=float(dpi)
+ imagePath=self.getImagePath().replace("/mpiwg/online","")
+
+
+ image="http://nausikaa2.mpiwg-berlin.mpg.de/digitallibrary/servlet/Scaler?fn="+imagePath+"&dw=%i&dh=%i&pn=%i"
+ xmlInfo="http://nausikaa2.mpiwg-berlin.mpg.de/digitallibrary/dlInfo-xml.jsp?fn="+imagePath
+
+ dom=xml.dom.minidom.parse(urllib.urlopen(xmlInfo))
+ for parameter in dom.getElementsByTagName('parameter'):
+ if parameter.getAttribute('name')=="pt":
+ pages=int(parameter.getAttribute('value'))
+ break
+
+
+ tempdir="/tmp/archivesImageServer"
+ if not os.path.exists(tempdir):
+ os.mkdir(tempdir)
+
+ tmpPath=tempfile.mkdtemp(dir=tempdir)
+
+
+ tmpZip=tempfile.mktemp(dir=tempdir)
+
+ tmpFn=os.path.split(tmpZip)[1]
+
+
+
+
+ if RESPONSE:
+ RESPONSE.setHeader("Content-Type","text/html")
+ RESPONSE.write("I am creating the pdf
")
+ txt="1. step: getting the images( %i pages)
"%pages
+ RESPONSE.write(txt)
+
+ c=canvas.Canvas(tmpZip)
+ for i in range(1,pages+1):
+ if RESPONSE:
+ RESPONSE.write(str("Get Page: %i
\n"%i))
+ faktor=dpi/72.0
+
+ fn=tmpPath+"/%i"%i
+
+ 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()
+
+
+
+ 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()
- ret+="""
"""
- return ret
def getRDF(self,urn=None):
- """rdf"""
- ret=getRDFDescription(self,self.link,urn=urn)
- return ret+self.createSubElementRDF(urn=urn)
-
-
- def createSubElementRDF(self,urn=None):
- """rdf list"""
- if not urn:
- urn=self.absolute_url()
- ret=""
-
- rettemp="""