Difference between revisions of "Archivematica API"

From Archivematica
Jump to navigation Jump to search
(Add completed endpoints)
(Update formatting to match SS API docs)
Line 9: Line 9:
 
=== Start Transfer ===
 
=== Start Transfer ===
 
* '''URL''': <code>/api/transfer/start_transfer/</code>
 
* '''URL''': <code>/api/transfer/start_transfer/</code>
* '''Verbs''': POST
+
* '''Verb''': POST
 
* Start a transfer.
 
* Start a transfer.
* '''Parameters''':
+
* '''Parameters''': JSON body
** ''name'': Name of new transfer
+
** <code>name</code>: Name of new transfer
** ''type'': Type of the new transfer. One of: standard, unzipped bag, zipped bag, dspace
+
** <code>type</code>: Type of the new transfer. One of: standard, unzipped bag, zipped bag, dspace
** ''accession'': Accession number of new transfer
+
** <code>accession</code>: Accession number of new transfer
** ''paths[]'': List of base64-encoded "<location_uuid>:<relative_path>" to be copied into the new transfer. Location UUIDs should be associated with this pipeline, and relative path should be relative to the location (TODO confirm relative vs absolute path).  E.g. NWJiYWJjMTMtMTIyNy00MWE3LWIwY2QtZjJhYzM1MjkxZTdmOi92YWdyYW50L3NhbXBsZWRhdGEvQ1NWbWV0YWRhdGE= (decoded: 5bbabc13-1227-41a7-b0cd-f2ac35291e7f:/vagrant/sampledata/CSVmetadata)
+
** <code>paths[]</code>: List of base64-encoded "<location_uuid>:<relative_path>" to be copied into the new transfer. Location UUIDs should be associated with this pipeline, and relative path should be relative to the location (TODO confirm relative vs absolute path).  E.g. NWJiYWJjMTMtMTIyNy00MWE3LWIwY2QtZjJhYzM1MjkxZTdmOi92YWdyYW50L3NhbXBsZWRhdGEvQ1NWbWV0YWRhdGE= (decoded: 5bbabc13-1227-41a7-b0cd-f2ac35291e7f:/vagrant/sampledata/CSVmetadata)
** ''row_ids[]'': ID of the associated TransferMetadataSet for disk image ingest.  Can be provided as [""]
+
** <code>row_ids[]</code>: ID of the associated TransferMetadataSet for disk image ingest.  Can be provided as [""]
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Copy successful."
+
** <code>message</code>: "Copy successful."
** ''path'': Path the transfer was copied to on start?
+
** <code>path</code>: Path the transfer was copied to on start?
  
=== List Unapproved Transfers ===  
+
=== List Unapproved Transfers ===
 
* '''URL''': <code>/api/transfer/unapproved</code>
 
* '''URL''': <code>/api/transfer/unapproved</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Returns a list of transfers waiting for approval.
 
* Returns a list of transfers waiting for approval.
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Fetched unapproved transfers successfully."
+
** <code>message</code>: "Fetched unapproved transfers successfully."
** ''results'': List of dicts with keys:
+
** <code>results</code>: List of dicts with keys:
*** ''type'': Transfer type. One of: standard, unzipped bag, zipped bag, dspace
+
*** <code>type</code>: Transfer type. One of: standard, unzipped bag, zipped bag, dspace
*** ''directory'': Directory the transfer is in currently
+
*** <code>directory</code>: Directory the transfer is in currently
*** ''uuid'': UUID of the transfer
+
*** <code>uuid</code>: UUID of the transfer
  
 
=== Approve Transfer ===
 
=== Approve Transfer ===
 
* '''URL''': <code>/api/transfer/approve</code>
 
* '''URL''': <code>/api/transfer/approve</code>
* '''Verbs''': POST
+
* '''Verb''': POST
 
* Approve a transfer waiting to be started.
 
