version 1.232, 2005/08/15 13:34:04
|
version 1.260, 2005/12/13 12:45:21
|
Line 1
|
Line 1
|
|
|
|
|
"""New version of the product started February, 8th. Without scientific classification, use content-type for further classification.""" |
"""New version of the product started February, 8th. Without scientific classification, use content-type for further classification.""" |
"""Echo collection provides the classes for the ECHO content web-site. |
"""Echo collection provides the classes for the ECHO content web-site. |
|
|
Line 17 try:
|
Line 15 try:
|
except: |
except: |
print "PDF generation will not work" |
print "PDF generation will not work" |
|
|
|
import urlparse |
import string |
import string |
import tempfile |
import tempfile |
import re |
import re |
Line 39 from Products.PageTemplates.PageTemplate
|
Line 37 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 Products.ZCatalog.CatalogPathAwareness import CatalogAware |
|
|
import urllib |
import urllib |
import cgi |
import cgi |
import smtplib |
import smtplib |
import time |
import time |
from Ft.Xml.Domlette import NonvalidatingReader |
from Ft.Xml.Domlette import NonvalidatingReader |
from Ft.Xml.Domlette import PrettyPrint |
from Ft.Xml.Domlette import PrettyPrint, Print |
from Ft.Xml import EMPTY_NAMESPACE |
from Ft.Xml import EMPTY_NAMESPACE |
|
|
import Ft.Xml.XPath |
import Ft.Xml.XPath |
import cStringIO |
import cStringIO |
import zLOG |
import zLOG |
|
import sys |
|
|
try: |
try: |
from psycopg import libpq |
from psycopg import libpq |
Line 68 import ECHO_helpers
|
Line 68 import ECHO_helpers
|
from ECHO_helpers import * |
from ECHO_helpers import * |
from ECHO_language import * |
from ECHO_language import * |
from ECHO_movie import * |
from ECHO_movie import * |
|
import vlp_xmlhelpers #TODO: vlp elemente aus echo herausnehmen |
#regexp for extracting elements from xml |
import xmlrpclib |
patternTXT=r"<\s*txt.*?>(.*?)</txt>" |
|
regexpTXT = re.compile(patternTXT, re.IGNORECASE + re.DOTALL) |
|
patternPage=r"<\s*page.*?>(.*?)</page>" |
|
regexpPage = re.compile(patternPage, re.IGNORECASE + re.DOTALL) |
|
|
|
|
|
|
|
def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs=""): |
def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs=""): |
Line 89 def setECHO_collectionInformation(self,t
|
Line 84 def setECHO_collectionInformation(self,t
|
self.credits=toList(credits) |
self.credits=toList(credits) |
self.weight=weight |
self.weight=weight |
|
|
|
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'}, |
|
) |
|
|
|
|
|
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): |
class ECHO_locale(ZopePageTemplate): |
"""localisierung""" |
"""localisierung""" |
|
|
Line 304 def manage_addECHO_fullText(self, id, ti
|
Line 383 def manage_addECHO_fullText(self, id, ti
|
return '' |
return '' |
|
|
|
|
class ECHO_resource(Folder,Persistent,ECHO_basis): |
class ECHO_resource(CatalogAware,Folder,Persistent,ECHO_basis): |
"""ECHO Ressource""" |
"""ECHO Ressource""" |
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
meta_type='ECHO_resource' |
meta_type='ECHO_resource' |
|
default_catalog='resourceCatalog' |
|
|
# viewClassificationList=viewClassificationListMaster |
# viewClassificationList=viewClassificationListMaster |
|
|
|
def PrincipiaSearchSource(self): |
|
"""Return cataloguable key for ourselves.""" |
|
return str(self) |
|
|
getSubCols = ECHO_helpers.getSubCols |
getSubCols = ECHO_helpers.getSubCols |
|
|
|
def reindex(self): |
|
"""generate fields for indexing and reindex""" |
|
|
|
#TODO: korrigieren des metalink pfades konfigurierbar machen |
|
splitted= [x for x in urlparse.urlparse(self.metalink)] |
|
splitted[1]="foxridge.mpiwg-berlin.mpg.de"[0:] |
|
|
|
if splitted[0]=="http": |
|
self.metalink=urlparse.urlunparse(splitted) |
|
|
|
|
|
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') |
security.declareProtected('View','createPDF') |
def createPDF(self,RESPONSE=None,local=None,dpi=150): |
def createPDF(self,RESPONSE=None,local=None,dpi=150): |
Line 403 class ECHO_resource(Folder,Persistent,EC
|
Line 512 class ECHO_resource(Folder,Persistent,EC
|
return ret+self.createSubElementRDF(urn=urn) |
return ret+self.createSubElementRDF(urn=urn) |
|
|
|
|
def getAccessRightSelectorHTML(self,outlook="select"): |
def changeAccessRightForm(self,preselect=None): |
"""htmlselector""" |
"""change the access rights""" |
values=['free','mpiwg'] |
|
|
|
if outlook=="select": |
pt=zptFile(self, 'zpt/ChangeECHO_resourceAccessRight.zpt') |
ret="""<select name="%s">"""%self.getId() |
return pt(preselect=preselect) |
|
|
|
def changeAccessRight(self): |
|
"""changeRights""" |
|
argv=self.REQUEST.form |
|
self.setAccessRightXML(argv["%s_xml"%self.getId()]) |
|
self.accessRight=argv["%s_echo"%self.getId()] |
|
|
|
self.REQUEST.RESPONSE.redirect('manage_main') |
|
|
|
|
|
def getAccessRightSelectorHTML(self,outlook="select",xmldominant=None,preselect=None): |
|
"""htmlselector, xmldominant= in der regel wird der wert des xmlfiles ausgegeben ausser er existiert nicht""" |
|
values=['','free','MPIWG'] |
|
|
|
if preselect:#set all to the preselected |
|
ar=(preselect,preselect) |
|
else:#else set to actual value |
|
ar=self.getAccessRightMD() |
|
|
|
if outlook=="select": |
|
ret="""<select name="%s_xml">"""%self.getId() |
|
ret1="""<select name="%s_echo">"""%self.getId() |
for value in values: |
for value in values: |
if value==self.getAccessRightMD(): |
if value==ar[0]: |
ret+="<option selected>%s</option>"%value |
ret+="<option selected>%s</option>"%value |
else: |
else: |
ret+="<option>%s</option>"%value |
ret+="<option>%s</option>"%value |
|
|
|
if value==ar[1]: |
|
ret1+="<option selected>%s</option>"%value |
|
else: |
|
ret1+="<option>%s</option>"%value |
|
|
|
|
|
if not xmldominant: |
|
return ret+"</select>",ret1+"</select>" |
|
else: |
|
if ar[0] is not None: |
return ret+"</select>" |
return ret+"</select>" |
|
else: |
|
return "<p>No xml file (only local selection):"+ret1 |
|
|
else: |
else: |
ret="" |
ret="" |
|
ret1="" |
for value in values: |
for value in values: |
|
|
if value==self.getAccessRightMD(): |
if value==ar[0]: |
ret+="""<input type="radio" name="%s" value="%s" checked>%s"""%(self.getId(),value,value) |
ret+="""<input type="radio" name="%s_xml" value="%s" checked>%s"""%(self.getId(),value,value) |
else: |
else: |
ret+="""<input type="radio" name="%s" value="%s">%s"""%(self.getId(),value,value) |
ret+="""<input type="radio" name="%s_xml" value="%s">%s"""%(self.getId(),value,value) |
|
|
|
if value==ar[1]: |
|
ret1+="""<input type="radio" name="%s_echo" value="%s" checked>%s"""%(self.getId(),value,value) |
|
else: |
|
ret1+="""<input type="radio" name="%s_echo" value="%s">%s"""%(self.getId(),value,value) |
|
|
|
if not xmldominant: |
|
return ret,ret1 |
|
else: |
|
if ar[0]: |
return ret |
return ret |
|
else: |
|
return "<p>No xml file (only local selection)</p>"+ret1 |
|
|
|
|
|
|
|
def copyAccessRightsFromMD(self): |
|
"""kopiere rechte aus den metadaten""" |
|
self.accessRight=self.getAccessRightMD()[0] |
|
|
|
|
|
|
|
|
|
|
Line 434 class ECHO_resource(Folder,Persistent,EC
|
Line 597 class ECHO_resource(Folder,Persistent,EC
|
url=self.metalink |
url=self.metalink |
|
|
try: |
try: |
geturl="" |
urllib.urlopen(url) |
for line in ECHO_helpers.urlopen(url).readlines(): |
except: |
geturl=geturl+line |
zLOG.LOG("ECHO_Resource (getAccessRightMD)", zLOG.INFO,"%s (%s)"%sys.exc_info()[0:2]) |
|
|
|
return None,getattr(self,'accessRight','') |
|
|
except: |
|
return (None,"Cannot open: "+url) |
|
|
|
try: |
try: |
dom=xml.dom.minidom.parseString(geturl) |
dom = NonvalidatingReader.parseUri(url) |
root=dom.getElementsByTagName('resource')[0] |
|
except: |
except: |
return (None,"Cannot parse: "+url+"<br>"+geturl) |
zLOG.LOG("ECHO_Resource (getAccessRightMD)", zLOG.INFO,"%s (%s)"%sys.exc_info()[0:2]) |
|
return (None,"Cannot parse: "+url+"<br>"+"%s (%s)"%sys.exc_info()[0:2]) |
|
|
internal=dom.getElementsByTagName('internal') |
|
if internal: |
|
institution=dom.getElementsByTagName('institution') |
|
return getText(institution[0].childNodes) |
|
|
|
free=dom.getElementsByTagName('free') |
|
if free: |
|
return "free" |
|
|
|
return "free" #default free |
accessright=dom.xpath("//meta/access-conditions/access/@type") |
|
if accessright: |
|
accessright=accessright[0].value |
|
if str(accessright)=='institution': |
|
tmp=dom.xpath("//meta/access-conditions/access/name") |
|
if tmp: |
|
accessright=getTextFromNode(tmp[0]) |
|
|
def changeAccessRightMD(self,accessright,RESPONSE=None): |
if not accessright: |
"""change the rights""" |
accessright="" |
|
|
|
return accessright,getattr(self,'accessRight','') |
|
|
|
def changeAccessRightMD(self,accessright,RESPONSE=None): |
|
"""change the rights - not user anymore""" |
|
#TODO: check if method still needed |
params="accessright=%s"%accessright |
params="accessright=%s"%accessright |
|
|
|
|
#print ECHO_helpers.urlopen(self.absolute_url()+'/setAccessRightXML'+'?'+params).read() |
#print ECHO_helpers.urlopen(self.absolute_url()+'/setAccessRightXML'+'?'+params).read() |
|
|
|
|
ECHO_helpers.urlopen('http://xserve02.mpiwg-berlin.mpg.de:18880/echo_nav/storage/downloadExternalXML?index_meta_url=%s&xml_url=%s'%(self.metalink,self.absolute_url()+'/setAccessRightXML'+urllib.quote('?'+params))).read() |
ECHO_helpers.urlopen('http://echo.mpiwg-berlin.mpg.de/echo_nav/storage/downloadExternalXML?index_meta_url=%s&xml_url=%s'%(self.metalink,self.absolute_url()+'/setAccessRightXML'+urllib.quote('?'+params))).read() |
|
|
|
|
if RESPONSE is not None: |
if RESPONSE is not None: |
Line 478 class ECHO_resource(Folder,Persistent,EC
|
Line 643 class ECHO_resource(Folder,Persistent,EC
|
def setAccessRightXML(self,accessright): |
def setAccessRightXML(self,accessright): |
"""set accessright""" |
"""set accessright""" |
url=self.metalink |
url=self.metalink |
|
accessrights=['MPIWG','free']#allowes rights |
|
|
|
if accessright =='': |
|
"""do nothing""" |
|
return "" |
|
|
|
|
try: |
try: |
geturl="" |
geturl="" |
Line 494 class ECHO_resource(Folder,Persistent,EC
|
Line 665 class ECHO_resource(Folder,Persistent,EC
|
except: |
except: |
return (None,"Cannot parse: "+url+"<br>"+geturl) |
return (None,"Cannot parse: "+url+"<br>"+geturl) |
|
|
metanodes=dom.getElementsByTagName('access-conditions') |
metamains=dom.getElementsByTagName('meta') |
|
|
|
if not metamains: |
|
nodenew=dom.createElement('meta') |
|
root.appendChild(nodenew) |
|
metamain=nodenew |
|
else: |
|
metamain=metamains[0] |
|
|
|
|
|
metanodes=metamain.getElementsByTagName('access-conditions') |
|
|
if not metanodes: |
if not metanodes: |
nodenew=dom.createElement('access-conditions') |
nodenew=dom.createElement('access-conditions') |
root.appendChild(nodenew) |
metamain.appendChild(nodenew) |
metanode=nodenew |
metanode=nodenew |
else: |
else: |
metanode=metanodes[0] |
metanode=metanodes[0] |
|
|
accesses=metanode.getElementsByTagName('access') |
accesses=metanode.getElementsByTagName('access') |
|
|
if not accesses: |
#delete old |
|
if accesses: |
|
metanode.removeChild(accesses[0]).unlink() |
|
|
|
#create new |
|
|
nodenew2=dom.createElement('access') |
nodenew2=dom.createElement('access') |
metanode.appendChild(nodenew2) |
metanode.appendChild(nodenew2) |
metanode2=nodenew2 |
metanode2=nodenew2 |
else: |
|
metanode2=accesses[0] |
|
|
|
internal=metanode.getElementsByTagName('internal') |
attribute=metanode2.getAttribute('type') |
|
|
if internal: |
if accessright=="free": |
metanode2.removeChild(internal[0]).unlink() |
|
|
|
free=metanode.getElementsByTagName('free') |
metanode2.setAttribute('type','free') |
|
|
if free: |
elif accessright.upper()=='MPIWG': |
metanode2.removeChild(internal[0]).unlink() |
metanode2.setAttribute('type','institution') |
|
nodenew4=dom.createElement('name') |
|
metanodetext=dom.createTextNode('MPIWG') |
|
nodenew4.appendChild(metanodetext) |
|
nodenew2.appendChild(nodenew4) |
|
#print dom.toxml().encode('utf-8') |
|
string= encodeRPC(dom.toxml().encode('utf-8')) |
|
|
|
#TODO: make server configurable |
|
server=xmlrpclib.Server("http://foxridge.mpiwg-berlin.mpg.de/server") |
|
|
if accessright=='free': |
path=urlparse.urlparse(self.metalink)[2] |
nodenew3=dom.createElement('free') |
|
metanode2.appendChild(nodenew3) |
|
elif accessright=='mpiwg': |
|
nodenew3=dom.createElement('internal') |
|
nodenew4=dom.createElement('institution') |
|
metanodetext=dom.createTextNode('mpiwg') |
|
nodenew4.appendChild(metanodetext) |
|
nodenew3.appendChild(nodenew4) |
|
metanode2.appendChild(nodenew3) |
|
|
|
return dom.toxml().encode('utf-8') |
server.writeMetaDataFile(path,string,"yes") |
|
|
def setStartPageForm(self): |
def setStartPageForm(self): |
"""Form for changing the startpage""" |
"""Form for changing the startpage""" |
Line 922 class ECHO_resource(Folder,Persistent,EC
|
Line 1104 class ECHO_resource(Folder,Persistent,EC
|
self.contentType=self.bib_type |
self.contentType=self.bib_type |
for data in self.metadata: |
for data in self.metadata: |
data_neu=re.sub('-','_',data) |
data_neu=re.sub('-','_',data) |
self.meta |
self.metaDataHash[data_neu]=getattr(self,data)[0:] |
DataHash[data_neu]=getattr(self,data)[0:] |
|
|
|
|
|
pt=zptFile(self, 'zpt/ChangeECHO_resource_metadata.zpt') |
pt=zptFile(self, 'zpt/ChangeECHO_resource_metadata.zpt') |
Line 1006 class ECHO_resource(Folder,Persistent,EC
|
Line 1187 class ECHO_resource(Folder,Persistent,EC
|
self.metaDataHash[self.getFieldTag(tags,field)]=self.REQUEST.form[self.getFieldTag(tags,field)] |
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)] |
self.OSAS_meta[self.getFieldTag(tags,field)]=self.REQUEST.form['OSAS_%s'%self.getFieldTag(tags,field)] |
except: |
except: |
"""nothing""" |
zLOG.LOG("ECHO_collection (changeECHO_resource_metadata)",zLOG.ERROR,"%s (%s)"%sys.exc_info()[0:2]) |
|
|
ECHO_helpers.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() |
ECHO_helpers.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() |
|
|
Line 1015 class ECHO_resource(Folder,Persistent,EC
|
Line 1196 class ECHO_resource(Folder,Persistent,EC
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
def getMDValue(self,fieldName,empty=None): |
|
|
def getMDValueSimpleSearchField(self): |
|
"""returns value for simple search""" |
|
|
|
try: |
|
return " ".join([self.getMDValue('title',generic="yes"), |
|
self.getMDValue('author',generic="yes"), |
|
self.getMDValue('year',generic="yes"),self.getTitle()]) |
|
except: |
|
|
|
#zLOG.LOG(" ECHO_collection(getMDSimpleSearchField)",zLOG.INFO," ".join([self.getMDValue('title',generic="yes"), |
|
# self.getMDValue('author',generic="yes"), |
|
# self.getMDValue('year',generic="yes"),''])) |
|
return "" |
|
|
|
def getMDValue(self,fieldNameTest,empty=None,generic=None): |
|
"""get md values""" |
|
#TODO: cache mappinghash |
|
|
|
fieldName=None |
|
if generic: |
|
if self.contentType: |
|
ct=self.contentType.replace(" ","_").lower() |
|
else: |
|
zLOG.LOG("ECHO_collection (getMDValue)", zLOG.INFO, "no_content type for %s"%self.getId()) |
|
ct="" |
|
|
|
#caching |
|
if not hasattr(self,'_v_mapHash'): #noch keine cachevariable |
|
self._v_mapHash={} |
|
|
|
tmp=self._v_mapHash.get(ct,None) |
|
if tmp: #teste ob type schon existiert |
|
fieldName=tmp.get(fieldNameTest,None) |
|
else: |
|
self._v_mapHash[ct]={} |
|
|
|
#noch nicht gecached |
|
if not fieldName and hasattr(self.standardMD,ct): |
|
fieldName=getattr(self.standardMD,ct).generateMappingHash()[fieldNameTest][0] |
|
self._v_mapHash[ct][fieldNameTest]=fieldName |
|
if not fieldName: |
|
fieldName=fieldNameTest |
if not empty: |
if not empty: |
return self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType) |
#FIXME: warum gibt es manchmal kein metadatahas |
|
try: |
|
|
|
ret =self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType) |
|
except: |
|
zLOG.LOG("ECHO (line 1069)",zLOG.ERROR,"no md hash for %s"%self.getId()) |
|
return "" |
|
|
else: |
else: |
return self.metaDataHash.get(fieldName,empty) |
|
|
ret= self.metaDataHash.get(fieldNameTest,empty) |
|
|
|
if type(ret) is StringType: |
|
return ret.decode('utf-8') |
|
else: |
|
return ret |
|
|
|
getFieldValue=getMDValue #depricated |
|
|
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""" |
Line 1035 class ECHO_resource(Folder,Persistent,EC
|
Line 1272 class ECHO_resource(Folder,Persistent,EC
|
return writeMetadata(self.metalink,self.metaDataHash,project,startpage,xslt,thumbtemplate,topbar,digiLibTemplate,digiliburlprefix=digiliburlprefix) |
return writeMetadata(self.metalink,self.metaDataHash,project,startpage,xslt,thumbtemplate,topbar,digiLibTemplate,digiliburlprefix=digiliburlprefix) |
|
|
def showMetaDataXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None): |
def showMetaDataXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None): |
"""schreibe md""" |
"""return bibliographical metadata as stored in the object""" |
|
|
try: |
try: |
|
|
Line 1043 class ECHO_resource(Folder,Persistent,EC
|
Line 1280 class ECHO_resource(Folder,Persistent,EC
|
except: |
except: |
return "<error> no metadata stored</error>" |
return "<error> no metadata stored</error>" |
|
|
|
def getXQueryMetaData(self,xquery): |
|
''' |
|
execute an xquery on the metadata and returns a list of tuples, |
|
each tuple represent the content of the node as text and the whole node as xml-fragment |
|
@param xquery: xquery auf den metadaten |
|
''' |
|
|
|
try: |
|
md=writeMetadata(self.metalink,self.metaDataHash,xmlfrag="yes") |
|
except: |
|
return None |
|
|
|
dom = NonvalidatingReader.parseString(md,"http://www.mpiwg-berlin.mpg.de/") |
|
|
|
results=Ft.Xml.XPath.Evaluate(xquery, contextNode=dom) |
|
|
|
ret=[] |
|
for result in results: |
|
|
|
buf = cStringIO.StringIO() |
|
PrettyPrint(result, stream=buf) |
|
str = buf.getvalue()[0:] |
|
buf.close() |
|
ret.append((getTextFromNode(result),str)) |
|
|
|
return ret |
|
|
def getMetaDataXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None): |
def getMetaDataXML(self,project=None,startpage=None,xslt=None,thumbtemplate=None,topbar=None,digiLibTemplate=None): |
"""prints out metadata as stored in the echo environment, format is the index.meta format""" |
"""prints out metadata as stored in the echo environment, format is the index.meta format""" |
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml') |
Line 1067 class ECHO_resource(Folder,Persistent,EC
|
Line 1331 class ECHO_resource(Folder,Persistent,EC
|
{'label':'Change TemplateSets and Image Viewer','action':'changeViewerTemplateSetForm'}, |
{'label':'Change TemplateSets and Image Viewer','action':'changeViewerTemplateSetForm'}, |
{'label':'set/change startpage','action':'setStartPageForm'}, |
{'label':'set/change startpage','action':'setStartPageForm'}, |
{'label':'Copy MD for indexing and search','action':'copySearchFields'}, |
{'label':'Copy MD for indexing and search','action':'copySearchFields'}, |
|
{'label':'Change AccessRights','action':'changeAccessRightForm'}, |
) |
) |
|
|
|
|
Line 1104 class ECHO_resource(Folder,Persistent,EC
|
Line 1369 class ECHO_resource(Folder,Persistent,EC
|
|
|
|
|
|
|
def getFieldValue(self,field): |
|
"""get value""" |
|
|
|
try: |
|
|
|
ret=self.metaDataHash[field] |
|
if ret == "": |
|
return None |
|
else: |
|
|
|
return ret |
|
except: |
|
return None |
|
|
|
def getMetaDataHash(self): |
def getMetaDataHash(self): |
"""md hash""" |
"""md hash""" |
return self.metaDataHash |
return self.metaDataHash |
|
|
def setFieldValue(self,field,value): |
def setFieldValue(self,field,value): |
"""get value""" |
"""get value""" |
|
#TODO: remove setFieldValue |
|
|
if not hasattr(self,'metaDataHash'): |
if not hasattr(self,'metaDataHash'): |
setattr(self,'metaDataHash',{}) |
setattr(self,'metaDataHash',{}) |
self.metaDataHash[field]=value[0:] |
self.metaDataHash[field]=value[0:] |
|
|
|
|
def copySearchFields(self): |
def copySearchFields(self): |
"""copys metadatafields to the object""" |
"""copys metadatafields to the object""" |
fields=['author','title','year'] |
fields=['author','title','year'] |
|
|
for field in fields: |
for field in fields: |
setattr(self,'MD_'+field,self.getFieldValue(field)) |
setattr(self,'MD_'+field,self.getMDValue(field,generic="yes")) |
|
|
|
|
def findLabelsFromMapping(self,referenceType): |
def findLabelsFromMapping(self,referenceType): |
Line 1187 class ECHO_resource(Folder,Persistent,EC
|
Line 1439 class ECHO_resource(Folder,Persistent,EC
|
|
|
|
|
|
|
|
|
|
|
bibdata={} |
bibdata={} |
retdata={} |
retdata={} |
fieldlist=self.standardMD.fieldList |
fieldlist=self.standardMD.fieldList |
Line 1238 class ECHO_resource(Folder,Persistent,EC
|
Line 1488 class ECHO_resource(Folder,Persistent,EC
|
if RESPONSE: |
if RESPONSE: |
return RESPONSE.redirect('manage_main') |
return RESPONSE.redirect('manage_main') |
|
|
def ECHO_getResourceMD(self,template="yes",back=None): |
return "OK:",self.absolute_url(),self.contentType |
|
|
|
def ECHO_getResourceMD(self,template="yes",back=None,overwrite="no"): |
"""Einlesen der Metadaten und Anlegen dieser Metadaten als Informationen zur Resource""" |
"""Einlesen der Metadaten und Anlegen dieser Metadaten als Informationen zur Resource""" |
(metadict, error)=readMetadata(self.metalink) |
(metadict, error)=readMetadata(self.metalink) |
|
|
Line 1248 class ECHO_resource(Folder,Persistent,EC
|
Line 1500 class ECHO_resource(Folder,Persistent,EC
|
if not error=="": #Fehler beim Auslesen des Metafiles |
if not error=="": #Fehler beim Auslesen des Metafiles |
return "ERROR:",error |
return "ERROR:",error |
|
|
if not self.contentType: |
if (not self.contentType) or (overwrite=="yes"): |
self.contentType=metadict['bib_type'].lower() |
self.contentType=metadict['bib_type'].lower() |
|
|
if not (metadict['bib_type'].lower()==self.contentType.lower()): |
if not (metadict['bib_type'].lower()==self.contentType.lower()): |
Line 1257 class ECHO_resource(Folder,Persistent,EC
|
Line 1509 class ECHO_resource(Folder,Persistent,EC
|
|
|
return zptFile(self, 'zpt/ECHO_getResourceMDErrorContentType.zpt')() |
return zptFile(self, 'zpt/ECHO_getResourceMDErrorContentType.zpt')() |
|
|
self.REQUEST.SESSION['metadict']=metadict |
#self.REQUEST.SESSION['metadict']=metadict |
|
|
|
|
|
|
self.REQUEST.SESSION['diffs']=checkDiffs(self,self.REQUEST.SESSION['metadict']) |
self.REQUEST.SESSION['diffs']=checkDiffs(self,metadict) |
|
|
|
|
|
|
if template=="yes": |
if template=="yes": |
|
#pt=PageTemplateFile(os.path.join(package_home(globals()), 'zpt/ECHO_resourceMD.zpt'),metadict=metadict).__of__(self) |
pt=zptFile(self, 'zpt/ECHO_resourceMD.zpt') |
pt=zptFile(self, 'zpt/ECHO_resourceMD.zpt') |
return pt() |
|
|
return pt(metadict=metadict) |
|
|
|
|
|
|
Line 1375 class ECHO_externalLink(Folder,ECHO_basi
|
Line 1627 class ECHO_externalLink(Folder,ECHO_basi
|
security.declarePublic('content_html') |
security.declarePublic('content_html') |
def content_html(self): |
def content_html(self): |
"""template fuer content""" |
"""template fuer content""" |
return ECHO_basis.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): |
|
|
Line 1449 class ECHO_link(ECHO_externalLink):
|
Line 1708 class ECHO_link(ECHO_externalLink):
|
|
|
meta_type="ECHO_link" |
meta_type="ECHO_link" |
|
|
|
manage_options = ECHO_externalLink.manage_options+( |
|
{'label':'add links config','action':'ECHO_link_addLinksForm'}, |
|
) |
|
|
|
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): |
def content_html(self): |
"""template fuer link""" |
"""template fuer link""" |
|
|
|
|
if hasattr(self,"link_template"): |
if hasattr(self,"link_template"): |
return ECHO_basis.content_html(self,'link') |
ret=ECHO_basis.content_html(self,'link') |
|
|
else: |
else: |
return ECHO_basis.content_html(self,'collection') |
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 index_html(self): |
def index_html(self): |
"""standard link""" |
"""standard link""" |
Line 1472 class ECHO_link(ECHO_externalLink):
|
Line 1765 class ECHO_link(ECHO_externalLink):
|
else: |
else: |
params={} |
params={} |
|
|
|
if getattr(self,'addLinks','yes')=="yes": |
params['backLink']=self.aq_parent.absolute_url() |
params['backLink']=self.aq_parent.absolute_url() |
params['startLink']=splitted[0]+"?"+urllib.urlencode(params) |
params['startLink']=splitted[0]+"?"+urllib.urlencode(params) |
|
|
Line 1493 def manage_addECHO_link(self,id,title,la
|
Line 1787 def manage_addECHO_link(self,id,title,la
|
|
|
self._setObject(id,newObj) |
self._setObject(id,newObj) |
|
|
|
getattr(self,id).addLinks='no' |
|
|
if RESPONSE is not None: |
if RESPONSE is not None: |
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
|
|
class ECHO_collection(Folder, Persistent, Implicit, Cacheable,ECHO_basis): |
class ECHO_collection(CatalogAware, Folder, Persistent, Implicit, Cacheable,ECHO_basis): |
"""ECHO Collection""" |
"""ECHO Collection""" |
|
|
|
management_page_charset="utf-8" |
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
meta_type='ECHO_collection' |
meta_type='ECHO_collection' |
|
default_catalog='resourceCatalog' |
|
|
# viewClassificationList=viewClassificationListMaster |
# viewClassificationList=viewClassificationListMaster |
displayTypes=displayTypes |
displayTypes=displayTypes |
|
|
path="/mpiwg/online/permanent/shipbuilding" |
path="/mpiwg/online/permanent/shipbuilding" |
|
|
|
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): |
def localizeObjects(self): |
"""localize all objects""" |
"""localize all objects""" |
contents=self.ZopeFind(self,obj_metatypes=['ECHO_link','ECHO_mapText']) |
contents=self.ZopeFind(self,obj_metatypes=['ECHO_externalLink','ECHO_link','ECHO_mapText']) |
|
|
find=self.ZopeFind(self,obj_ids=('locale_en')) |
find=self.ZopeFind(self,obj_ids=('locale_en')) |
if not find: |
if not find: |
self.manage_addECHO_locale("en",'','') |
self.manage_addECHO_locale("en",'','') |
for content in contents: |
for content in contents: |
if content[1].meta_type=='ECHO_link': |
|
|
if content[1].meta_type in ['ECHO_link','ECHO_externalLink']: |
|
|
find=content[1].ZopeFind(content[1],obj_metatypes=('ECHO_mapText')) |
find=content[1].ZopeFind(content[1],obj_metatypes=('ECHO_mapText')) |
if find: |
if find: |
root=find[0][1] |
root=find[0][1] |
Line 1608 class ECHO_collection(Folder, Persistent
|
Line 1918 class ECHO_collection(Folder, Persistent
|
pt=zptFile(self, 'zpt/changeMetaDataLinkForm') |
pt=zptFile(self, 'zpt/changeMetaDataLinkForm') |
pt.content_type="text/html" |
pt.content_type="text/html" |
return pt() |
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): |
def changeAccessRightsCollection(self): |
"""change""" |
"""change""" |
ret="" |
ret="" |
Line 1616 class ECHO_collection(Folder, Persistent
|
Line 1935 class ECHO_collection(Folder, Persistent
|
resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource']) |
resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource']) |
for resource in resources: |
for resource in resources: |
|
|
try: |
if argv.has_key(resource[1].getId()+'_xml'): |
ret+=resource[1].getId()+" "+argv[resource[1].getId()]+"</br>" |
ret+=resource[1].getId()+" "+argv[resource[1].getId()+'_xml']+"</br>" |
resource[1].changeAccessRightMD(argv[resource[1].getId()]) |
resource[1].setAccessRightXML(argv[resource[1].getId()+'_xml']) |
except: |
resource[1].accessRight=argv[resource[1].getId()+'_xml'] |
pass |
elif argv.has_key(resource[1].getId()+'_echo'): |
|
ret+="only local:"+resource[1].getId()+" "+argv[resource[1].getId()+'_echo']+"</br>" |
|
resource[1].accessRight=argv[resource[1].getId()+'_echo'] |
|
else: |
|
ret+="ERROR:" +resource[0] |
return ret |
return ret |
|
|
def changeMetaDataLinkInCollection(self): |
def changeMetaDataLinkInCollection(self): |
Line 1698 class ECHO_collection(Folder, Persistent
|
Line 2021 class ECHO_collection(Folder, Persistent
|
pass |
pass |
return ret |
return ret |
|
|
def updateCollection(self,RESPONSE=None): |
def importCollection(self,path=None,RESPONSE=None): |
"""liest verzeichnisse aus dem pfad und legt sie dann als objekte in den ordner""" |
"""liest verzeichnisse aus dem pfad und legt sie dann als objekte in den ordner""" |
files=os.listdir(self.path) |
|
|
if path is None: |
|
pt=zptFile(self, 'zpt/importCollection.zpt') |
|
return pt() |
|
|
|
files=os.listdir(path) |
ret="" |
ret="" |
for fileName in files: |
for fileName in files: |
|
|
if fileName: |
if fileName: |
|
|
tempPath=re.sub("/mpiwg/online","",self.path) |
tempPath=re.sub("/mpiwg/online","",path) |
link="http://echo.mpiwg-berlin.mpg.de/zogilib_book?fn="+tempPath+"/"+fileName+"/pageimg" |
link="http://echo.mpiwg-berlin.mpg.de/zogilib_book?fn="+tempPath+"/"+fileName+"/pageimg" |
|
|
metalink=self.path+"/"+fileName+"/index.meta" |
metalink=self.path+"/"+fileName+"/index.meta" |
Line 1729 class ECHO_collection(Folder, Persistent
|
Line 2057 class ECHO_collection(Folder, Persistent
|
if RESPONSE is not None: |
if RESPONSE is not None: |
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
def updateCollectionMD(self,RESPONSE=None): |
|
"""updateMD""" |
|
files=os.listdir(self.path) |
|
for fileName in files: |
|
if fileName: |
|
genObj=getattr(self,fileName) |
|
genObj.copyIndex_meta2echo_resource() |
|
genObj.generate_title() |
|
|
|
if RESPONSE is not None: |
|
RESPONSE.redirect('manage_main') |
|
|
|
|
|
|
|
def changeViewerTemplateSetsForm(self): |
def changeViewerTemplateSetsForm(self): |
"""change the viewer template set""" |
"""change the viewer template set""" |
pt=zptFile(self, 'zpt/changeViewerTemplateSet') |
pt=zptFile(self, 'zpt/changeViewerTemplateSet') |
Line 1833 class ECHO_collection(Folder, Persistent
|
Line 2147 class ECHO_collection(Folder, Persistent
|
RESPONSE.redirect('manage_main') |
RESPONSE.redirect('manage_main') |
|
|
def copySearchFields(self,RESPONSE=None): |
def copySearchFields(self,RESPONSE=None): |
"""copys import metadatafields to the object""" |
"""copys < metadatafields to the object""" |
resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource']) |
resources=self.ZopeFind(self,obj_metatypes=['ECHO_resource'],search_sub=1) |
|
|
for resource in resources: |
for resource in resources: |
|
|
Line 1852 class ECHO_collection(Folder, Persistent
|
Line 2166 class ECHO_collection(Folder, Persistent
|
def reloadMetaDataFromStorage(self,RESPONSE=None): |
def reloadMetaDataFromStorage(self,RESPONSE=None): |
"""copy metadata from the storage to ECHO""" |
"""copy metadata from the storage to ECHO""" |
|
|
return reloadMetaDataFromStorage(self,RESPONSE=None) |
return reloadMetaDataFromStorage(self,RESPONSE) |
|
|
|
|
def getPartnerCopyright(self,name,sonst="generic"): |
def getPartnerCopyright(self,name,sonst="generic"): |
Line 1989 class ECHO_collection(Folder, Persistent
|
Line 2303 class ECHO_collection(Folder, Persistent
|
areas = self.getAllMapAreas() |
areas = self.getAllMapAreas() |
return self.createJSAreas(areas) |
return self.createJSAreas(areas) |
|
|
|
|
|
emptyPartner=ECHO_partner("", "","", "", "", "", "", "", "") |
|
|
security.declarePublic('getCreditObject') |
security.declarePublic('getCreditObject') |
def getCreditObject(self,name): |
def getCreditObject(self,name): |
"""credit id to credititem""" |
"""credit id to credititem""" |
try: |
try: |
return getattr(self.partners,name) |
return getattr(self.partners,name) |
except: |
except: |
return "" |
|
|
return self.emptyPartner |
|
|
|
|
security.declarePublic('ECHO_generateNavBar') |
security.declarePublic('ECHO_generateNavBar') |
def ECHO_generateNavBar(self): |
def ECHO_generateNavBar(self): |
Line 2063 class ECHO_collection(Folder, Persistent
|
Line 2382 class ECHO_collection(Folder, Persistent
|
{'label':'Set Startpage','action':'setStartpageFolderForm'}, |
{'label':'Set Startpage','action':'setStartpageFolderForm'}, |
{'label':'Change Viewer Templates and Image Viewer','action':'changeViewerTemplateSetsForm'}, |
{'label':'Change Viewer Templates and Image Viewer','action':'changeViewerTemplateSetsForm'}, |
{'label':'Reload Metadata','action':'reloadMetaDataFromStorageWarning'}, |
{'label':'Reload Metadata','action':'reloadMetaDataFromStorageWarning'}, |
{'label':'ImportCollection','action':'updateCollection'}, |
{'label':'ImportCollection','action':'importCollection'}, |
{'label':'Copy MD for indexing and search','action':'copySearchFields'}, |
{'label':'Copy MD for indexing and search','action':'copySearchFields'}, |
|
{'label':'Change access rights', 'action':'changeAccessRightsCollectionForm'}, |
) |
) |
|
|
|
|
Line 2159 class ECHO_collection(Folder, Persistent
|
Line 2479 class ECHO_collection(Folder, Persistent
|
def content_html(self,**argv): |
def content_html(self,**argv): |
"""template fuer content""" |
"""template fuer content""" |
#print "NN",argv |
#print "NN",argv |
return ECHO_basis.content_html(self,'collection') |
ret = ECHO_basis.content_html(self,'collection') |
|
|
|
if type(ret) is StringType: |
|
return ret.decode('utf-8') |
|
else: |
|
return ret |
|
|
|
|
def getCredits(self): |
def getCredits(self): |
"""Ausgabe der credits""" |
"""Ausgabe der credits""" |
Line 2219 class ECHO_collection(Folder, Persistent
|
Line 2545 class ECHO_collection(Folder, Persistent
|
|
|
getSubCols = ECHO_helpers.getSubCols |
getSubCols = ECHO_helpers.getSubCols |
|
|
|
def getSubcolsXMLRpc(self,searchSimple): |
|
"""simplesearch results suitable for xml rpc, gives back array objid,url""" |
|
|
|
return [x.absolute_url() for x in self.getSubCols(searchSimple=searchSimple)] |
|
|
|
|
Globals.InitializeClass(ECHO_collection) |
Globals.InitializeClass(ECHO_collection) |
|
|
def manage_addECHO_collectionForm(self): |
def manage_addECHO_collectionForm(self): |
Line 2516 class ECHO_root(Folder,Persistent,Implic
|
Line 2848 class ECHO_root(Folder,Persistent,Implic
|
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
|
|
meta_type="ECHO_root" |
meta_type="ECHO_root" |
|
management_page_charset="utf-8" |
|
|
|
def mod_re_sub(self,pattern,replace,string): |
|
"""re.sub aus mod re zur Verfuegung stellen""" |
|
return re.sub(pattern,replace,string) |
|
|
|
def findObjectFromFulltext(self,existUri): |
|
''' |
|
|
|
@param url: |
|
@param existUri: |
|
''' |
|
|
|
if existUri: |
|
#TODO: at the moment assume that the filename is unique, the whole has to changed to a system of ids. |
|
filename=existUri.split("/")[-1] |
|
|
|
founds=self.resourceCatalog.search({'fullTextUrl':os.path.splitext(filename)[0]}) |
|
|
|
ret=[(found.title,found.getObject().absolute_url(),found.getObject().aq_parent.absolute_url()) for found in founds] |
|
|
|
return ret |
|
|
|
def reindex(self,RESPONSE=None): |
|
"""indiziere alle Objecte neu""" |
|
|
|
if RESPONSE: |
|
RESPONSE.write("<html><body>") |
|
|
|
resources=self.ZopeFind(self,obj_metatypes=["ECHO_resource"], search_sub=1) |
|
|
|
for resource in resources: |
|
resource[1].reindex() |
|
#print "<p> done %s </p>\n" |
|
if RESPONSE: |
|
RESPONSE.write("<p> done %s </p>\n"%resource[0]) |
|
|
|
if RESPONSE: |
|
RESPONSE.write("<p> ok </p></html></body>\n") |
|
|
def printer(self,txt): |
def printer(self,txt): |
print txt |
print txt |
Line 2533 class ECHO_root(Folder,Persistent,Implic
|
Line 2904 class ECHO_root(Folder,Persistent,Implic
|
|
|
def setLanguage(self,lang): |
def setLanguage(self,lang): |
"""Set language cookie""" |
"""Set language cookie""" |
self.REQUEST.RESPONSE.setCookie('lang_exhibition',lang,path="") |
self.REQUEST.RESPONSE.setCookie('lang_exhibition',lang,path="/") |
|
|
def switchLanguage(self): |
def switchLanguage(self): |
"""Set language cookie""" |
"""Set language cookie""" |
Line 2542 class ECHO_root(Folder,Persistent,Implic
|
Line 2913 class ECHO_root(Folder,Persistent,Implic
|
else: |
else: |
lang="en" |
lang="en" |
|
|
self.REQUEST.RESPONSE.setCookie('lang_exhibition',lang,path="") |
self.REQUEST.RESPONSE.setCookie('lang_exhibition',lang,path="/") |
self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']) |
self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']) |
def getLanguage(self): |
def getLanguage(self): |
"""get language cookie""" |
"""get language cookie""" |
Line 2799 class ECHO_root(Folder,Persistent,Implic
|
Line 3170 class ECHO_root(Folder,Persistent,Implic
|
return ret |
return ret |
|
|
def getValueFromClass(self,field,found): |
def getValueFromClass(self,field,found): |
"""retattribute falss existing""" |
"""ret attribute if existing""" |
try: |
try: |
|
|
return getattr(found,field).decode('ascii','ignore') |
return getattr(found,field).decode('ascii','ignore') |
Line 3056 class ECHO_root(Folder,Persistent,Implic
|
Line 3427 class ECHO_root(Folder,Persistent,Implic
|
else: |
else: |
return "" |
return "" |
|
|
def link2html(self,str): |
link2html=vlp_xmlhelpers.link2html |
"""link2html fuer VLP muss hier noch raus""" |
|
if str: |
|
|
|
str=re.sub("\&","&",str) |
|
dom=xml.dom.minidom.parseString("<?xml version='1.0' encoding='utf-8'?><txt>"+str+"</txt>") |
|
links=dom.getElementsByTagName("link") |
|
|
|
|
|
for link in links: |
|
link.tagName="a" |
|
ref=link.getAttribute("ref") |
|
pn=link.getAttribute("page") |
|
|
|
if self.checkRef(ref): |
|
if pn: |
|
link.setAttribute("href",self.aq_parent.absolute_url()+"/references?id="+ref+"&page="+pn) |
|
else: |
|
link.setAttribute("href",self.aq_parent.absolute_url()+"/references?id="+ref) |
|
|
|
|
|
newxml=dom.toxml('utf-8') |
xml2html=vlp_xmlhelpers.xml2html |
|
|
retStr=regexpTXT.search(newxml) |
checkRef=vlp_xmlhelpers.checkRef |
|
|
return retStr.group(1) |
# def checkRef(self,ref): |
|
# if ref[0:3]=='lit': |
|
# if len(self.library_data({ 'id':ref}))>0: |
return "" |
# return 1 |
|
# try: |
def xml2html(self,str,quote="yes"): |
# if ref[0:7]=="tec_cat": |
"""link2html fuer VLP muss hier noch raus""" |
# return 1 |
|
# except: |
if str: |
# """nothing""" |
if quote=="yes2": |
# |
str=re.sub("\&","&",str) |
# dbs={'vl_technology':'','vl_people':" AND complete='yes'",'vl_sites':''} |
#dom=xml.dom.minidom.parseString(str) |
# res=None |
dom = NonvalidatingReader.parseString(str,"http://www.mpiwg-berlin.mpg.de/") |
# for db in dbs.keys(): |
#links=dom.getElementsByTagName("link") |
# res=res or self.search(var=str("select reference from %s where reference =\'%s\' %s"%(db,ref,dbs[db]))) |
links=Ft.Xml.XPath.Evaluate(".//link", contextNode=dom) |
# return res |
for link in links: |
# |
#link.tagName="a" |
# #Ende Methode fuer vlp |
|
|
ref=link.getAttributeNS(EMPTY_NAMESPACE,"ref") |
|
pn=link.getAttributeNS(EMPTY_NAMESPACE,"page") |
|
|
|
cns=link.childNodes[0:] |
|
|
|
newLink=dom.createElementNS(EMPTY_NAMESPACE,"a") |
|
for x in cns: |
|
newLink.appendChild(x) |
|
|
|
|
|
|
|
link.parentNode.replaceChild(newLink,link) |
|
if self.checkRef(ref): |
|
if pn: |
|
newLink.setAttributeNS(EMPTY_NAMESPACE,"href",self.aq_parent.absolute_url()+"/vlp_coll?id="+ref+"&p="+pn) |
|
else: |
|
newLink.setAttributeNS(EMPTY_NAMESPACE,"href",self.aq_parent.absolute_url()+"/vlp_coll?id="+ref) |
|
|
|
#str= dom.toxml('utf-8') |
|
buf = cStringIO.StringIO() |
|
PrettyPrint(dom, stream=buf) |
|
str = buf.getvalue() |
|
buf.close() |
|
#str=PrettyPrint(dom.documentElement,encoding='UTF-8') |
|
#print link.toxml('utf-8') |
|
#print type(str) |
|
retStr=regexpPage.search(str) |
|
|
|
try: # hack warum fehtl manchmal page?? |
|
return retStr.group(1) |
|
except: |
|
return str |
|
return "" |
|
|
|
def checkRef(self,ref): |
|
if ref[0:3]=='lit': |
|
if len(self.library_data({ 'id':ref}))>0: |
|
return 1 |
|
try: |
|
if ref[0:7]=="tec_cat": |
|
return 1 |
|
except: |
|
"""nothing""" |
|
|
|
dbs={'vl_technology':'','vl_people':" AND complete='yes'",'vl_sites':''} |
|
res=None |
|
for db in dbs.keys(): |
|
res=res or self.search(var=str("select reference from %s where reference =\'%s\' %s"%(db,ref,dbs[db]))) |
|
return res |
|
|
|
#Ende Methode fuer vlp |
|
|
|
def PgQuoteString(self,string): |
def PgQuoteString(self,string): |
"""Quote string""" |
"""Quote string""" |
Line 3405 def manage_addECHO_copyrightType(self,id
|
Line 3705 def manage_addECHO_copyrightType(self,id
|
|
|
|
|
|
|
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'}, |
|
) |
|
|
|
|
|
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_linkList(ZopePageTemplate,ECHO_basis): |
class ECHO_linkList(ZopePageTemplate,ECHO_basis): |
"""LinkList Objekt""" |
"""LinkList Objekt""" |