Fedora 3.0 API

TableOfContents

DOMS metadata objects will be stored in Fedora-commons 3.0. Fedora 3.0 is currently in beta 2, but is expected to be final by the time we release DOMS.

The API is documented here: http://www.fedora-commons.org/documentation/3.0/userdocs/index.html#webservices

The following restrictions apply:

All ingested objects, and all updates, must lead to valid objects, as defined by the data model. The exception is that objects marked as "draft" or "intermediate" in the datamodel are always considered valid.

Making a call to any API method that changes the object to a state not valid as defined by the datamodel will fail. Any call to a state-changing API-call where the object is not first set to intermediate state will fail.

Examples

Saving seven new interrelated objects to DOMS

Since the datamodel may require that all seven objects are correctly ingested and interrelated before they are valid, ingest all seven objects in intermediate state, and then publish them

Updating fields and references for 8 interrelated objects

To make sure that the changes don't interfere with validity, first set the state to intermediate, then update state to published after modifications.

Usage of Fedora API-M and API-A

The following describes those methods of the Fedora API-M and API-A that may be called by the GUI.

Descriptions in the following were copied (in part) from the Fedora documentation at http://www.fedora-commons.org/confluence/display/FCR30/API-M and http://www.fedora-commons.org/confluence/display/FCR30/API-A.

API-A (Fedora Access service API)

Anchor(anchor_describeRepository)

describeRepository

Gets information that describes the repository.

Returns:

Throws:

Anchor(anchor_getDatastreamDissemination)

getDatastreamDissemination

Gets the content of a datastream.

Input parameters:

Returns:

Throws:

Anchor(anchor_getDissemination)

getDissemination

Disseminates the content produced by executing the method specified in the service definition associated the specified digital object.

Input parameters:

Returns:

Throws:

Anchor(anchor_getObjectHistory)

getObjectHistory

Gets a list of timestamps that correspond to modification dates of components. This currently includes changes to Datastreams and disseminators.

Input parameters:

Returns:

Throws:

Anchor(anchor_getObjectProfile)

getObjectProfile

Gets the ObjectProfile of an object, which includes key metadata fields and URLs for the object Dissemination Index and the object Item Index. Can be thought of as a default view of the object.

Input parameters:

Returns:

Throws:

Anchor(anchor_listDatastreams)

listDatastreams

Lists the datastreams of an object.

Input parameters:

Returns:

Throws:

Anchor(anchor_listMethods)

listMethods

Lists all the methods that the object supports.

Input parameters:

Returns:

Throws:

Usage of Fedora RISearch

http://wiki.statsbiblioteket.dk/domswiki/RIsearch