* Approve a transfer waiting to be started.
* '''Parameters''':
+
* '''Parameters''': JSON body
** ''type'': Type of the transfer to approved. One of: standard, unzipped bag, zipped bag, dspace.
+
** <code>type</code>: Type of the transfer to approved. One of: standard, unzipped bag, zipped bag, dspace.
** ''directory'': Name of the directory for the transfer to approve
+
** <code>directory</code>: Name of the directory for the transfer to approve
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Approval successful."
+
** <code>message</code>: "Approval successful."
** ''uuid'': UUID of the approved transfer
+
** <code>uuid</code>: UUID of the approved transfer
  
 
=== Status ===
 
=== Status ===
 
* '''URL''': <code>/transfer/status/<transfer UUID>/</code>
 
* '''URL''': <code>/transfer/status/<transfer UUID>/</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Returns the status of the transfer.
 
* Returns the status of the transfer.
* '''Fields''':
+
* '''Response''': JSON
** ''status'': One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
+
** <code>status</code>: One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
** ''name'': Name of the transfer, e.g. "imgs"
+
** <code>name</code>: Name of the transfer, e.g. "imgs"
** ''sip_uuid'': If status is COMPLETE, this field will exist with either the UUID of the SIP or 'BACKLOG'
+
** <code>sip_uuid</code>: If status is COMPLETE, this field will exist with either the UUID of the SIP or 'BACKLOG'
** ''microservice'': Name of the current microservice
+
** <code>microservice</code>: Name of the current microservice
** ''directory'': Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
+
** <code>directory</code>: Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
** ''path'': Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/watchedDirectories/SIPCreation/completedTransfers/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
+
** <code>path</code>: Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/watchedDirectories/SIPCreation/completedTransfers/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
** ''message'': "Fetched status for <transfer UUID> successfully."
+
** <code>message</code>: "Fetched status for <transfer UUID> successfully."
** ''type'': "transfer"
+
** <code>type</code>: "transfer"
** ''uuid'': UUID of the transfer, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"
+
** <code>uuid</code>: UUID of the transfer, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"
  
 
=== Hide ===
 
=== Hide ===
 
* '''URL''': <code>/api/transfer/<transfer UUID>/delete/</code>
 
* '''URL''': <code>/api/transfer/<transfer UUID>/delete/</code>
* '''Verbs''': DELETE
+
* '''Verb''': DELETE
 
* Hide a transfer
 
* Hide a transfer
* '''Fields''':
+
* '''Response''': JSON
** ''removed'': True
+
** <code>removed</code>: True
  
 
=== Completed ===
 
=== Completed ===
 
* '''URL''': <code>/api/transfer/completed/</code>
 
* '''URL''': <code>/api/transfer/completed/</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Return list of Transfers that are completed
 
* Return list of Transfers that are completed
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Fetched completed transfers successfully."
+
** <code>message</code>: "Fetched completed transfers successfully."
** ''results'': List of UUIDs of completed Transfers
+
** <code>results</code>: List of UUIDs of completed Transfers
 
* Added in Archivematica 1.6
 
* Added in Archivematica 1.6
  
 
=== Start Reingest ===
 
=== Start Reingest ===
 
* '''URL''': <code>/api/transfer/reingest</code>
 
* '''URL''': <code>/api/transfer/reingest</code>
* '''Verbs''': POST
+
* '''Verb''': POST
 
* Start a full reingest.
 
* Start a full reingest.
* '''Parameters''':
+
* '''Parameters''': JSON body
** ''name'': Name of the AIP. The AIP should also be found at <code>%sharedDirectory%/tmp/<name></code>
+
** <code>name</code>: Name of the AIP. The AIP should also be found at <code>%sharedDirectory%/tmp/<name></code>
** ''uuid'': UUID of the AIP to reingest
+
** <code>uuid</code>: UUID of the AIP to reingest
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Approval successful."
+
** <code>message</code>: "Approval successful."
** ''reingest_uuid'': UUID of the reingested transfer
+
** <code>reingest_uuid</code>: UUID of the reingested transfer
  
 
== Ingest ==
 
