--- ECHO_content/ECHO_collection.py 2004/05/24 19:04:09 1.89
+++ ECHO_content/ECHO_collection.py 2004/06/07 14:30:16 1.99
@@ -46,30 +46,65 @@ import xml.dom.minidom
from ECHO_graphicalOverview import javaHandler,javaScriptMain
import ECHO_helpers
+def getCopyrightsFromForm(argv):
+ medias={}
+ partners={}
+ copyrights={}
+
+ copyrightsFinal=[]
+ for arg in argv.keys():
+ print arg
+ if arg[0:5]=='media':
+ nm=int(arg[5:])
+ medias[nm]=argv[arg]
+ elif arg[0:5]=='partn':
+ nm=int(arg[5:])
+ partners[nm]=argv[arg]
+ elif arg[0:5]=='copyr':
+ nm=int(arg[5:])
+ copyrights[nm]=argv[arg]
+
+ copyrightsList=[(medias[nm],partners[nm],copyrights[nm]) for nm in medias.keys()]
+ for copyright in copyrightsList:
+ if not copyright[0]=='':
+ copyrightsFinal.append(copyright)
+ return copyrightsFinal
+
#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)
+ self.referencetypes=tags[2]
+ self.fields=tags[3]
+
+
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):
@@ -78,11 +113,11 @@ def content_html(self,type):
#
#if templates:
# return templates[0][1]()
-
- try:
+
+ if hasattr(self,type+"_template"):
obj=getattr(self,type+"_template")
return obj()
- except:
+ else:
pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_%s_template_standard.zpt'%type).__of__(self)
pt.content_type="text/html"
return pt()
@@ -166,7 +201,7 @@ def writeMetadata(url,metadict):
metanode=metanodes[0]
for metaData in metadict.keys():
- print metaData,metanode
+
try:
nodeOld=metanode.getElementsByTagName(metaData)
except:
@@ -185,13 +220,18 @@ def writeMetadata(url,metadict):
metanode.removeChild(nodeOld[0]).unlink()
metanodeneu=dom.createElement(metaData)
- metanodetext=dom.createTextNode(unicode(metadict[metaData],"utf8"))
+ try:
+ metanodetext=dom.createTextNode(unicode(metadict[metaData],"utf-8"))
+ except:
+ metanodetext=dom.createTextNode(metadict[metaData].encode('utf-8'))
metanodeneu.appendChild(metanodetext)
metanode.appendChild(metanodeneu)
- return dom.topxml().encode('utf-8')
+ return dom.toxml().encode('utf-8')
+
+
def readMetadata(url):
"""Methode zum Auslesen der Metadateninformation zu einer Resource
Vorerst noch Typ bib"""
@@ -216,7 +256,7 @@ def readMetadata(url):
if len(metanode)==0:
metanode=dom.getElementsByTagName('archimedes')
metadict['bib_type']='Archimedes'
- #print "HELLO"
+
if not len(metanode)==0:
metacontent=metanode[0].childNodes
@@ -228,7 +268,8 @@ def readMetadata(url):
for node in metacontent:
try:
- metadict[re.sub('-','_',node.tagName.lower())]=getText(node.childNodes)
+ #print urllib.unquote(getText(node.childNodes)),getText(node.childNodes)
+ metadict[re.sub('-','_',node.tagName.lower())]=urllib.unquote(getText(node.childNodes))
except:
"""nothing"""
@@ -253,66 +294,75 @@ def setECHO_collectionInformation(self,t
coords=[]
#coordinates of for rectangles
- #print "cs", coordstrs
+
if coordstrs:
for coordstr in coordstrs:
- #print "cs", coordstr
+
try:
temco=coordstr.split(",")
except:
temco=[]
- #temco.append(angle)
+
coords.append(temco)
self.coords=coords[0:]
+class ECHO_copyright(Folder):
+ """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'},
+ )
-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
-
-
-class scientificInformation(Folder,Persistent,Implicit):
- """outdated will be deleted in the next versions: subclass scientificInformation"""
- security=ClassSecurityInfo()
-
-
-
- def __init__(self,source_type,period):
+ def ECHO_copyright_configForm(self):
+ """change form"""
+ pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_copyright').__of__(self)
+ pt.content_type="text/html"
+ return pt()
- self.id="scientific_Information"
- self.source_type=source_type
- self.period=period
-
+ def ECHO_copyright_config(self,title,RESPONSE):
+ """change"""
+ self.title=title
+ self.copyrights=[]
+ self.copyrights=getCopyrightsFromForm(self.REQUEST.form)[0:]
+ 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
+
+def manage_addECHO_copyrightForm(self):
+ """Form for adding"""
+ pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_copyright.zpt').__of__(self)
+ 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.REQUEST.form)))
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
class ECHO_layoutTemplate(ZopePageTemplate):
"""Create a layout Template for different purposes"""
@@ -381,13 +431,15 @@ def manage_addECHO_layoutTemplate(self,
REQUEST.RESPONSE.redirect(u+'/manage_main')
return ''
-class ECHO_resource(Folder):
+class ECHO_resource(Folder,Persistent):
"""ECHO Ressource"""
meta_type='ECHO_resource'
viewClassificationList=viewClassificationListMaster
getSubCols = ECHO_helpers.getSubCols
+
+
def getTitle(self):
"""title"""
return self.title.encode('utf-8')
@@ -407,19 +459,37 @@ class ECHO_resource(Folder):
return ""
def getFullTextXML(self,noredirect=None):
- """getFullTextXML"""
+ """getFullTextXML; gives the FullText as an XML Document, and if somthing goes wrong."""
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)
+ self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
if not noredirect:
self.REQUEST.RESPONSE.redirect(texturl)
else:
return texturl
except:
- return None
+
+ if not noredirect:
+ self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
+ self.REQUEST.RESPONSE.write("no fulltext available")
+ else:
+ return "no fulltext available"
+
+ def getCopyright(self):
+ """gib link auf copyright notiz aus"""
+ if hasattr(self,'copyrightType') and hasattr(self.copyrightTypes,self.copyrightType):
+ obj=getattr(self.copyrightTypes,self.copyrightType)
+ else:
+ obj=getattr(self.copyrightTypes,'generic')
+
+ label=obj.label
+ link="copyrightTypes/"+obj.getId()+'/copyright.html'
+
+ return """%s"""%(link,label)
def getCredits(self):
"""Ausgabe der credits"""
@@ -428,7 +498,7 @@ class ECHO_resource(Folder):
else:
return []
- def __init__(self,id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords):
+ def __init__(self,id,link,metalink,resourceID,title,label,description,contentType,renderingType,copyrightType,responsible,credits,weight,coords):
self.id = id
"""Festlegen der ID"""
@@ -441,8 +511,11 @@ class ECHO_resource(Folder):
self.credits=toList(credits)
self.description=description
self.contentType=contentType
+ self.copyrightType=copyrightType
+ self.renderingType=renderingType
self.responsible=responsible
-
+ self.resourceID=resourceID
+
if coords:
coordsnew=[ string.split(x,",") for x in coords]
else:
@@ -520,8 +593,7 @@ class ECHO_resource(Folder):
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()
@@ -574,6 +646,17 @@ class ECHO_resource(Folder):
RESPONSE.redirect('manage_main')
+ def changeECHO_resource_metadata_local(self,RESPONSE=None):
+ """change metadata"""
+ tags=self.findTagsFromMapping(self.contentType)
+ for field in tags[1]:
+ self.metaDataHash[self.getFieldTag(tags,field)]=self.REQUEST.form[self.getFieldTag(tags,field)]
+
+
+
+ if RESPONSE is not None:
+ RESPONSE.redirect('manage_main')
+
def changeECHO_resource_metadata(self,RESPONSE=None):
"""change metadata"""
tags=self.findTagsFromMapping(self.contentType)
@@ -591,12 +674,20 @@ class ECHO_resource(Folder):
RESPONSE.redirect('manage_main')
+ def getMDValue(self,fieldName):
+ return self.metaDataHash.get(fieldName,'!!NOT USED HERE in Type: %s'%self.contentType)
+
def newMetaXML(self):
"""new index.meta"""
self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
return writeMetadata(self.metalink,self.OSAS_meta)
-
+
+ def getMetaDataXML(self):
+ """prints out metadata as stored in the echo environment, format is the index.meta format"""
+ self.REQUEST.RESPONSE.setHeader('Content-Type','text/xml')
+ return writeMetadata(self.metalink,self.metaDataHash)
+
def changeECHO_resource(self,metalink,link,title,label,description,contentType,responsible,weight,viewClassification="",coords=None,credits=None,RESPONSE=None):
"""Änderung der Properties"""
@@ -617,7 +708,6 @@ class ECHO_resource(Folder):
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'},
@@ -687,7 +777,7 @@ class ECHO_resource(Folder):
def getFieldValue(self,field):
"""get value"""
- #print field
+
try:
ret=self.metaDataHash[field]
@@ -698,19 +788,38 @@ class ECHO_resource(Folder):
except:
return None
+ def getMetaDataHash(self):
+ """md hash"""
+ return self.metaDataHash
+
+ def setFieldValue(self,field,value):
+ """get value"""
+
+ if not hasattr(self,'metaDataHash'):
+ setattr(self,'metaDataHash',{})
+ self.metaDataHash[field]=value[0:]
+
+
+
def findLabelsFromMapping(self,referenceType):
"""gib hash mit label -> generic zurueck"""
- self.referencetypes=self.ZopeFind(self.standardMD)
- #print "RT",referenceType
+ #return {},[]
+
+ temp=self.ZopeFind(self.standardMD)
+
+ if referenceType=="":
+ referenceType="book"
+
bibdata={}
retdata={}
+ fields=[]
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
@@ -719,22 +828,34 @@ class ECHO_resource(Folder):
bibdata['data']=referenceTypeF[1]
- self.fields=bibdata[referenceType]
+ fields=bibdata[referenceType]
for field in fieldlist:
retdata[field]=referenceTypeF[1].getValue(field)[1]
- #print retdata,fieldlist
- return retdata,fieldlist
+
+ return retdata,fieldlist,temp,fields
def findTagsFromMapping(self,referenceType):
"""gib hash mit label -> generic zurueck"""
- self.referencetypes=self.ZopeFind(self.standardMD)
+
+ if referenceType=="":
+ referenceType="book"
+
+ temp = self.ZopeFind(self.standardMD)[0:]
+
+
+ #self.referencetypes=temp[0:]
+
+
+
+
+
bibdata={}
retdata={}
fieldlist=self.standardMD.fieldList
- for referenceTypeF in self.referencetypes:
+ for referenceTypeF in temp:
if referenceTypeF[1].title.lower() == referenceType.lower():
try:
@@ -743,20 +864,41 @@ class ECHO_resource(Folder):
except:
bibdata[referenceType]=referenceTypeF[1].fields
bibdata['data']=referenceTypeF[1]
- self.fields=bibdata[referenceType]
+ fields=bibdata[referenceType]
for field in fieldlist:
retdata[field]=referenceTypeF[1].getValue(field)[0]
- return retdata,fieldlist
+ return retdata,fieldlist,temp,fields
-
+
+ def copyIndex_meta2echo_resource(self,RESPONSE=None):
+ """copy MD von Index_meta to the echo_resource"""
+
+ (metadict, error)=readMetadata(self.metalink)
+
+ self.metaDataHash={}
+ if not error=="": #Fehler beim Auslesen des Metafiles
+ return "ERROR:",error
+ fields=self.findTagsFromMapping(self.contentType)
+
+ #fields=self.findLabelsFromMapping(self.contentType)
+ for field in fields[1]:
+ if self.isDefinedInThisSet(fields,field):
+ #print urllib.unquote(metadict.get(self.getFieldTag(fields,field),''))
+ self.setFieldValue(self.getFieldTag(fields,field),metadict.get(self.getFieldTag(fields,field),''))
+
+
+
+ if RESPONSE:
+ return RESPONSE.redirect('manage_main')
+
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
@@ -767,16 +909,20 @@ class ECHO_resource(Folder):
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)
+ self.REQUEST.SESSION['metadict']=metadict
+
+
+
+ self.REQUEST.SESSION['diffs']=checkDiffs(self,self.REQUEST.SESSION['metadict'])
+
if template=="yes":
- pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_resourceMD.zpt').__of__(self)
- return pt()
+ pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_resourceMD.zpt').__of__(self)
+ return pt()
+
@@ -789,12 +935,49 @@ class ECHO_resource(Folder):
return self.REQUEST.RESPONSE.redirect(self.link)
+ def startpage_html(self):
+ """prints out a startpage for a resource for use e.g. in the BVE"""
+
+ # suche ob startpage.html in dem Ordner vorhanden ist, dann wir diese angezeigt
+
+ sp=self.ZopeFind(self,obj_ids=['startpage.html'])
+
+ if sp:
+ return sp[1]()
+
+ #prüfen ob irgendwo ein template
+ if hasattr(self,'startpage_index_template'):
+ return self.startpage_index_template()
+
+ #generisches template ausgeben
+
+ pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_startpage_index_template_standard.zpt').__of__(self)
+ pt.content_type="text/html"
+ return pt()
+
+ def toc_html(self):
+
+ sp=self.ZopeFind(self,obj_ids=['toc.html'])
+
+ if sp:
+ return sp[0][1]()
+
+
+
def generate_label(self):
"""Erzeugt_standard_Label aus Template"""
pt=getattr(self,"label_template_"+self.bib_type)
return pt()
+ def generate_title(self,RESPONSE=None):
+ """Erzeugt_standard_Label aus Template"""
+ pt=getattr(self,"label_template_"+self.contentType)
+
+ self.title=pt()
+
+ return pt()
+
def manage_addECHO_resourceForm(self):
"""Form for adding a ressource"""
pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_resourceForm.zpt').__of__(self)
@@ -802,10 +985,10 @@ def manage_addECHO_resourceForm(self):
-def manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
+def manage_addECHO_resource(self,id,title,label,description,responsible,link,metalink,weight,copyrightType=None,resourceID=None,contentType=None,renderingType=None,credits=None,coords=None,RESPONSE=None):
"""addaresource"""
- newObj=ECHO_resource(id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords)
+ newObj=ECHO_resource(id,link,metalink,resourceID,title,label,description,contentType,renderingType,copyrightType,responsible,credits,weight,coords)
self._setObject(id,newObj)
@@ -854,7 +1037,7 @@ 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)
return pt()
@@ -880,12 +1063,6 @@ class ECHO_externalLink(Folder):
{'label':'Main Config','action':'ECHO_externalLink_config'},
)
- def getCredits(self):
- """Ausgabe der credits"""
- if self.credits:
- return self.credits
- else:
- return []
def index_html(self):
"""standard page"""
@@ -947,6 +1124,34 @@ class ECHO_collection(Folder, Persistent
viewClassificationList=viewClassificationListMaster
displayTypes=displayTypes
+ 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="