--- ImageArchive/ImageArchive.py 2006/05/15 13:14:16 1.78
+++ ImageArchive/ImageArchive.py 2006/05/22 13:54:37 1.89
@@ -1,7 +1,7 @@
genericServerPath="http://www.mpiwg-berlin.mpg.de/zogilib_images" #can be changed with main config
-
+from Ft.Xml.Domlette import NonvalidatingReader
from OFS.Folder import Folder
from OFS.OrderedFolder import OrderedFolder
from OFS.SimpleItem import SimpleItem
@@ -491,58 +491,68 @@ class ImageDigilib(Folder,Persistent,Imp
RESPONSE.redirect(self.aq_parent.absolute_url()+"?filename="+self.filename)
- def updateImage(self,file,rename=None,RESPONSE=None):
- """lade neues Version des Bildes"""
- #teste ob Dokumenten ordner schon vorhanden
- #imagePath=os.path.join(self.ImageStoragePath,self.getId())
+ def updateImage(self,_fileupload,_rename=None,RESPONSE=None):
+ """lade neues Version des Bildes"""
+ #teste ob Dokumenten ordner schon vorhanden
+ #imagePath=os.path.join(self.ImageStoragePath,self.getId())
+
+ identifyField="filename"
+
+ if _fileupload and _fileupload.filename!="":
imagePath=os.path.join(self.ImageStoragePath,self.filename)
path=os.path.join(self.ImageStoragePath,"."+self.getId()+".dir")
-
+
if not os.path.exists(path):
- os.mkdir(path,0775)
- os.chmod(path,0775)
-
+ os.mkdir(path,0775)
+ os.chmod(path,0775)
+
versionNumber=getattr(self,'versionNumber',0)+1
-
+
#teste ob version schon existiert
-
+
while os.path.exists(os.path.join(path,"V%i_%s"%(versionNumber,self.filename))):
- versionNumber+=1
-
+ versionNumber+=1
+
#kopieren der bestehenden Version in den Versions ordner.
imageNewPath=os.path.join(path,"V%i_%s"%(versionNumber,self.filename))
- try:
- #zLOG.LOG("ImageArchive:updateImage", zLOG.INFO, "rename: %s -> %s"%(imagePath,imageNewPath))
- os.rename(imagePath,imageNewPath)
- except:
- zLOG.LOG("ImageArchive:updateImage", zLOG.ERROR, "rename: %s -> %s didn't work!"%(imagePath,imageNewPath))
-
+ try:
+ #zLOG.LOG("ImageArchive:updateImage", zLOG.INFO, "rename: %s -> %s"%(imagePath,imageNewPath))
+ os.rename(imagePath,imageNewPath)
+ except:
+ zLOG.LOG("ImageArchive:updateImage", zLOG.ERROR, "rename: %s -> %s didn't work!"%(imagePath,imageNewPath))
+
#lesen des upload files und schreiben
- filedata=file.read()
+ filedata=_fileupload.read()
f=open(imagePath,"w") # if we wanted to have filename=id we should do it here!
f.write(filedata)
f.close()
try:
- os.chmod(imagePath,0664)
+ os.chmod(imagePath,0664)
except:
- """hack"""
+ pass
#scale thumb
-
- self.scaleThumbs()
+ self.scaleThumbs()
+
#scale standard
-
+
self.scaleWorkingVersions()
-
- if rename:
- self.renameImage(file.filename)
-
+
+ if _rename:
+ self.renameImage(_fileupload.filename)
- if RESPONSE:
- RESPONSE.redirect(self.aq_parent.absolute_url()+"?filename="+self.filename)
+
+ args=self.REQUEST.form
+
+ args['-identify']=identifyField+"="+args['_identifyField']
+
+ self.ZSQLChange(args=args)
+
+ if RESPONSE:
+ RESPONSE.redirect(self.aq_parent.absolute_url()+"?filename="+self.filename)
- return "done"
+ return "done"
security.declarePublic('thumb')
def thumb(self,url=None):
@@ -779,7 +789,7 @@ class ImageCollection(OrderedFolder, Per
"""scale thumbs"""
#scale thumbs
- ret=os.popen("ssh nausikaa2.rz-berlin.mpg.de /usr/local/mpiwg/scripts/scaleomat.pl -src=/mpiwg/online/ -dir=%s -dest=/mpiwg/temp/online/scaled/thumb -scaleto=100 &"% self.ImageViewerPath)
+ ret=os.popen("/docuserver/libs/scaleomat/scaleomat.pl -src=/docuserver/images/ -dir=%s -dest=/docuserver/scaled/thumb -scaleto=100 &"% self.ImageViewerPath)
if RESPONSE:
RESPONSE.write(ret.read())
RESPONSE.write("\n")
@@ -791,7 +801,10 @@ class ImageCollection(OrderedFolder, Per
#scale standard
- ret=os.popen("ssh nausikaa2.rz-berlin.mpg.de /usr/local/mpiwg/scripts/scaleomat.pl -src=/mpiwg/online/ -dir=%s -dest=/mpiwg/temp/online/scaled/small -scaleto=2000 &"% self.ImageViewerPath)
+ ret=os.popen("/docuserver/libs/scaleomat/scaleomat.pl -src=/docuserver/images -dir=%s -dest=/docuserver/scaled/small -scaleto=1000 &"% self.ImageViewerPath)
+
+ ret=os.popen("/docuserver/libs/scaleomat/scaleomat.pl -src=/docuserver/images -dir=%s -dest=/docuserver/scaled/medium -scaleto=2000 &"% self.ImageViewerPath)
+
if RESPONSE:
RESPONSE.write(ret.read())
RESPONSE.write("\n")
@@ -1119,11 +1132,11 @@ class ImageCollection(OrderedFolder, Per
#scale thumb
- #self.scaleThumbs()
+ self.scaleThumbs()
#scale standard
- #self.scaleWorkingVersions()
+ self.scaleWorkingVersions()
if RESPONSE:
RESPONSE.redirect('manage_main')
@@ -1621,19 +1634,33 @@ class ImageCollection(OrderedFolder, Per
def getImageByName(self,filename,onlyName=None):
"""get filename"""
- print repr(filename)
+ #print repr(filename)
#FIXME: umlaute in filename
fn=getattr(self,repr(filename),None)
if not fn:
filenameM=filename.split(".")[0]
+
founds=self.ZopeFind(self,obj_metatypes=['ImageDigilib'])
+
+
for found in founds:
foundM=found[0].split(".")[0]
+
if filenameM.lower()==foundM.lower():
if onlyName:
return found[0]
else:
- return found[1]
+ return found[1]
+ #HACK teste noch ob am ende des filenames eventuell ein "_" und loesche das.
+ if foundM[-1]=="_":
+ foundM=foundM[0:-1]
+
+ if filenameM.lower()==foundM.lower():
+ if onlyName:
+ return found[0]
+ else:
+ return found[1]
+
if onlyName:
return filename
else:
@@ -1730,6 +1757,49 @@ class ImageCollectionMD(ImageCollection,
except:
pass
+
+ def ImportFiles(self,RESPONSE=None):
+ """Import the existing files of a folder"""
+ files=os.listdir(self.ImageStoragePath)
+ ret=""
+ #print self.__dict__
+ for file in files:
+ if not file[0]==".":
+ if self.__dict__.has_key(file):
+
+ ret=ret+"
"+file+" already exists!"
+ else:
+ ret=ret+"
"+file+" created!"
+ newObj=ImageDigilib(file,file)
+ #print newObj,file
+ #print newObj
+ try:
+ self._setObject(file,newObj)
+ except:
+ """nothing yet"""
+
+
+ args={}
+ args['_table']=self.imageCollectionConfig.getTable()
+ args[self.imageCollectionConfig.getKey()]=file
+
+ if not self.ZSQLInlineSearch(args=args):
+ self.ZSQLAdd(args=args)
+ #print ret
+ #pt=PageTemplateFile('Products/ImageArchive/out.zpt')).__of__(self)
+ #print self.ImageStoragePath
+
+ #scale thumb
+
+
+ self.scaleThumbs()
+
+ #scale standard
+
+ self.scaleWorkingVersions()
+
+ if RESPONSE:
+ RESPONSE.redirect('manage_main')
def addImage(self):
"""Add an Image"""
@@ -1737,7 +1807,7 @@ class ImageCollectionMD(ImageCollection,
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addImageMD.zpt')).__of__(self)
return pt()
- def addImage2(self,_fileupload,_fileName=None,_meta=None,_use_default=None,RESPONSE=None,**argv):
+ def addImage2(self,_fileupload,_fileName=None,_meta=None,_use_default=None,RESPONSE=None):
"""Add"""
filenameKey="filename"
@@ -1755,9 +1825,10 @@ class ImageCollectionMD(ImageCollection,
manage_AddImageDigilib(self,fn,_fileupload,meta=meta)
- args[key]=_filename
+ args=self.REQUEST.form
+ args[filenameKey]=fn
- self.ZSQLAdd(args=argv)
+ self.ZSQLAdd(args=args)
if RESPONSE:
return RESPONSE.redirect(self.REQUEST['URL1']+'/'+fn)
@@ -1802,15 +1873,38 @@ class ImageCollectionMD(ImageCollection,
def searchDB(self,REQUEST=None,RESPONSE=None,xml=None):
"""search"""
- #context.ZSQLFind(_table='vision_main')
- urlTmp=REQUEST['URL1']
- url=urlTmp+'/searchResultXML?-table=vision_main&'+REQUEST['QUERY_STRING']
+ rc=[]
+ fnIds={}
+ for found in self.ZSQLInlineSearch(args=self.REQUEST.form):
+ key=getattr(found,self.imageCollectionConfig.getKey())
+ key=self.getImageByName(key,onlyName="yes")
+ rc.append((key,'',0))
+ fnIds[key]=('',0)
+
+ rc.sort()
+ self.REQUEST.SESSION['filenames']=rc
+ self.REQUEST.SESSION['filenamesIds']=fnIds
- if xml is None:
- RESPONSE.redirect('xmlinput?url='+urllib.quote(url))
+ overview=self.ZopeFind(self,obj_ids=['overview_selectedMD.html'])
+
+ if overview:
+ return overview[0][1]()
else:
- RESPONSE.redirect(url)
+ pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','overview_selectedMD.zpt')).__of__(self)
+ return pt()
+
+ pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','overview_selectedMD.zpt')).__of__(self)
+ return pt()
+
+ #urlTmp=REQUEST['URL1']
+
+ #url=urlTmp+'/searchResultXML?-table=%s&'%self.imageCollectionConfig.getTable()+REQUEST['QUERY_STRING']
+
+ #if xml is None:
+ # RESPONSE.redirect('xmlinput?url='+urllib.quote(url))
+ #else:
+ # RESPONSE.redirect(url)
def index_html(self,fn=None,selection=None,generic='No',REQUEST=None,RESPONSE=None):
"""main template collection"""
@@ -1831,7 +1925,7 @@ class ImageCollectionMD(ImageCollection,
self.REQUEST.SESSION['filenames']=ret
#self.REQUEST.SESSION['filenamesIds']=fnIds
- overview=self.ZopeFind(self,obj_ids=['overview_selectedMD.html'])
+ overview=self.ZopeFind(self,obj_ids=['overview_selected.html'])
if overview and (generic =='No'):
@@ -1851,13 +1945,13 @@ class ImageCollectionMD(ImageCollection,
self.REQUEST.SESSION['filename']=filen[0:]
- if not self.REQUEST.SESSION['filename']=="":
- url=getattr(self.getImageByName(self.REQUEST.SESSION['filename']),'absolute_url')()
- if mode=="view":
- self.REQUEST.RESPONSE.redirect(url)
- elif mode=="download":
- self.REQUEST.RESPONSE.redirect(url+"/download")
-
+# if not self.REQUEST.SESSION['filename']=="":
+# url=getattr(self.getImageByName(self.REQUEST.SESSION['filename']),'absolute_url')()
+# if mode=="view":
+# self.REQUEST.RESPONSE.redirect(url)
+# elif mode=="download":
+# self.REQUEST.RESPONSE.redirect(url+"/download")
+#
if self.REQUEST.has_key('showall'):
self.REQUEST.SESSION['showall']=self.REQUEST.get('showall')
@@ -1867,12 +1961,11 @@ class ImageCollectionMD(ImageCollection,
if selection:
#selection i.e. selection already stored at self.REQUEST.SESSION['filenames']
- overview=self.ZopeFind(self,obj_ids=['overview_selectedMD.html'])
+ overview=self.ZopeFind(self,obj_ids=['overview_selected.html'])
if overview and (generic =='No'):#
- print "selected"
- print repr(overview[0][1])
+
return overview[0][1]()
else:
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','overview_selectedMD.zpt')).__of__(self)
@@ -1881,7 +1974,7 @@ class ImageCollectionMD(ImageCollection,
#no filename then show overview
- overview=self.ZopeFind(self,obj_ids=['overviewMD.html'])
+ overview=self.ZopeFind(self,obj_ids=['overview.html'])
if overview and (generic == 'No'):
@@ -1900,6 +1993,9 @@ class ImageCollectionMD(ImageCollection,
if not selected and self.REQUEST.has_key('fn'):
imagename=self.REQUEST['fn'].split('/')[-1]
+
+ imagename=self.getImageByName(imagename,onlyName=True)
+
nr=self.getObjectPosition(imagename)
objects=self.objectIds()
@@ -1914,6 +2010,9 @@ class ImageCollectionMD(ImageCollection,
if not selected and self.REQUEST.has_key('fn'):
imagename=self.REQUEST['fn'].split('/')[-1]
+
+ imagename=self.getImageByName(imagename,onlyName=True)
+
nr=self.getObjectPosition(imagename)
objects=self.objectIds()
@@ -1982,24 +2081,26 @@ class ImageCollectionMD(ImageCollection,
xmldoc=urllib.urlopen(url).read()
#return xmldoc
try:
- dom=xml.dom.minidom.parseString(xmldoc)
+ dom=NonvalidatingReader.parseUri(url)
+
except:
return "ERROR: (%s %s) %s"%(sys.exc_info()[0],sys.exc_info()[1],xmldoc)
- images=dom.getElementsByTagName('image')
+ imagenames=dom.xpath("//imagename")
rc=[]
fnIds={}
- for image in images:
- imagename=image.getElementsByTagName('imagename')[0]
-
+ for imagename in imagenames:
+
+ #imagename=image.xpath('./imagename')[0]
+ #print "im",imagename
- idnr=image.getElementsByTagName('idnr')[0]
+ idnr=imagename.xpath('../idnr')[0]
id=getText(idnr.childNodes)
try:
- numberOfPages=image.getElementsByTagName('numberOfPages')[0]
+ numberOfPages=imagename.xpath('../numberOfPages')[0]
except:
numberOfPages=None
@@ -2015,7 +2116,9 @@ class ImageCollectionMD(ImageCollection,
texts=getText(imagename.childNodes).split("\n") #mehrere bilder in return getrennter liste
for text in texts:
if not text=="":
+ #print "a"
text=self.getImageByName(text,onlyName="yes")
+ #print "b"
try:
rc.append((str(text),id,nop))
fnIds[str(text)]=(id,nop)
@@ -2023,7 +2126,7 @@ class ImageCollectionMD(ImageCollection,
rc.append((repr(text),id,nop))
fnIds[repr(text)]=(id,nop)
-
+ #print "done"
rc.sort()
self.REQUEST.SESSION['filenames']=rc
self.REQUEST.SESSION['filenamesIds']=fnIds