== Ingest ==
Line 89: Line 89:
 
=== Status ===
 
=== Status ===
 
* '''URL''': <code>/ingest/status/<unit UUID>/</code>
 
* '''URL''': <code>/ingest/status/<unit UUID>/</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Returns the status of the SIP
 
* Returns the status of the SIP
* '''Fields''':
+
* '''Response''': JSON
** ''status'': One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
+
** <code>status</code>: One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
** ''name'': Name of the SIP, e.g. "imgs"
+
** <code>name</code>: Name of the SIP, e.g. "imgs"
** ''microservice'': Name of the current microservice
+
** <code>microservice</code>: Name of the current microservice
** ''directory'': Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
+
** <code>directory</code>: Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
** ''path'': Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/currentlyProcessing/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
+
** <code>path</code>: Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/currentlyProcessing/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
** ''message'': "Fetched status for <SIP UUID> successfully."
+
** <code>message</code>: "Fetched status for <SIP UUID> successfully."
** ''type'': "SIP"
+
** <code>type</code>: "SIP"
** ''uuid'': UUID of the SIP, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"
+
** <code>uuid</code>: UUID of the SIP, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"
  
 
=== Hide ===
 
=== Hide ===
 
* '''URL''': <code>/api/ingest/<SIP UUID>/delete/</code>
 
* '''URL''': <code>/api/ingest/<SIP UUID>/delete/</code>
* '''Verbs''': DELETE
+
* '''Verb''': DELETE
 
* Hide a SIP
 
* Hide a SIP
* '''Fields''':
+
* '''Response''': JSON
** ''removed'': True
+
** <code>removed</code>: True
  
 
=== List SIPS Waiting for User Input ===
 
=== List SIPS Waiting for User Input ===
 
* '''URL''': <code>/api/ingest/waiting</code>
 
* '''URL''': <code>/api/ingest/waiting</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Returns a list of SIPs waiting for user input.
 
* Returns a list of SIPs waiting for user input.
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Fetched units successfully."
+
** <code>message</code>: "Fetched units successfully."
** ''results'': List of dicts with keys:
+
** <code>results</code>: List of dicts with keys:
*** ''sip_directory'': Directory the SIP is in currently
+
*** <code>sip_directory</code>: Directory the SIP is in currently
*** ''sip_uuid'': UUID of the SIP
+
*** <code>sip_uuid</code>: UUID of the SIP
*** ''sip_name'': Name of the SIP
+
*** <code>sip_name</code>: Name of the SIP
*** ''microservice'': Name of the current microservice
+
*** <code>microservice</code>: Name of the current microservice
  
 
=== Completed ===
 
=== Completed ===
 
* '''URL''': <code>/api/ingest/completed/</code>
 
* '''URL''': <code>/api/ingest/completed/</code>
* '''Verbs''': GET
+
* '''Verb''': GET
 
* Return list of SIPs that are completed
 
* Return list of SIPs that are completed
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Fetched completed ingests successfully."
+
** <code>message</code>: "Fetched completed ingests successfully."
** ''results'': List of UUIDs of completed SIPs
+
** <code>results</code>: List of UUIDs of completed SIPs
 
* Added in Archivematica 1.6
 
* Added in Archivematica 1.6
  
 
=== Reingest ===
 
=== Reingest ===
 
* '''URL''': <code>/api/ingest/reingest</code>
 
* '''URL''': <code>/api/ingest/reingest</code>
* '''Verbs''': POST
+
* '''Verb''': POST
 
* Start a partial or metadata-only reingest.
 
