= Improvements to the OAIPMH Harvester =
|| '''Date''' || 2012-07-16 ||
|| '''Contact(s)''' || Simon Pigot ||
|| '''Last edited''' || 2012-07-16 ||
|| '''Status''' || draft, being discussed ||
|| '''Assigned to release''' || 2.9 ||
|| '''Resources''' || Available ||
|| '''Ticket #''' || #XYZ ||
== Overview ==
OAIPMH Harvester in !GeoNetwork needs to be enhanced to support the following:
=== '''Object harvesting''' ===
In recent times !GeoNetwork has moved from supporting ISO19115/19139 metadata in the form of a 'record' to supporting a tree based hierarchy of ISO19115/19139 metadata 'objects'. The diagram below shows a typical hierarchy:
The mechanisms for handling these relationships are part of the ISO standard. They can be explicit in the form of an xlink that refers directly to the related metadata object or implicit by including the UUID of a related metadata object as content in an element. Here is an example of an explicit relationship between a metadata record and a fragment of contact information that it includes:
{{{
}}}
Here is an example of an implicit relationship where the UUID of the parent record in a parent-child relationship is held in the content of the parent identifier element:
{{{
urn:marine.csiro.au:project:187
}}}
And another example of an implicit relationship where the UUID of the sibling record in a sibling relationship between a dataset metadata record and a project metadata record (uuid: urn:marine.csiro.au:marlin:project:187) is held as a code in an identifier element:
{{{
...
urn:marine.csiro.au:marlin:project:187
...
crossReference
project
}}}
OAIPMH and most other harvesters are record based. ie. it is expected or assumed that a harvest will retrieve one or more metadata records. !GeoNetwork's OAIPMH server returns records by '''resolving''' xlink references to metadata objects. The resolve process:
* finds the fragment of metadata referenced by the xlink (which could be local to the catalog or external to the catalog)
* copies the fragment of metadata into the record
Metadata objects that are implicitly referenced as UUIDs in the content are not resolved.
One of the goals of this proposal is to provide an alternative OAIPMH harvester service that:
* retrieves metadata records with '''unresolved''' references
* retrieves and adds all referenced metadata objects to the OAIPMH harvest results
* extends the current OAIPMH implementation: the default behaviour will be to return resolved metadata records. Referencing the alternative OAIPMH service will deliver all metadata objects in unresolved form.
The reason for implementing this extension is to enable conversions to formats that support metadata objects eg. ANDS RIF-CS.
=== '''Deleted Records''' ===
This is a feature of the OAIPMH standard that has not been implemented in the !GeoNetwork OAIPMH server but has been implemented in the OAIPMH client. To implement this capability in the !GeoNetwork OAIPMH server:
* Records (and metadata objects in general) that have been deleted from the catalog should remain searchable by date range and/or set but be marked as deleted when returning results to an OAIPMH if the delete date-time is in the query date-time range and/or the deleted record is part of a requested set of records.
The idea behind this feature is that a harvester can use the response from a determine whether a record has been deleted.
== Proposal Type ==
* '''Type''': Core Change
* '''App''': !GeoNetwork
* '''Module''': Kernel, Harvester, Data Manager, Lucene Index
== Detailed Proposal ==
=== Deleted Records ===
'''OAIPMH server''': This proposal will implement the deleted records capability as follows:
* Metadata records that are deleted from the !GeoNetwork catalog will continue to be removed from the database table and archived.
* Before removal, a subset of the content (date of deletion, uuid, schema) will be added to a table of deleted records and indexed with status set to deleted so that they are excluded from normal searches (this will require a change to the default Lucene search terms).
* The OAIPMH server will advertise that it maintains deleted records in a persistent manner when answering the OAIPMH "Identify" request.
'''OAIPMH client''': This proposal will implement the deleted records capability as follows:
* If the OAIPMH server being harvested advertises that it maintains deleted records in a persistent manager, then records will not be deleted at the start of the harvest. Instead, records will be updated and .
=== Links ===
* '''Documents''': http://www.openarchives.org/OAI/openarchivesprotocol.html#DeletedRecords
* '''Email discussions''':
* '''Other wiki discussions''':
=== Voting History ===
* Vote proposed by X on Y, result was +/-n (m non-voting members).