--- ECHO_content/ECHO_collection.py 2004/05/18 22:30:09 1.87
+++ ECHO_content/ECHO_collection.py 2012/09/03 14:48:22 1.310.2.10
@@ -1,4 +1,4 @@
-"""New version of the product started February, 8th. Without scientific classification, use content-type for further classification."""
+"""New version of the produc started February, 8th. Without scientific classification, use content-type for further classification."""
"""Echo collection provides the classes for the ECHO content web-site.
class ECHO_collection is the basis class for an ECHO collection.
@@ -9,11 +9,17 @@ class ECHO_externalLink contains informa
"""
+
+
+import urlparse
import string
+import tempfile
+import zipfile
import re
-import os
+import os,shutil
import OFS.Image
from types import *
+from OFS.Cache import Cacheable
from OFS.Image import Image
from Globals import DTMLFile
from OFS.Folder import Folder
@@ -25,223 +31,73 @@ from Globals import DTMLFile
import Globals
from Products.PageTemplates.PageTemplateFile import PageTemplateFile
from Products.PageTemplates.PageTemplate import PageTemplate
-from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
+from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate,manage_addPageTemplate
from Globals import Persistent, package_home
from Acquisition import Implicit
-from ECHO_helpers import displayTypes
+from Products.ZCatalog.CatalogPathAwareness import CatalogAware
+from Products.ZCTextIndex.ZCTextIndex import manage_addLexicon
+import ECHO_helpers
+from Acquisition import aq_parent
+try:
+ from Products.MetaDataProvider.MetaDataClient import MetaDataClient
+except:
+ print "no metadataclient"
+import urllib
+import urllib2
+import cgi
+import smtplib
+import time
+#from Ft.Xml.Domlette import NonvalidatingReader
+#from Ft.Xml.Domlette import PrettyPrint, Print
+#from Ft.Xml import EMPTY_NAMESPACE
+#
+#import Ft.Xml.XPath
+import cStringIO
+import sys
+import logging
try:
- from psycopg import libpq
+ from psycopg import libpq
except:
- try:
- from pyPgSQL import libpq
- except:
- print "ECHO_collection: Warning - No libpq imported!"
-
+ try:
+ from pyPgSQL import libpq
+ except:
+ print "ECHO_collection: Warning - No libpq imported!"
+
import xml.dom.minidom
import urllib
import xml.dom.minidom
-from ECHO_graphicalOverview import javaHandler,javaScriptMain
import ECHO_helpers
+from ECHO_helpers import *
-#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)
- 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:
- print "DIFF",field,self.getFieldValue(self.getFieldTag(tags,field)),metadict[self.getFieldTag(tags,field)]
- diffs[self.getFieldTag(tags,field)]=0
- except:
- diffs[self.getFieldTag(tags,field)]=0
- print "EX",field
- 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]()
-
- try:
- obj=getattr(self,type+"_template")
- return obj()
- except:
- pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_%s_template_standard.zpt'%type).__of__(self)
- pt.content_type="text/html"
- return pt()
-
-def toList(field):
- """Einzelfeld in Liste umwandeln"""
- if type(field)==StringType:
- return [field]
- else:
- return field
-
-def getText(nodelist):
-
- 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):
- """Einlesen der Metadaten und und erstellen des geaenderten XML file"""
-
- try:
- geturl=""
- for line in urllib.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+" "+geturl)
-
- metanodes=dom.getElementsByTagName('bib')
+try:
+ from ECHO_language import *
+except:
+ print "no echo_language"
+ class ECHO_language:
+ """ leere Klasse"""
+ pass
- if not metanodes:
- metanodes=dom.getElementsByTagName('archimedes')
+from ECHO_movie import *
+#import vlp_xmlhelpers #TODO: vlp elemente aus echo herausnehmen
+import xmlrpclib
- metanode=metanodes[0]
+import logging
- for metaData in metadict.keys():
- print metaData,metanode
- 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(unicode(metadict[metaData],"utf8"))
- metanodeneu.appendChild(metanodetext)
- metanode.appendChild(metanodeneu)
-
-
- return dom.topxml().encode('utf-8')
-
-def readMetadata(url):
- """Methode zum Auslesen der Metadateninformation zu einer Resource
- Vorerst noch Typ bib"""
-
- metadict={}
- try:
- geturl=""
- for line in urllib.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+" "+geturl)
-
- metanode=dom.getElementsByTagName('bib')
- metadict['bib_type']='Book'
- if len(metanode)==0:
- metanode=dom.getElementsByTagName('archimedes')
- metadict['bib_type']='Archimedes'
- #print "HELLO"
-
- 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:
- metadict[re.sub('-','_',node.tagName.lower())]=getText(node.childNodes)
- except:
- """nothing"""
+from ECHO_root import ECHO_root
+#ersetzt logging.info
+def logger(txt,method,txt2):
+ """logging"""
+ logging.info(txt+ txt2)
- 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=""):
"""Allegemeine Informationen zu einer ECHO Collection"""
- self.viewClassification=viewClassification
-
self.label = label
self.title=title
self.description=description
@@ -250,70 +106,208 @@ def setECHO_collectionInformation(self,t
self.credits=toList(credits)
self.weight=weight
- coords=[]
- #coordinates of for rectangles
+import ECHO_resource
+from ECHO_resource import manage_addECHO_resource
- #print "cs", coordstrs
- if coordstrs:
- for coordstr in coordstrs:
- #print "cs", coordstr
- try:
- temco=coordstr.split(",")
- except:
- temco=[]
- #temco.append(angle)
- coords.append(temco)
+class ECHO_resource(ECHO_resource.ECHO_resource):
+ """depricated use class in ECHO_resource.py"""
- self.coords=coords[0:]
-
+class ECHO_partner(Image,Persistent,ECHO_basis):
+ """ECHO Partner"""
+
+ meta_type="ECHO_partner"
+
+ def __init__(self, id, title,url, file, copyrightType, person, email, country, color, content_type='', precondition=''):
+ self.__name__=id
+ self.title=title
+ self.url=url
+ self.person=person
+ self.email=email
+ self.country=country
+ self.color=color
+ self.precondition=precondition
+ self.copyrightType=copyrightType
+ data, size = self._read_data(file)
+ content_type=self._get_content_type(file, data, id, content_type)
+ self.update_data(data, content_type, size)
+
+ manage_options = Image.manage_options+(
+ {'label':'Partner Information','action':'ECHO_partner_config'},
+ )
-class scientificClassification(SimpleItem,Persistent,Implicit):
- """outdated will be deleeted in the next versions: subclass"""
- security=ClassSecurityInfo()
-
- def __init__(self,context,science,practice):
- self.context=context
- self.science=science
- self.practice=practice
- self.id="scientific_Classification"
-
- security.declarePublic('get_context')
- def get_context(self):
- return self.context
-
- security.declarePublic('get_science')
- def get_science(self):
- return self.science
-
- security.declarePublic('get_practice')
- def get_practice(self):
- return self.practice
+ def changeECHO_partner(self,url,copyrightType,person, email, country, color, RESPONSE=None):
+ """Change main information"""
+ self.url=url
+ self.person=person
+ self.email=email
+ self.country=country
+ self.color=color
+ self.copyrightType=copyrightType
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+
+
+ def ECHO_partner_config(self):
+ """Main configuration"""
+ if not hasattr(self,'url'):
+ self.url=""
+ pt=zptFile(self, 'zpt/ChangeECHO_partner.zpt')
+ return pt()
+
+
+manage_addECHO_partnerForm=DTMLFile('dtml/ECHO_partnerAdd',globals(),
+ Kind='ECHO_partner',kind='ECHO_partner')
+
+
+
+def manage_addECHO_partner(self, id, url, person, email, country, color, file=None, copyrightType='', title='', precondition='', content_type='',
+ REQUEST=None):
+ """
+ Add a new ECHO_partner object.
+
+ Creates a new ECHO_partner object 'id' with the contents of 'file'.
+ Based on Image.manage_addImage
+ """
+
+ id=str(id)
+ title=str(title)
+ content_type=str(content_type)
+ precondition=str(precondition)
+
+ id, title = OFS.Image.cookId(id, title, file)
+
+ self=self.this()
+
+ # First, we create the image without data:
+ self._setObject(id, ECHO_partner(id,title,url,'',copyrightType, person, email, country, color, content_type, precondition))
+
+ # Now we "upload" the data. By doing this in two steps, we
+ # can use a database trick to make the upload more efficient.
+ if file:
+ self._getOb(id).manage_upload(file)
+ if content_type:
+ self._getOb(id).content_type=content_type
+
+ if REQUEST is not None:
+ try: url=self.DestinationURL()
+ except: url=REQUEST['URL1']
+ REQUEST.RESPONSE.redirect('%s/manage_main' % url)
+ return id
+
+class ECHO_locale(ZopePageTemplate):
+ """localisierung"""
+
+ meta_type="ECHO_locale"
+
+ def __init__(self,id,lang,title,label,text=None,content_type=None):
+ self.lang=lang
+ self.title=title
+ self.label=label
+ # default content
+ if not text:
+ text = open(self._default_content_fn).read()
+ content_type = 'text/html'
+ self.pt_edit(text, content_type)
+ self.id=id
+
+ manage_options = ZopePageTemplate.manage_options+(
+ {'label':'Main Config','action':'change_ECHO_localeForm'},
+ )
+
+ def change_ECHO_localeForm(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/ChangeECHO_localeForm.zpt')
+ return pt()
+
+ def change_ECHO_locale(self,lang,title,label,text=None,content_type=None,RESPONSE=None):
+ """change echo locale"""
+ self.lang=lang
+ self.title=title
+ self.label=label
+ if not text is None:
+ if content_type is None:
+ content_type = self.content_type
+ self.pt_edit(text, content_type)
+
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
-class scientificInformation(Folder,Persistent,Implicit):
- """outdated will be deleted in the next versions: subclass scientificInformation"""
- security=ClassSecurityInfo()
-
-
-
- def __init__(self,source_type,period):
+def manage_addECHO_localeForm(self):
+ """Form for adding"""
+ pt=zptFile(self, 'zpt/AddECHO_localeForm.zpt')
+ return pt()
- self.id="scientific_Information"
- self.source_type=source_type
- self.period=period
+def manage_addECHO_locale(self,lang,title,label,text=None,content_type=None,RESPONSE=None):
+ """add echo locale"""
+
+ id="locale_"+lang
+ self._setObject(id, ECHO_locale(id,lang,title,label,text,content_type))
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
- security.declarePublic('get_source_type')
- def get_source_type(self):
- return self.source_type
-
- security.declarePublic('get_period')
- def get_period(self):
- return self.period
+class ECHO_copyright(Folder,ECHO_basis):
+ """Copyright informationen"""
+ meta_type="ECHO_copyright"
+
+
+
+ def __init__(self,id,title,copyrights):
+ """init"""
+ self.title=title
+ self.id=id
+ self.copyrights=copyrights[0:]
+
+ def getCopyrights(self):
+ """return coyprights"""
+ return self.copyrights
+
+ manage_options = Folder.manage_options+(
+ {'label':'Main Config','action':'ECHO_copyright_configForm'},
+ )
+
+
+ def ECHO_copyright_configForm(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/ChangeECHO_copyright')
+ pt.content_type="text/html"
+ return pt()
+
+ def ECHO_copyright_config(self,title,RESPONSE=None):
+ """change"""
+ self.title=title
+ self.copyrights=[]
+ self.copyrights=getCopyrightsFromForm(self,self.REQUEST.form)[0:]
+
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+
+def manage_addECHO_copyrightForm(self):
+ """Form for adding"""
+ pt=zptFile(self, 'zpt/AddECHO_copyright.zpt')
+ return pt()
+
+def manage_addECHO_copyright(self, id,title,RESPONSE=None):
+ """add the copyright"""
+
+ meta_type="ECHO_copyright"
+
+ #first generate copyrights as list of tripels (mediaType,partner,copyrightType)
+
+
+
+ self._setObject(id, ECHO_copyright(id, title,getCopyrightsFromForm(self,self.REQUEST.form)))
-class ECHO_layoutTemplate(ZopePageTemplate):
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+class ECHO_layoutTemplate(ZopePageTemplate,ECHO_basis):
"""Create a layout Template for different purposes"""
meta_type="ECHO_layoutTemplate"
@@ -321,26 +315,20 @@ class ECHO_layoutTemplate(ZopePageTempla
def __init__(self, id, text=None, content_type=None,EchoType=None):
self.id = str(id)
-
-
self.ZBindings_edit(self._default_bindings)
if text is None:
- self._default_content_fn = os.path.join(package_home(globals()),
- 'zpt/ECHO_%s_template_standard.zpt'%EchoType)
+ self._default_content_fn = os.path.join(package_home(globals()),'zpt','ECHO_%s_template_standard.zpt'%EchoType)
text = open(self._default_content_fn).read()
+ if content_type is None:
+ content_type = self.content_type
self.pt_edit(text, content_type)
-
- """change form"""
-
def manage_addECHO_layoutTemplateForm(self):
"""Form for adding"""
- pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_layoutTemplate.zpt').__of__(self)
+ pt=zptFile(self, 'zpt/AddECHO_layoutTemplate.zpt')
return pt()
-from urllib import quote
-
def manage_addECHO_layoutTemplate(self, EchoType,title=None,REQUEST=None):
"Add a Page Template with optional file content."
@@ -381,456 +369,79 @@ def manage_addECHO_layoutTemplate(self,
REQUEST.RESPONSE.redirect(u+'/manage_main')
return ''
-class ECHO_resource(Folder):
- """ECHO Ressource"""
- meta_type='ECHO_resource'
-
- viewClassificationList=viewClassificationListMaster
-
- getSubCols = ECHO_helpers.getSubCols
- def getTitle(self):
- """title"""
- return self.title.encode('utf-8')
-
- def getLabel(self):
- """title"""
- return self.label.encode('utf-8')
-
- def content_html(self):
- """template fuer content"""
- return content_html(self,'resource')
-
- def getViewClassification(self):
- if hasattr(self,'viewClassification'):
- return self.viewClassification
- else:
- return ""
-
- def getFullTextXML(self,noredirect=None):
- """getFullTextXML"""
- try:
- fh=urllib.urlopen(self.metalink)
- dom=xml.dom.minidom.parse(fh)
- texttools=dom.getElementsByTagName('texttool')
- text=texttools[0].getElementsByTagName('text')
- texturl=getText(text[0].childNodes)
- if not noredirect:
- self.REQUEST.RESPONSE.redirect(texturl)
- else:
- return texturl
- except:
- return None
-
- def getCredits(self):
- """Ausgabe der credits"""
- if self.credits:
- return self.credits
- else:
- return []
-
- def __init__(self,id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords):
-
- self.id = id
- """Festlegen der ID"""
-
- self.label = label
- self.link= link
- self.metalink=metalink
- self.title=title
- self.weight=weight
- self.credits=toList(credits)
- self.description=description
- self.contentType=contentType
- self.responsible=responsible
-
- if coords:
- coordsnew=[ string.split(x,",") for x in coords]
- else:
- coordsnew=[]
-
- self.coords=coordsnew
-
+class ECHO_fullText(ZopePageTemplate,ECHO_basis,ECHO_language):
+ """echo fulltext in xml"""
- def getCoords(self):
- """gibt coordinaten als String zurück und löscht zugleich einträge die keine Koordinaten sind, letzteres zur korrektur der Eingabe der alten version"""
- retList=[]
- if hasattr(self,'coords'):
- for x in self.coords:
- if len(x)>1:
- retList.append(string.join(x,","))
- return retList
+ meta_type="ECHO_fullText"
-
-
- def getContentType(self):
- try:
- return self.contentType
- except:
- return ""
-
- def getCopyrightType(self):
- try:
- return self.copyrightType
- except:
- return ""
-
- def getRenderingType(self):
- try:
- return self.renderingType
- except:
- return ""
-
- def ECHO_resource_config(self):
- """Main configuration"""
-
- if not hasattr(self,'weight'):
- self.weight=""
-
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource.zpt').__of__(self)
- return pt()
-
-
- def ECHO_resource_config_main(self):
- """Main configuration"""
-
- if not hasattr(self,'weight'):
- self.weight=""
-
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource_main.zpt').__of__(self)
- return pt()
-
- def ECHO_resource_config_coords(self):
- """Coords configuration """
-
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource_coords.zpt').__of__(self)
- return pt()
-
- def ECHO_resource_config_credits(self):
- """Main configuration"""
-
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource_credits.zpt').__of__(self)
- return pt()
-
- def ECHO_resource_config_metadata(self):
- """Main configuration"""
-
- if (hasattr(self,'metadata')) and not (hasattr(self,'metaDataHash')):
- self.metaDataHash={}
- self.contentType=self.bib_type
- for data in self.metadata:
- data_neu=re.sub('-','_',data)
- self.metaDataHash[data_neu]=getattr(self,data)
- #print data_neu, getattr(self,data)
- #print self.metaDataHash,self.metadata
-
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource_metadata.zpt').__of__(self)
- return pt()
-
-
-
-
- def changeECHO_resource_main(self,metalink,link,title,label,description,contentType,renderingType,weight,resourceID,RESPONSE=None):
- """Änderung der Properties"""
- self.resourceID=resourceID
- self.title=title
- self.label=label
- self.description=description
-
- self.contentType=contentType
- self.renderingType=renderingType
- self.weight=weight
-
- self.link=link
- self.metalink=metalink
-
- if RESPONSE is not None:
- RESPONSE.redirect('manage_main')
-
-
- def changeECHO_resource_coords(self,coords,viewClassification,RESPONSE=None):
- """Änderung der Properties - coords"""
-
- if type(coords)==StringType:
- coords=[coords]
-
- try:
- coordsnew=[ string.split(x,",") for x in coords]
- except:
- coordsnew=[]
-
- self.coords=coordsnew[0:]
- self.viewClassification=viewClassification
- if RESPONSE is not None:
- RESPONSE.redirect('manage_main')
-
- def changeECHO_resource_credits(self,credits,responsible,copyrightType,RESPONSE=None):
- """Änderung der Properties"""
- self.credits=credits
- self.responsible=responsible
- self.copyrightType=copyrightType
+ def getPage(self,nr='1'):
+ """get page n"""
+ #return self().encode('latin-1','ignore')
+ try:
+ dom=xml.dom.minidom.parseString(self())
+ except:
+ dom=xml.dom.minidom.parseString(self.utf8ify(self()))
+ pages=dom.getElementsByTagName('page')
+
+ return pages[int(nr)-1].toxml()
- if RESPONSE is not None:
- RESPONSE.redirect('manage_main')
-
-
- def changeECHO_resource_metadata(self,RESPONSE=None):
- """change metadata"""
- tags=self.findTagsFromMapping(self.contentType)
- self.OSAS_meta={}
- for field in tags[1]:
- try:
- self.metaDataHash[self.getFieldTag(tags,field)]=self.REQUEST.form[self.getFieldTag(tags,field)]
- self.OSAS_meta[self.getFieldTag(tags,field)]=self.REQUEST.form['OSAS_%s'%self.getFieldTag(tags,field)]
- except:
- """nothing"""
-
- return urllib.urlopen('http://xserve02.mpiwg-berlin.mpg.de:18880/echo_nav/storage/downloadExternalXML?index_meta_url=%s&xml_url=%s'%(self.metalink,self.absolute_url()+'/newMetaXML')).read()
-
- if RESPONSE is not None:
- RESPONSE.redirect('manage_main')
-
+# Product registration and Add support
+manage_addECHO_fullTextForm = PageTemplateFile(
+ 'zpt/AddECHO_fullText.zpt', globals())
- def newMetaXML(self):
- """new index.meta"""
- self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
- return writeMetadata(self.metalink,self.OSAS_meta)
+def manage_addECHO_fullText(self, id, title=None, text=None,
+ REQUEST=None, submit=None):
+ "Add a Page Template with optional file content."
-
- def changeECHO_resource(self,metalink,link,title,label,description,contentType,responsible,weight,viewClassification="",coords=None,credits=None,RESPONSE=None):
- """Änderung der Properties"""
-
- try:
- coordsnew=[ string.split(x,",") for x in coords]
- except:
- coordsnew=[]
-
- setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
- self.viewClassification=viewClassification
- self.coords=coordsnew[0:]
- self.link=link
- self.metalink=metalink
-
- if RESPONSE is not None:
- RESPONSE.redirect('manage_main')
-
-
- manage_options = Folder.manage_options+(
- {'label':'Main Config','action':'ECHO_resource_config_main'},
- {'label':'Change Credits & Copyright','action':'ECHO_resource_config_credits'},
- {'label':'Change Metadata','action':'ECHO_resource_config_metadata'},
- {'label':'Change Coords','action':'ECHO_resource_config_coords'},
- {'label':'Add coords','action':'ECHO_graphicEntry'},
- {'label':'Sync Metadata','action':'ECHO_getResourceMD'},
- )
-
- def getOverview(self):
- """overview graphics"""
-
- return self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])[0][1]
-
- def ECHO_graphicEntry(self):
- """DO nothing"""
- overview = self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])
- if overview:
- pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_draw.zpt').__of__(self)
- return pt()
+ id = str(id)
+ if REQUEST is None:
+ self._setObject(id, ECHO_fullText(id, text))
+ ob = getattr(self, id)
+ if title:
+ ob.pt_setTitle(title)
+ return ob
+ else:
+ file = REQUEST.form.get('file')
+ headers = getattr(file, 'headers', None)
+ if headers is None or not file.filename:
+ zpt = ECHO_fullText(id)
else:
- return "NO OVERVIEW GRAPHICS"
-
- def ECHO_enterCoords(self,coordstr,angle="",RESPONSE=None):
- """Enter coords"""
- coords=self.coords
- temco=coordstr.split(",")
- temco.append(angle)
- coords.append(temco)
-
- self.coords=coords[0:]
-
- if RESPONSE is not None:
- RESPONSE.redirect('ECHO_graphicEntry')
-
-
- def isDefinedInThisSet(self,fields,field):
- """checks if field is defined in fields"""
- if (fields[0].has_key(field)) and not (fields[0][field]==""):
- return 1
- else:
-
- return 0
-
- def getFieldLabel(self,fields,field):
- """get labels"""
- try:
- ret =fields[0][field]
- if ret == "":
- return field
- else:
- return ret
- except:
- return field
-
+ zpt = ECHO_fullText(id, file, headers.get('content_type'))
+ self._setObject(id, zpt)
- def getFieldTag(self,fields,field):
- """get labels"""
try:
- ret =fields[0][field]
- if ret == "":
- return field
- else:
- return ret
- except:
- return field
-
-
-
- def getFieldValue(self,field):
- """get value"""
- #print field
- try:
-
- ret=self.metaDataHash[field]
- if ret == "":
- return None
- else:
- return ret
- except:
- return None
-
- def findLabelsFromMapping(self,referenceType):
- """gib hash mit label -> generic zurueck"""
- self.referencetypes=self.ZopeFind(self.standardMD)
- #print "RT",referenceType
-
- bibdata={}
- retdata={}
- fieldlist=self.standardMD.fieldList
-
- for referenceTypeF in self.referencetypes:
- #print referenceTypeF[1].title,referenceType
- if referenceTypeF[1].title.lower() == referenceType.lower():
- #print "OK"
- try:
- bibdata[referenceTypeF[1].title]=referenceTypeF[1].fields
- referenceType=referenceTypeF[1].title
- except:
- bibdata[referenceType]=referenceTypeF[1].fields
-
-
- bibdata['data']=referenceTypeF[1]
- self.fields=bibdata[referenceType]
- for field in fieldlist:
- retdata[field]=referenceTypeF[1].getValue(field)[1]
- #print retdata,fieldlist
- return retdata,fieldlist
-
- def findTagsFromMapping(self,referenceType):
- """gib hash mit label -> generic zurueck"""
- self.referencetypes=self.ZopeFind(self.standardMD)
-
-
- bibdata={}
- retdata={}
- fieldlist=self.standardMD.fieldList
-
- for referenceTypeF in self.referencetypes:
-
- if referenceTypeF[1].title.lower() == referenceType.lower():
- try:
- bibdata[referenceTypeF[1].title]=referenceTypeF[1].fields
- referenceType=referenceTypeF[1].title
- except:
- bibdata[referenceType]=referenceTypeF[1].fields
- bibdata['data']=referenceTypeF[1]
- self.fields=bibdata[referenceType]
- for field in fieldlist:
- retdata[field]=referenceTypeF[1].getValue(field)[0]
-
- return retdata,fieldlist
-
-
-
-
- def ECHO_getResourceMD(self,template="yes"):
- """Einlesen der Metadaten und Anlegen dieser Metadaten als Informationen zur Resource"""
- (metadict, error)=readMetadata(self.metalink)
-
-
-
- if not error=="": #Fehler beim Auslesen des Metafiles
- return "ERROR:",error
-
-
- if not (metadict['bib_type'].lower()==self.contentType.lower()):
- self.REQUEST.SESSION['contentStorage']=metadict['bib_type']
- self.REQUEST.SESSION['contentZope']=self.contentType
-
- return PageTemplateFile('Products/ECHO_content/zpt/ECHO_getResourceMDErrorContentType.zpt').__of__(self)()
-
- self.REQUEST.SESSION['metadict']=metadict
-
- self.REQUEST.SESSION['diffs']=checkDiffs(self,metadict)
-
-
- if template=="yes":
- pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_resourceMD.zpt').__of__(self)
- return pt()
-
-
-
-
- def ECHO_getMD(self,item):
- """Ausgabe der MD"""
- return getattr(self,item)
-
- def index_html(self):
- """standard page"""
-
- return self.REQUEST.RESPONSE.redirect(self.link)
-
- def generate_label(self):
- """Erzeugt_standard_Label aus Template"""
- pt=getattr(self,"label_template_"+self.bib_type)
-
- return pt()
-
-def manage_addECHO_resourceForm(self):
- """Form for adding a ressource"""
- pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_resourceForm.zpt').__of__(self)
- return pt()
-
-
-
-def manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
- """addaresource"""
+ u = self.DestinationURL()
+ except AttributeError:
+ u = REQUEST['URL1']
+
+ if submit == " Add and Edit ":
+ u = "%s/%s" % (u, urllib.quote(id))
+ REQUEST.RESPONSE.redirect(u+'/manage_main')
+ return ''
- newObj=ECHO_resource(id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords)
- self._setObject(id,newObj)
- if RESPONSE is not None:
- 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"""
- return self.title.encode('utf-8')
-
- def getLabel(self):
- """title"""
- return self.label.encode('utf-8')
-
+ security.declarePublic('content_html')
def content_html(self):
"""template fuer content"""
- return content_html(self,'externalLink')
+ ret= ECHO_basis.content_html(self,'externalLink')
+
+ if type(ret) is StringType:
+ return ret.decode('utf-8')
+ else:
+ return ret
+
+
- 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,linkType):
self.id = id
"""Festlegen der ID"""
@@ -845,6 +456,8 @@ class ECHO_externalLink(Folder):
self.responsible=responsible
coordsnew=[ string.split(x,",") for x in coords]
self.coords=coordsnew
+ self.linkType = linkType # Linktypen 'otherPresentation','external'
+
def ECHO_externalLink_config(self):
"""Main configuration"""
@@ -854,54 +467,67 @@ class ECHO_externalLink(Folder):
if not hasattr(self,'coords'):
self.coords=['']
- #print "G",self.coords
- pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_externalLink.zpt').__of__(self)
+
+ pt=zptFile(self, 'zpt/ChangeECHO_externalLink.zpt')
return pt()
- def changeECHO_externalLink(self,link,title,label,description,contentType,responsible,weight,coords=None,credits=None,RESPONSE=None):
-
- """Änderung der Properties"""
- try:
- coordsnew=[ string.split(x,",") for x in coords]
- except:
- coordsnew=[]
-
- setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coords)
+ def changeECHO_externalLink(self,link,title,label,description,contentType,responsible,weight,coords=None,credits=None,RESPONSE=None,linkType='otherPresentation'):
+ """Aenderung der Properties"""
+ setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight)
- self.coords=coordsnew[0:]
self.link=link
+ self.linkType = linkType
if RESPONSE is not None:
RESPONSE.redirect('manage_main')
+ def getLinkType(self):
+ """ return linkType """
+ if hasattr(self,"linkType"):
+ return self.linkType
+ else :
+ return 'otherPresentation'
+
+ def setLinkType(self,type):
+ """ set linkType """
+ self.linkType = type
+
+ def checkLink(self):
+ """ returns tuple (isWorking,Error) """
+ try:
+ urllib2.urlopen(self.link)
+ return (True, '')
+ except urllib2.HTTPError, e:
+ return (False, e.code)
+ except urllib2.URLError, e:
+ return (False, str(e.reason))
+ except:
+ return (False, 'unknown Error')
- manage_options = Folder.manage_options+(
+
+ manage_options = (
{'label':'Main Config','action':'ECHO_externalLink_config'},
- )
+ {'label':'Graphic Coords','action':'ECHO_graphicEntry'},
+ )+Folder.manage_options
- def getCredits(self):
- """Ausgabe der credits"""
- if self.credits:
- return self.credits
- else:
- return []
def index_html(self):
"""standard page"""
return self.REQUEST.RESPONSE.redirect(self.link)
+
def manage_addECHO_externalLinkForm(self):
"""Form for external Links"""
- pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_externalLinkForm.zpt').__of__(self)
+ pt=zptFile(self, 'zpt/AddECHO_externalLinkForm.zpt')
return pt()
-def manage_addECHO_externalLink(self,id,title,label,description,contentType,responsible,link,weight,coords=None,credits=None,RESPONSE=None):
+def manage_addECHO_externalLink(self,id,title,label,description,contentType,responsible,link,weight,coords=None,credits=None,RESPONSE=None,linkType='otherPresentation'):
"""Add an external Link"""
- newObj=ECHO_externalLink(id,link,title,label,description,contentType,responsible,credits,weight,coords)
+ newObj=ECHO_externalLink(id,link,title,label,description,contentType,responsible,credits,weight,coords,linkType)
self._setObject(id,newObj)
@@ -910,78 +536,693 @@ def manage_addECHO_externalLink(self,id,
class ECHO_link(ECHO_externalLink):
- """external_link"""
+ """external_link"""
+
+ meta_type="ECHO_link"
+
+ manage_options = ECHO_externalLink.manage_options+(
+ {'label':'add links config','action':'ECHO_link_addLinksForm'},
+ )
+
+ def getMDValueSimpleSearchField(self):
+ """returns value for simple search"""
+ return " ".join([self.getTitle(),self.getDescription()])
+
+ def ECHO_link_addLinksForm(self):
+ """Main configuration"""
+
+ pt=zptFile(self, 'zpt/ChangeECHO_link_addLinks.zpt')
+ return pt()
+
+ def ECHO_link_addLinks(self,addLinks,RESPONSE):
+ """add links"""
+ self.addLinks=addLinks
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+ def content_html(self):
+ """template fuer link"""
+
+
+ if hasattr(self,"link_template"):
+ ret=ECHO_basis.content_html(self,'link')
+
+ else:
+ ret=ECHO_basis.content_html(self,'collection')
+
+
+ #return ret
+ return ret
+#
+#
+# try:
+# return ret.decode('utf-8')
+# except:
+# try:
+# return ret.decode('latin-1')
+# except:
+#
+# return ret
+#
+ def getCopyrightsHTML(self):
+ """gib (link auf copyright link, mediatyp, institution, copyrightType, label von copyrightType) aus"""
+
+ if hasattr(self,'copyrightModel'):
+ obj=self.copyrightModel
+
+ else:
+ return "ERROR"
+ ret=[]
+
+ for copyright in obj.getCopyrights(): #copyright - media / partner / copyrightID
+
+
+ try:
+ if hasattr(self.copyrightTypes,copyright[2]):
+ copyrightTypeObj=getattr(self.copyrightTypes,copyright[2])
+ link="copyrightTypes/"+copyright[2]+'/copyright.html'
+ else:
+ copyrightTypeObj=getattr(obj,copyright[2])
+ link="copyrightModel/"+copyright[2]+'/copyright.html'
+
+ label=copyrightTypeObj.label
+ url=getattr(copyrightTypeObj, 'url', '')
+
+ if url!='':
+ ret.append((url,copyright[0],copyright[1],copyright[2],label))
+ else:
+ if hasattr(copyrightTypeObj, 'copyright.html'):
+ ret.append(("""%s?partner=%s"""%(link,copyright[1]),copyright[0],copyright[1],copyright[2],label))
+ else:
+ ret.append(('empty',copyright[0],copyright[1],copyright[2],label))
+ except:
+ """nothing"""
+
+ return ret
+
+ def getInstitutionsHTML(self):
+ """gibt Liste der foerdernden Institutionen aus"""
+
+ if hasattr(self,'support'):
+ obj=self.support
+ ret=obj.getSupporter()
+ return ret
+ else:
+ return ''
+
+ def getOwnerOriginalsHTML(self):
+ """gibt Liste der foerdernden Institutionen aus"""
+
+ if hasattr(self,'ownerOriginal'):
+ obj=self.ownerOriginal
+ ret=obj.getOwner()
+ return ret
+ else:
+ return ''
+
+ def getDigiCopyByHTML(self):
+ """gibt Liste der foerdernden Institutionen aus"""
+
+ if hasattr(self,'digiCopyBy'):
+ obj=self.digiCopyBy
+ ret=obj.getDigiCopyBy()
+ return ret
+ else:
+ return ''
+
+ def index_html(self):
+ """standard link"""
+ if self.link:
+ splitted=self.link.split("?")
+ if len(splitted)>1:
+ params=cgi.parse_qs(splitted[1])
+
+ for x in params.keys():
+ if type(params[x]) is ListType:
+ params[x]=params[x][0]
+
+
+ else:
+ params={}
+
+ if getattr(self,'addLinks','yes')=="yes":
+ params['backLink']=self.aq_parent.absolute_url()
+ params['startLink']=splitted[0]+"?"+urllib.urlencode(params)
+
- meta_type="ECHO_link"
-
+ return self.REQUEST.RESPONSE.redirect(splitted[0]+"?"+urllib.urlencode(params))
+ else:
+ return ""
- def content_html(self):
- """template fuer link"""
- if hasattr(self,"link_template"):
- return content_html(self,'link')
- else:
- return content_html(self,'collection')
-
def manage_addECHO_linkForm(self):
"""Form for external Links"""
- pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_linkForm.zpt').__of__(self)
+ pt=zptFile(self, 'zpt/AddECHO_linkForm.zpt')
return pt()
-def manage_addECHO_link(self,id,title,label,description,contentType,responsible,link,weight,coords=None,credits=None,RESPONSE=None):
+def manage_addECHO_link(self,id,title,label,description="",contentType="",responsible="",link="",weight="",coords=[],credits=None,linkType="external",RESPONSE=None):
"""Add an external Link"""
- newObj=ECHO_link(id,link,title,label,description,contentType,responsible,credits,weight,coords)
+ newObj=ECHO_link(id,link,title,label,description,contentType,responsible,credits,weight,coords,linkType)
self._setObject(id,newObj)
-
+
+ getattr(self,id).addLinks='no'
+
if RESPONSE is not None:
RESPONSE.redirect('manage_main')
-
+
-class ECHO_collection(Folder, Persistent, Implicit):
+class ECHO_collection(CatalogAware, Folder, Persistent, Implicit, Cacheable,ECHO_basis):
"""ECHO Collection"""
+ management_page_charset="utf-8"
security=ClassSecurityInfo()
meta_type='ECHO_collection'
- viewClassificationList=viewClassificationListMaster
+ default_catalog='resourceCatalog'
+
+ rootMetaTypes = ['ECHO_root', 'ECHO_main', 'ECHO_nav']
+
+# viewClassificationList=viewClassificationListMaster
displayTypes=displayTypes
- def getViewClassification(self):
- if hasattr(self,'viewClassification'):
- return self.viewClassification
- else:
- return ""
+ path="/mpiwg/online/permanent/shipbuilding"
- def getTitle(self):
- """title"""
- return self.title.encode('utf-8')
+ def getSection(self, crumbs=None):
+ """returns the current section name"""
+ # use breadcrumbs if available
+ if crumbs is not None and len(crumbs) > 0:
+ return crumbs[0][2].getId()
+
+ p = self
+ sec = None
+ # descend parents to the root (and remember the last id)
+ while p is not None and p.meta_type not in self.rootMetaTypes:
+ sec = p.getId()
+ p = aq_parent(p.context)
+
+ return sec
+
+ def getSubSection(self, crumbs=None):
+ """returns the current subsection name"""
+ # use breadcrumbs if available
+ if crumbs is not None and len(crumbs) > 1:
+ return crumbs[1][2].getId()
+
+ p = self
+ sec = None
+ subsec = None
+ # descend parents to the root (and remember the last id)
+ while p is not None and p.meta_type not in self.rootMetaTypes:
+ subsec = sec
+ sec = p.getId()
+ p = aq_parent(p.context)
+
+ return subsec
+
+
+ def getCrumb(self):
+ """returns breadcrumb for this object"""
+ return ECHO_helpers.getCrumb(self)
+
+ def getHierCrumbs(self):
+ """returns a list of hierarchical breadcrumbs from self to the ECHO_root"""
+ return ECHO_helpers.getHierCrumbs(self)
+
+
+ def exportImportObjects_html(self,RESPONSE):
+ """ImportObject"""
+ pt=zptFile(self, 'zpt/exportImportObjects.zpt')
+ pt.content_type="text/html"
+ return pt()
+
+ def importObjects_html(self,RESPONSE):
+ """ImportObject"""
+ pt=zptFile(self, 'zpt/importObjects.zpt')
+ pt.content_type="text/html"
+ return pt()
+
+ def importObjects(self,zfile,RESPONSE=None,REQUEST=None):
+ """import object from file"""
+
+ zf=zipfile.ZipFile(zfile,"r")
+ tmpdir=tempfile.mkdtemp() # create tempdir
+ ret=None
+
+ for name in zf.namelist():
+ ds,fn=tempfile.mkstemp()
+ tf=file(fn,"w")
+ x=zf.read(name)
+ tf.write(x)
+ tf.close()
+ try:
+ self._importObjectFromFile(fn,set_owner=1)
+ except:
+ if not ret:
+ ret=""
+ ret+="Cannot import: %s (Already existing?) "%name
+ os.close(ds)
+ os.remove(fn)
+
+ zf.close()
+
+ if ret:
+ return """
%s"""%ret
+ if RESPONSE:
+ RESPONSE.redirect(self.absolute_url())
+
+ def exportObjects_html(self,RESPONSE):
+ """Export objects"""
+
+ pt=zptFile(self, 'zpt/exportObjects.zpt')
+ pt.content_type="text/html"
+ return pt()
+
+ def exportObjects(self,ids,RESPONSE=None):
+ """export objects with type id"""
+ if not (type(ids) is ListType):
+ ids=[ids]
+
+ tmpdir=tempfile.mkdtemp() # create tempdir
+ objs=self.ZopeFind(self,obj_ids=ids)
+ tmpfile=tempfile.mkstemp()[1]
+
+ zf=zipfile.ZipFile(tmpfile,"w")
+ for obj in objs:
+
+ f = os.path.join(tmpdir, '%s.zexp' %obj[0])
+ #print E.absolute_url()
+
+ obj[1]._p_jar.exportFile(obj[1]._p_oid, f)
+
+ zf.write(f,obj[0])
+
+ zf.close()
+ shutil.rmtree(tmpdir)
+ if RESPONSE:
+ RESPONSE.setHeader("Content-Type","application/octet-stream")
+ len=os.stat(tmpfile)[6]
+ RESPONSE.setHeader("Content-Length",len)
+ RESPONSE.setHeader("Content-Disposition","""attachement; filename=%s"""%"export.zip")
+ fh=file(tmpfile)
+ for x in fh.read():
+ RESPONSE.write(x)
+ fh.close()
+
+ def getMDValueSimpleSearchField(self):
+ """returns value for simple search"""
+ return " ".join([self.title,self.description])
+
+ def getTitleAndLabel(self):
+ """gibt title und label zurueck"""
+ return (getattr(self,'title',''),getattr(self,'label',''))
+
+ def localizeObjects(self):
+ """localize all objects"""
+ contents=self.ZopeFind(self,obj_metatypes=['ECHO_externalLink','ECHO_link','ECHO_mapText'])
+
+ find=self.ZopeFind(self,obj_ids=('locale_en'))
+ if not find:
+ self.manage_addECHO_locale("en",'','')
+ for content in contents:
+
+ if content[1].meta_type in ['ECHO_link','ECHO_externalLink']:
+
+ find=content[1].ZopeFind(content[1],obj_metatypes=('ECHO_mapText'))
+ if find:
+ root=find[0][1]
+
+ locale=find[0][1].ZopeFind(find[0][1],obj_ids=('locale_en'))
+ else:
+ root=None
+ else:
+ root=content[1]
+ locale=content[1].ZopeFind(content[1],obj_ids=('locale_en'))
+ if root and not locale:
+ root.manage_addECHO_locale("en",'','')
+
+ pt=zptFile(self, 'zpt/localizeObjects.zpt')
+ return pt()
- def getLabel(self):
- """title"""
- return self.label.encode('utf-8')
+ def localize(self,REQUEST,RESPONSE):
+ """localize"""
+ for key in REQUEST.form.keys():
+ splitted=key.split("!")
+
+ if splitted[0]=="" or splitted[0]=="en" or splitted[0]=="title" or splitted[0]=="label":
+ if splitted[0]=="en":
+ setattr(self.locale_en,splitted[1],REQUEST.form[key])
+ else:
+ setattr(self,splitted[0],REQUEST.form[key])
+ else:
+ obj=getattr(self,splitted[0])
+
+ if obj.meta_type=="ECHO_mapText":
+ if splitted[1]=="en":
+ obj.locale_en.pt_edit(REQUEST.form[key],obj.locale_en.content_type)
+ else:
+ obj.pt_edit(REQUEST.form[key],obj.content_type)
+ else:
+ text=obj.ZopeFind(obj,obj_metatypes=['ECHO_mapText'])
+ if splitted[1]=="en":
+
+ text[0][1].locale_en.pt_edit(REQUEST.form[key],text[0][1].locale_en.content_type)
+ else:
+ text[0][1].pt_edit(REQUEST.form[key],text[0][1].content_type)
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+
+ def getRDF(self,urn=None):
+ """rdf of the collection"""
+
+ contents=self.ZopeFind(self,obj_metatypes=['ECHO_group','ECHO_resource','ECHO_collection'])
+
+ ret=getRDFDescription(self,self.absolute_url(),urn=urn)
+
+ if not urn:
+ urn=self.absolute_url()
+
+ li="""\n"""
+
+
+ for content in contents:
+ try:
+ ret+=content[1].getRDF()+"\n"
+ except:
+ logging.error("getrdf: "+repr(content[1].getRDF()))
+ try:
+ ret+=self.unicodify(content[1].getRDF())+"\n"
+ except:
+ logging.error("--still cannot do it")
+ ret+=repr(content[1].getRDF())+"\n"
+ ret+="""\n"""%urn
+ for content in contents:
+ nurn=content[1].absolute_url()
+ ret+=li%nurn
+ return ret+""
+
+
+
+ def changeLabels(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/changeLabelsForm')
+ pt.content_type="text/html"
+ return pt()
+
+ def changeTitles(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/changeTitleForm')
+ pt.content_type="text/html"
+ return pt()
+
+ def changeWeights(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/changeWeightForm')
+ pt.content_type="text/html"
+ return pt()
+
+ def changeMetaDataLinks(self):
+ """change form"""
+ pt=zptFile(self, 'zpt/changeMetaDataLinkForm')
+ pt.content_type="text/html"
+ return pt()
+
+ def changeAccessRightsCollectionForm(self,preselect=None):
+ """change access rights of all resources in this collection"""
+
+ pt=zptFile(self, 'zpt/changeAccessRightsCollectionForm')
+ pt.content_type="text/html"
+ return pt(preselect=preselect)
+
+
+ def changeAccessRightsCollection(self):
+ """change"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'])
+ for resource in resources:
+
+ if argv.has_key(resource[1].getId()+'_xml'):
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()+'_xml']+""
+ resource[1].setAccessRightXML(argv[resource[1].getId()+'_xml'])
+ resource[1].accessRight=argv[resource[1].getId()+'_xml']
+ elif argv.has_key(resource[1].getId()+'_echo'):
+ ret+="only local:"+resource[1].getId()+" "+argv[resource[1].getId()+'_echo']+""
+ resource[1].accessRight=argv[resource[1].getId()+'_echo']
+ else:
+ ret+="ERROR:" +resource[0]
+ return ret
+
+ def changeMetaDataLinkInCollection(self):
+ """change all lables of a collection"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'])
+ for resource in resources:
+
+ try:
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()]+""
+ resource[1].metalink=argv[resource[1].getId()][0:]
+ except:
+ pass
+ return ret
+
+ def changeMetaDataLinkInCollection(self):
+ """change all lables of a collection"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'])
+ for resource in resources:
+
+ try:
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()]+""
+ resource[1].metalink=argv[resource[1].getId()][0:]
+ except:
+ pass
+ return ret
+
+ def changeWeightsInCollection(self):
+ """change all lables of a collection"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_pageTemplate','ECHO_movie','ECHO_resource','ECHO_collection','ECHO_link','ECHO_externalLink'])
+ for resource in resources:
+
+ try:
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()]+""
+ resource[1].weight=argv[resource[1].getId()][0:]
+ except:
+ pass
+ return ret
+
+ def changeTitlesInCollection(self):
+ """change all lables of a collection"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_pageTemplate','ECHO_movie','ECHO_resource','ECHO_collection','ECHO_link','ECHO_externalLink'])
+ for resource in resources:
+
+ try:
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()]+""
+ resource[1].title=argv[resource[1].getId()][0:]
+ except:
+ pass
+ return ret
+
+ def changeLabelsInCollection(self):
+ """change all lables of a collection"""
+ ret=""
+ argv=self.REQUEST.form
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_pageTemplate','ECHO_movie','ECHO_resource','ECHO_collection','ECHO_link','ECHO_externalLink'])
+ for resource in resources:
+
+ try:
+ ret+=resource[1].getId()+" "+argv[resource[1].getId()]+""
+ resource[1].label=argv[resource[1].getId()][0:]
+ except:
+ pass
+ return ret
+
+ def importCollection(self,path=None,viewerUrl=None,metaDataUrl=None,replacePathPermanent=None,replacePathExperimental=None,RESPONSE=None):
+ """liest verzeichnisse aus dem pfad und legt sie dann als objekte in den ordner"""
+
+ if path is None:
+ pt=zptFile(self, 'zpt/importCollection.zpt')
+ return pt()
+
+ files=os.listdir(path)
+ ret=""
+ for fileName in files:
+
+ if fileName:
+
+ if (replacePathExperimental and replacePathExperimental!=''):
+ path=re.sub(replacePathExperimental,"/mpiwg/online/experimental",path)
+
+ if (replacePathPermanent and replacePathPermanent!=''):
+ path=re.sub(replacePathPermanent,"/mpiwg/online/permanent",path)
+
+ link=viewerUrl%(path+"/"+fileName+"/pageimg")
+
+ metalink=metaDataUrl+"/"+path+"/"+fileName+"/index.meta"
+ try:
+
+ #link="http://nausikaa2.mpiwg-berlin.mpg.de/cgi-bin/toc/toc.x.cgi?dir="+fileName+"&step=thumb"
+
+ newObj=ECHO_resource(fileName,link,metalink,fileName,fileName,fileName,'','book','','','','','','')
+ self._setObject(fileName,newObj)
+
+ genObj=getattr(self,fileName)
+ #genObj.createIndexFile()
+ ret+="OK:"+fileName+" "
+ except:
+ print "ERROR"
+ ret+="ERROR:"+fileName+" "
+
+ return ret
+
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+
+ def changeViewerForm(self):
+ """change the viewer template set"""
+ pt=zptFile(self, 'zpt/changeECHOViewer')
+ return pt()
+
+ def getTextToolsField(self,name,default=''):
+ """Lese text tool field der Collection not implemented yet!"""
+
+ return default
+
+
+
+ def changeViewer(self,newViewer,REQUEST=None,RESPONSE=None):
+ """changes all ressources to the newViewer"""
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'],search_sub=1)
+ if RESPONSE is not None:
+ RESPONSE.write("")
+
+ for resource in resources:
+
+ done,msg=resource[1].changeViewer(newViewer)
+ if done:
+ if RESPONSE is not None:
+ RESPONSE.write("
OK: %s"%resource[0])
+ else:
+ if RESPONSE is not None:
+ RESPONSE.write("
ERROR: %s (%s)"%(resource[1].absolute_url()+'/ECHO_resource_config_main',resource[0],msg))
+
+
+
+ if RESPONSE is not None:
+ RESPONSE.write("
Done
")
+
+
+
+ def copyTitleToInfoXMLFolder(self,RESPONSE=None):
+ """copy title into the title field of info.xml
+ author and date werden leer!!!
+ """
+
+
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'],search_sub=1)
+
+
+ for resource in resources:
+ ret,txt=resource[1].copyTitleToInfoXML()
+ if (not ret) and RESPONSE:
+ RESPONSE.write("error: %s\n"%txt)
+ if ret and RESPONSE:
+ RESPONSE.write("ok: %s\n"%txt)
+
+ #logger("ECHO (copyTitleToInfoXMLFolder)",logging.INFO,txt)
+ if RESPONSE is not None:
+ RESPONSE.write("done!\n")
+ RESPONSE.close()
+ RESPONSE.redirect('manage_main')
+
+ def copySearchFields(self,RESPONSE=None):
+ """copys < metadatafields to the object"""
+ resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'],search_sub=1)
+
+ for resource in resources:
+
+ resource[1].copySearchFields()
+
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
+
-
+ def getPartnerCopyright(self,name,sonst="generic"):
+ """gibt generisches copyright eines partners aus, sonst behalte jetzige einsteillung"""
+ #print "hi",name,sonst
+ #print getattr(self.partners,name).copyrightType
+ try:
+ partner=getattr(self.partners,name)
+ return partner.copyrightType
+ except:
+ print "error"
+ return sonst
+
+ def partnerSelector_HTML(self,selected=None):
+ """give type selector"""
+ if not selected:
+ retStr="