* Start a partial or metadata-only reingest.
* '''Parameters''':
+
* '''Parameters''': JSON body
** ''name'': Name of the AIP. The AIP should also be found at <code>%sharedDirectory%/tmp/<name></code>
+
** <code>name</code>: Name of the AIP. The AIP should also be found at <code>%sharedDirectory%/tmp/<name></code>
** ''uuid'': UUID of the AIP to reingest
+
** <code>uuid</code>: UUID of the AIP to reingest
* '''Fields''':
+
* '''Response''': JSON
** ''message'': "Approval successful."
+
** <code>message</code>: "Approval successful."
** ''reingest_uuid'': UUID of the reingested SIP
+
** <code>reingest_uuid</code>: UUID of the reingested SIP
  
 
=== Copy Metadata ===
 
=== Copy Metadata ===
 
* '''URL''': <code>/api/ingest/copy_metadata_files/</code>
 
* '''URL''': <code>/api/ingest/copy_metadata_files/</code>
* '''Verbs''': POST
+
* '''Verb''': POST
 
* Add metadata files to a SIP.
 
* Add metadata files to a SIP.
* '''Parameters''':
+
* '''Parameters''': JSON body
** ''sip_uuid'': UUID of the SIP to put files in
+
** <code>sip_uuid</code>: UUID of the SIP to put files in
** ''source_paths[]'': List of files to be copied, base64 encoded, in the format 'source_location_uuid:full_path'
+
** <code>source_paths[]</code>: List of files to be copied, base64 encoded, in the format 'source_location_uuid:full_path'
* '''Fields''':
+
* '''Response''': JSON
** ''error'': False
+
** <code>error</code>: False
** ''message'': "Files added successfully."
+
** <code>message</code>: "Files added successfully."
  
 
== Administration ==
 
== Administration ==
Line 155: Line 155:
 
=== Levels of Description ===
 
=== Levels of Description ===
 
* '''URL''': <code>/api/administration/dips/atom/levels/</code>
 
* '''URL''': <code>/api/administration/dips/atom/levels/</code>
* '''Verbs''': GET?
+
* '''Verb''': GET?
 
* Returns a JSON-encoded set of the configured levels of description.
 
* Returns a JSON-encoded set of the configured levels of description.
* ''Returns'': List of AtoM Levels of description with key 'UUID' and value 'name of level of description'.
+
* ''Response'': JSON. List of AtoM Levels of description with key 'UUID' and value 'name of level of description'.
  
 
=== Fetch Levels of Description ===
 
=== Fetch Levels of Description ===
 
* '''URL''': <code>/api/administration/dips/atom/fetch_levels/</code>
 
* '''URL''': <code>/api/administration/dips/atom/fetch_levels/</code>
* '''Verbs''': GET?
+
* '''Verb''': GET?
 
* Fetch all levels of description from an AtoM database, replacing any previously existing.
 
* Fetch all levels of description from an AtoM database, replacing any previously existing.
* ''Returns'': Updated list of AtoM Levels of description with key 'UUID' and value 'name of level of description'.
+
* '''Response''': JSON. Updated list of AtoM Levels of description with key 'UUID' and value 'name of level of description'.
  
 
== Other ==
 
== Other ==
Line 169: Line 169:
 
=== Path Metadata ===
 
=== Path Metadata ===
 
* '''URL''': <code>/api/filesystem/metadata/</code>
 
* '''URL''': <code>/api/filesystem/metadata/</code>
* '''Verbs''': GET, POST
+
* '''Verb''': GET, POST
 
* Fetch (GET) or update (POST) metadata for a path (currently only level of description).
 
* Fetch (GET) or update (POST) metadata for a path (currently only level of description).
* '''Parameters''':
+
* '''Parameters''': Query string parameters (GET) or JSON body (POST)
** ''path'': Arranged path to get metadata on
+
** <code>path</code>: Arranged path to get metadata on
* '''GET fields''':
+
* '''GET response''': JSON
** ''level_of_description'': Level of description
+
** <code>level_of_description</code>: Level of description
* '''POST fields''':  
+
* '''POST response''': JSON
** ''success'': True
+
** <code>success</code>: True
  
 
=== Processing Configuration ===
 
=== Processing Configuration ===
 
* '''URL''': <code>/api/processing-configuration/<name></code>
 
