⇤ ← Revision 1 as of 2008-06-26 12:26:08
Size: 2202
Comment: Created by the PackagePages action.
|
Size: 2200
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 5: | Line 5: |
The API is documented here: http://www.fedora-commons.org/documentation/3.0b2/userdocs/index.html#webservices | The API is documented here: http://www.fedora-commons.org/documentation/3.0/userdocs/index.html#webservices |
Fedora 3.0 API
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:
The possibilities "PurgeDatastream" and "PurgeObject" are not allowed. Instead change the state to deleted
- setDatastreamVersionable is disallowed. The internal datastreams are always versioned.
- Do not use getNextPID, instead use the method provided from DOMS
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
- Call the method for generating DOMS PIDs seven times
- Generate 7 FoxML objects, each with the administrative state set to "intermediate"
Call API-M ingest seven times
Call API-M modifyDatastreamByValue 7 times to update the state to "published"
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.
Call API-M modifyDatastreamByValue 8 times to update the administrative state to "intermediate"
Update datastreams and relations as needed to make the changes using addRelationsship/addDatastream/purgeRelationship/modifyDatastreamByValue/setDatastreamState
Call API-M modifyDatastreamByValue 8 times to update the administrative state to "published"