some fixes to oaipmh: namespaces
authorMarcin Koziej <marcin@lolownia.org>
Wed, 5 Sep 2012 12:36:30 +0000 (14:36 +0200)
committerMarcin Koziej <marcin@lolownia.org>
Wed, 5 Sep 2012 12:36:30 +0000 (14:36 +0200)
apps/oai/handlers.py
apps/oai/views.py

index b49bfaa..824cca9 100644 (file)
@@ -27,6 +27,8 @@ wl_dc_reader = metadata.MetadataReader(
     'identifier':  ('textList', 'rdf:RDF/rdf:Description/dc:identifier.url/text()'),
     'source':      ('textList', 'rdf:RDF/rdf:Description/dc:source/text()'),
     'language':    ('textList', 'rdf:RDF/rdf:Description/dc:language/text()'),
     'identifier':  ('textList', 'rdf:RDF/rdf:Description/dc:identifier.url/text()'),
     'source':      ('textList', 'rdf:RDF/rdf:Description/dc:source/text()'),
     'language':    ('textList', 'rdf:RDF/rdf:Description/dc:language/text()'),
+    'isPartOf':     ('textList', 'rdf:RDF/rdf:Description/dc:relation.isPartOf/text()'),
+    'hasPart':     ('textList', 'rdf:RDF/rdf:Description/dc:relation.hasPart/text()'),
     #    'relation':    ('textList', 'rdf:RDF/rdf:Description/dc:relation/text()'),
     #    'coverage':    ('textList', 'rdf:RDF/rdf:Description/dc:coverage/text()'),
     'rights':      ('textList', 'rdf:RDF/rdf:Description/dc:rights/text()')
     #    'relation':    ('textList', 'rdf:RDF/rdf:Description/dc:relation/text()'),
     #    'coverage':    ('textList', 'rdf:RDF/rdf:Description/dc:coverage/text()'),
     'rights':      ('textList', 'rdf:RDF/rdf:Description/dc:rights/text()')
index eb90035..4c44e56 100644 (file)
@@ -1,17 +1,39 @@
 
 from oai.handlers import Catalogue
 
 from oai.handlers import Catalogue
-from oaipmh.server import ServerBase, oai_dc_writer, NS_OAIDC, NS_DC, NS_XSI
+from oaipmh.server import ServerBase, oai_dc_writer, NS_OAIDC, NS_DC, NS_XSI, nsoaidc, nsdc
 from oaipmh.metadata import MetadataRegistry
 from django.http import HttpResponse
 from oaipmh.metadata import MetadataRegistry
 from django.http import HttpResponse
-from lxml.etree import tostring
+from lxml.etree import tostring, SubElement
+
 
 
-metadata_registry = MetadataRegistry()
-metadata_registry.registerWriter('oai_dc', oai_dc_writer)
 ns_map = {'oai_dc': NS_OAIDC, 'dc': NS_DC, 'xsi': NS_XSI}
 
 ns_map = {'oai_dc': NS_OAIDC, 'dc': NS_DC, 'xsi': NS_XSI}
 
-server = ServerBase(Catalogue(metadata_registry), metadata_registry, ns_map)
+
+def fbc_oai_dc_writer(element, metadata):
+    """FBC notified us that original writer does not output all necessary namespace declarations.
+    """
+    e_dc = SubElement(element, nsoaidc('dc'),
+                      nsmap={'oai_dc': NS_OAIDC, 'dc': NS_DC, 'xsi': NS_XSI})
+    e_dc.set('{%s}schemaLocation' % NS_XSI,
+             '%s http://www.openarchives.org/OAI/2.0/oai_dc.xsd' % NS_OAIDC)
+    map = metadata.getMap()
+    for name in [
+        'title', 'creator', 'subject', 'description', 'publisher',
+        'contributor', 'date', 'type', 'format', 'identifier',
+        'source', 'language', 'relation', 'coverage', 'rights',
+        'isPartOf', 'hasPart']:
+        for value in map.get(name, []):
+            e = SubElement(e_dc, nsdc(name))
+            e.text = value
+               
+
+metadata_registry = MetadataRegistry()
+metadata_registry.registerWriter('oai_dc', fbc_oai_dc_writer)
+
+server = ServerBase(Catalogue(metadata_registry), metadata_registry,
+    {'topxsi': NS_XSI})
 
 
 def oaipmh(request):
     resp = server.handleRequest(request.GET)
 
 
 def oaipmh(request):
     resp = server.handleRequest(request.GET)
-    return HttpResponse(resp)
+    return HttpResponse(resp, content_type='application/xml')