* '''URL''': <code>/api/processing-configuration/<name></code>
* '''Verbs''': GET?
+
* '''Verb''': GET?
 
* Return processing configuration with <name>
 
* Return processing configuration with <name>
* ''Content type'': text/xml
+
* '''Response''': The processing config file as a stream.
 +
* '''Content type''': text/xml
  
 
[[Category:Development documentation]]
 
[[Category:Development documentation]]

Revision as of 15:19, 20 March 2017

Main Page > Development > Archivematica API

Endpoints require authentication with a username and API key. This can be submitted as GET parameters (eg ?username=demo&api_key=e6282adabed84e39ffe451f8bf6ff1a67c1fc9f2) or as a header (eg Authorization: ApiKey demo:e6282adabed84e39ffe451f8bf6ff1a67c1fc9f2)

Endpoints return JSON. If there's an error, they will return a 4xx or 5xx HTTP error code and a JSON body {'error': True, 'message': 'message describing error'}

Transfer

Start Transfer

  • URL: /api/transfer/start_transfer/
  • Verb: POST
  • Start a transfer.
  • Parameters: JSON body
    • name: Name of new transfer
    • type: Type of the new transfer. One of: standard, unzipped bag, zipped bag, dspace
    • accession: Accession number of new transfer
    • paths[]: List of base64-encoded "<location_uuid>:<relative_path>" to be copied into the new transfer. Location UUIDs should be associated with this pipeline, and relative path should be relative to the location (TODO confirm relative vs absolute path). E.g. NWJiYWJjMTMtMTIyNy00MWE3LWIwY2QtZjJhYzM1MjkxZTdmOi92YWdyYW50L3NhbXBsZWRhdGEvQ1NWbWV0YWRhdGE= (decoded: 5bbabc13-1227-41a7-b0cd-f2ac35291e7f:/vagrant/sampledata/CSVmetadata)
    • row_ids[]: ID of the associated TransferMetadataSet for disk image ingest. Can be provided as [""]
  • Response: JSON
    • message: "Copy successful."
    • path: Path the transfer was copied to on start?

List Unapproved Transfers

  • URL: /api/transfer/unapproved
  • Verb: GET
  • Returns a list of transfers waiting for approval.
  • Response: JSON
    • message: "Fetched unapproved transfers successfully."
    • results: List of dicts with keys:
      • type: Transfer type. One of: standard, unzipped bag, zipped bag, dspace
      • directory: Directory the transfer is in currently
      • uuid: UUID of the transfer

Approve Transfer

  • URL: /api/transfer/approve
  • Verb: POST
  • Approve a transfer waiting to be started.
  • Parameters: JSON body
    • type: Type of the transfer to approved. One of: standard, unzipped bag, zipped bag, dspace.
    • directory: Name of the directory for the transfer to approve
  • Response: JSON
    • message: "Approval successful."
    • uuid: UUID of the approved transfer

Status

  • URL: /transfer/status/<transfer UUID>/
  • Verb: GET
  • Returns the status of the transfer.
  • Response: JSON
    • status: One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
    • name: Name of the transfer, e.g. "imgs"
    • sip_uuid: If status is COMPLETE, this field will exist with either the UUID of the SIP or 'BACKLOG'
    • microservice: Name of the current microservice
    • directory: Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
    • path: Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/watchedDirectories/SIPCreation/completedTransfers/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
    • message: "Fetched status for <transfer UUID> successfully."
    • type: "transfer"
    • uuid: UUID of the transfer, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"

Hide

  • URL: /api/transfer/<transfer UUID>/delete/
  • Verb: DELETE
  • Hide a transfer
  • Response: JSON
    • removed: True

Completed

  • URL: /api/transfer/completed/
  • Verb: GET
  • Return list of Transfers that are completed
  • Response: JSON
    • message: "Fetched completed transfers successfully."
    • results: List of UUIDs of completed Transfers
  • Added in Archivematica 1.6

Start Reingest

  • URL: /api/transfer/reingest
  • Verb: POST
  • Start a full reingest.
  • Parameters: JSON body
    • name: Name of the AIP. The AIP should also be found at %sharedDirectory%/tmp/<name>
    • uuid: UUID of the AIP to reingest
  • Response: JSON
    • message: "Approval successful."
    • reingest_uuid: UUID of the reingested transfer

Ingest

Status

  • URL: /ingest/status/<unit UUID>/
  • Verb: GET
  • Returns the status of the SIP
  • Response: JSON
    • status: One of FAILED, REJECTED, USER_INPUT, COMPLETE or PROCESSING
    • name: Name of the SIP, e.g. "imgs"
    • microservice: Name of the current microservice
    • directory: Name of the directory, e.g. "imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c"
    • path: Full path to the transfer, e.g. "/var/archivematica/sharedDirectory/currentlyProcessing/imgs-52dd0c01-e803-423a-be5f-b592b5d5d61c/"
    • message: "Fetched status for <SIP UUID> successfully."
    • type: "SIP"
    • uuid: UUID of the SIP, e.g. "52dd0c01-e803-423a-be5f-b592b5d5d61c"

Hide

  • URL: /api/ingest/<SIP UUID>/delete/
  • Verb: DELETE
  • Hide a SIP
  • Response: JSON
    • removed: True

List SIPS Waiting for User Input

  • URL: /api/ingest/waiting
  • Verb: GET
  • Returns a list of SIPs waiting for user input.
  • Response: JSON
    • message: "Fetched units successfully."
    • results: List of dicts with keys:
      • sip_directory: Directory the SIP is in currently
      • sip_uuid: UUID of the SIP
      • sip_name: Name of the SIP
      • microservice: Name of the current microservice

Completed

  • URL: /api/ingest/completed/
  • Verb: GET
  • Return list of SIPs that are completed
  • Response: JSON
    • message: "Fetched completed ingests successfully."
    • results: List of UUIDs of completed SIPs
  • Added in Archivematica 1.6

Reingest

  • URL: /api/ingest/reingest
  • Verb: POST
  • Start a partial or metadata-only reingest.
  • Parameters: JSON body
    • name: Name of the AIP. The AIP should also be found at %sharedDirectory%/tmp/<name>
    • uuid: UUID of the AIP to reingest
  • Response: JSON
    • message: "Approval successful."
    • reingest_uuid: UUID of the reingested SIP

Copy Metadata

  • URL: /api/ingest/copy_metadata_files/
  • Verb: POST
  • Add metadata files to a SIP.
  • Parameters: JSON body
    • sip_uuid: UUID of the SIP to put files in
    • source_paths[]: List of files to be copied, base64 encoded, in the format 'source_location_uuid:full_path'
  • Response: JSON
    • error: False
    • message: "Files added successfully."

Administration

Levels of Description

  • URL: /api/administration/dips/atom/levels/
  • Verb: GET?
  • Returns a JSON-encoded set of the configured levels of description.
  • Response: JSON. List of AtoM Levels of description with key 'UUID' and value 'name of level of description'.

Fetch Levels of Description

  • URL: /api/administration/dips/atom/fetch_levels/
  • Verb: GET?
  • Fetch all levels of description from an AtoM database, replacing any previously existing.
  • Response: JSON. Updated list of AtoM Levels of description with key 'UUID' and value 'name of level of description'.

Other

Path Metadata

  • URL: /api/filesystem/metadata/
  • Verb: GET, POST
  • Fetch (GET) or update (POST) metadata for a path (currently only level of description).
  • Parameters: Query string parameters (GET) or JSON body (POST)
    • path: Arranged path to get metadata on
  • GET response: JSON
    • level_of_description: Level of description
  • POST response: JSON
    • success: True

Processing Configuration

  • URL: /api/processing-configuration/<name>
  • Verb: GET?
  • Return processing configuration with <name>
  • Response: The processing config file as a stream.
  • Content type: text/xml