DataCite Support

 

Version History

  • v.1: June 25, 2016, first draft.
  • v.1.1: October 10, 2016, follow JSONAPI spec for side-loading associations
  • v.1.2: December 9, 2017, follow JSONAPI spec for pagination

Overview

The DataCite REST API returns information about DataCite content. The API is generally RESTFUL and returns results in JSON. It follows the JSONAPI specification. The mime-type for API results is application/vnd.api+json. There are two general types of results:

  • Singletons
  • Lists

Singletons

Singletons are single results. Retrieving metadata for a specific identifier (e.g. DOI, ORCID) typically returns a singleton result.

Lists

Lists results can contain multiple entries. Searching or filtering typically returns a list result. A list has three parts:

  • meta, which includes information about the query, e.g. number of results returned.
  • data, which will contain the items matching the query or filter.
  • included, which will contain side-loaded associations, via the ?include=x parameter.

Major resource components supported by the DataCite API are (in alphabetical order):

These can be used alone like this

Resource Description
/data-centers returns a list of all DataCite data centers
/members returns a list of all DataCite members
/works returns a list of all works (datasets, text documents, etc.), 25 per page

Resource components and identifiers

Resource components can be used in conjunction with identifiers to retrieve the metadata for that identifier.

Resource Description
/members/{member-id} returns metadata for a DataCite member
/data-centers/{data-center-id} returns metadata for a DataCite data center
/works/{doi} returns metadata for the specified DataCite DOI.

Notes on dates

Note that dates in filters should always be of the form YYYY-MM-DD, YYYY-MM or YYYY. Also note that the date published in DataCite metadata is always expressed as YYYY (the publicationYear field).

Page[size]

Normally, results are returned 25 at a time. You can control the number of results returns by using the page[size] parameter. To limit results to 5, for example, you could do the following:

# GET /works?query=
$ curl https://api.datacite.org/works?query=allen+renear&page[size]=5

If you would just like to get the summary of the results, you can set the page[size] to 1.

# GET /works?query=
$ curl https://api.datacite.org/works?query=allen+renear&page[size]=1

The maximum page[size] you can ask for in one query is 1000.

Page[number]

The number of returned items is controlled by the page[size] parameter, but you can select the page of the result list by using the page[number] parameter. So, for example, to select the second set of 5 results (i.e. results 6 through 10), you would do the following:

# GET /works?query=
$ curl https://api.datacite.org/works?query=allen+renear&page[size]=5&page[number]=2

Includes

To sideload associations use the include parameter, for example:

# GET /works?query=
$ curl https://api.datacite.org/works?query=climate&include=data-center,resource-type

Sideload multiple associations by providing them in a comma-separated list.

Notes on owner prefixes

The prefix of a DataCite DOI does NOT indicate who currently owns the DOI.

DataCite also has data-center_id (datacentre_symbol in the DataCite metadata) for depositing organisations. A single data center may control multiple owner prefixes, which in turn may control a number of DOIs. When looking at works published by a certain organisation, data_center_ids and the data center routes should be used.

Queries support a subset of DisMax, so, for example, you can refine queries as follows.

Works that include "renear" but not "ontologies":

GET /works?query=
$ curl https://api.datacite.org/works?query=renear+-ontologies

Sorting

Results from a list response can be sorted by applying the sort and order parameters. Order sets the result ordering, either asc or desc. Sort sets the field by which results will be sorted. Possible values are:

Sort value Description
score Sort by relevance score
updated Sort by date of most recent change to metadata
deposited Sort by time of most recent deposit
published Sort by publication date

An example that sorts results in order of publication, beginning with the least recent:

GET /works?query=
$ curl https://api.datacite.org/works?query=josiah+carberry&sort=published&order=asc

Facet Counts

Facet counts are returned via the meta object. Facet counts give counts per field value for an entire result set. The following facet counts are returned:

Resource Facet counts
/data centers total, members
/works total, data-centers, resource-types, schema-versions, sources, years

All other resources return only total in the meta object.

Filter Names

Filters allow you to narrow queries. All filter results are lists. The following filters are supported:

Filter Possible values Description
member-id {member-id} metadata associated with a specific DataCite member
data-center-id {data-center-id} metadata associated with a specific DataCite data center
resource-id {resource-type-id} metadata for a specific resourceTypeGeneral
source-id {source-id} metadata associated with a specific source
relation-type-id {relation-type-id} metadata associated with a specific relation type
from-created-date {date} metadata where deposited date is since (inclusive) {date}
until-created-date {date} metadata where deposited date is before (inclusive) {date}
from-update-date {date} metadata where updated date is since (inclusive) {date}
until-update-date {date} metadata where updated date is before (inclusive) {date}
year {year} publication year of the resource {year}

Includes

To sideload associations (as specified in the JSONAPI documentation) use the include parameter, for example:

# GET /works?query=
$ curl https://api.datacite.org/works?query=climate&include=data-center,resource-type

Sideload multiple associations by providing them in a comma-separated list. The following resources can be sideloaded:

Resource Resources that can be included
/data-centers member
/works data-center, member, resource-type

When an error occurs, the API will return a JSONAPI error object, for example

{
  "errors": [
    {
      "status": "422",
      "title":  "Invalid Attribute"
    }
  ]
}

Further Details

Review or github repository for further details:
https://github.com/datacite/spinone

 
Suggest Edits

Get Data Center

Returns information about a specific data center

 
gethttps://api.datacite.org/data-centers/data-center-id

Path Params

data-center-id
string
required

returns metadata for a data center

Query Params

include
string

Comma-separated list from member

 
https://api.datacite.org/publishers/cdl.dryad?include=member,registration-agency
A binary file was returned

You couldn't be authenticated

{
    "data": {
        "id": "cdl.dryad",
        "type": "publishers",
        "attributes": {
            "title": "Dryad",
            "other-names": [],
            "prefixes": [],
            "member-id": "cdl",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:04:33Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "cdl",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    },
    "included": [{
        "id": "cdl",
        "type": "members",
        "attributes": {
            "title": "California Digital Library",
            "description": "<p>California Digital Library (CDL) handles scholarly information at every stage of its life. CDL provides technology and expertise to help the University of California (UC) collect, publish, access, and preserve its full range of information resources. CDL partners with organizations outside the UCs on far-reaching problems.</p>\n\n<p>CDL offers DataCite DOIs and other identifiers via the EZID service, a service CDL developed to help educational, non-profit, governmental and commercial clients create and manage globally unique identifiers for data and other sources.</p>\n",
            "member-type": "allocating",
            "region": "Americas",
            "country": "United States",
            "year": 2009,
            "logo-url": "https://assets.datacite.org/images/members/CDL.png",
            "email": "ezid@ucop.edu",
            "website": "http://ezid.cdlib.org",
            "phone": "1-510-987-0469",
            "updated": "2016-09-09T17:46:16.000Z"
        }
    }, {
        "id": "datacite",
        "type": "registration-agencies",
        "attributes": {
            "title": "DataCite",
            "updated": "2016-04-27T02:23:01Z"
        }
    }]
}
{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
 
Suggest Edits

List Data Centers

Returns information about a list of data centers.

 
gethttps://api.datacite.org/data-centers

Query Params

query
string

Query string, e.g. data center name

member-id
string

Member that the data center is associated with

page[number]
int32
page[size]
int32
include
string

Comma-separated list from member

 
http://api.datacite.org/data-centers?member-id=delft&include=member
A binary file was returned

You couldn't be authenticated

{
    "data": [{
        "id": "delft.datacent",
        "type": "publishers",
        "attributes": {
            "title": "3TU Datacentrum",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T19:40:58Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.data4-tu",
        "type": "publishers",
        "attributes": {
            "title": "4TU.Centre for Research Data",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T19:40:58Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.easy",
        "type": "publishers",
        "attributes": {
            "title": "DANS-EASY",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:01:43Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.tpm",
        "type": "publishers",
        "attributes": {
            "title": "Faculty of Technology, Policy and Management, TU Delft",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:11:33Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.iea",
        "type": "publishers",
        "attributes": {
            "title": "International Association for the Evaluation of Educational Achievement",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:26:23Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.isric",
        "type": "publishers",
        "attributes": {
            "title": "ISRIC",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:32:11Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.jrc",
        "type": "publishers",
        "attributes": {
            "title": "Joint Research Centre's Institute of Energy",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:38:06Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.maastro",
        "type": "publishers",
        "attributes": {
            "title": "MAASTRO Clinic",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:52:54Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.nibg",
        "type": "publishers",
        "attributes": {
            "title": "Nederlands Instituut voor Beeld en Geluid",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:55:57Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.tudarch",
        "type": "publishers",
        "attributes": {
            "title": "TU Delft Architecture",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:41:17Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.tudelft",
        "type": "publishers",
        "attributes": {
            "title": "TU Delft Library",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:44:02Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.tue",
        "type": "publishers",
        "attributes": {
            "title": "TU Eindhoven",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T20:44:03Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.eur",
        "type": "publishers",
        "attributes": {
            "title": "Universiteitsbibliotheek EUR",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T21:02:34Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }, {
        "id": "delft.vliz",
        "type": "publishers",
        "attributes": {
            "title": "VLIZ - Vlaams Instituut voor de Zee",
            "other-names": [],
            "prefixes": [],
            "member-id": "delft",
            "registration-agency-id": "datacite",
            "updated": "2017-01-04T19:37:44Z"
        },
        "relationships": {
            "member": {
                "data": {
                    "id": "delft",
                    "type": "members"
                }
            },
            "registration-agency": {
                "data": {
                    "id": "datacite",
                    "type": "registration-agencies"
                }
            }
        }
    }],
    "included": [{
        "id": "delft",
        "type": "members",
        "attributes": {
            "title": "TU Delft Library",
            "description": "<p>The TU Delft Library is the hub of knowledge for technical and scientific information and the largest technical-scientific library in the Netherlands. We support research and education at the national level and are part of the Delft University of Technology. TU Delft Library is a founding member of DataCite and a regional office for the Netherlands.</p>\n\n<p>TU Delft Library has established DataCite Netherlands to serve as a central research dataset registration service that will enable Dutch research organizations to register research datasets and assign digital object identifiers (DOIs) to them. Our aim is to support researchers by improving access to research data and to increase acceptance of the research data as legitimate, citable contributions to scientific record through trustworthy registration and identification of datasets. The current focus of DataCite Netherlands is on promoting the use of digital object identifiers for datasets.</p>\n",
            "member-type": "allocating",
            "region": "EMEA",
            "country": "Netherlands",
            "year": 2009,
            "logo-url": "https://assets.datacite.org/images/members/DELFT.png",
            "email": "library@tudelft.nl",
            "website": "http://www.library.tudelft.nl/en",
            "phone": "+31 15 27 85678",
            "updated": "2016-07-31T23:38:25.000Z"
        }
    }, {
        "id": "datacite",
        "type": "registration-agencies",
        "attributes": {
            "title": "DataCite",
            "updated": "2016-04-27T02:23:01Z"
        }
    }],
    "meta": {
        "total": 14,
        "registration-agencies": [{
            "id": "datacite",
            "title": "DataCite",
            "count": 14
        }],
        "members": [{
            "id": "delft",
            "title": "TU Delft Library",
            "count": 14
        }]
    }
}
 
Suggest Edits

Get Member

Returns information about a DataCite member.

 
gethttps://api.datacite.org/members/member-id

Path Params

member-id
string
required

returns metadata for a DataCite member

 
curl https://api.datacite.org/members/cern
A binary file was returned

You couldn't be authenticated

{
  "data": {
    "id": "cern",
    "type": "members",
    "attributes": {
      "title": "European Organization for Nuclear Research",
      "description": "<p>CERN, the European Organization for Nuclear Research, is the world&#39;s largest particle physics laboratory. Founded in 1954 and based on the Franco-Swiss border near Geneva, it was one of Europe&#39;s first joint ventures and now has 21 member states and more than 50 cooperation agreements and scientific contacts with other countries.</p>\n\n<p>At CERN, physicists and engineers probe the fundamental structure of the universe. They use the world&#39;s largest and most complex scientific instrument, the Large Hadron Collider (LHC), to study the basic constituents of matter. The results of their experimental and theoretical work are publicly available following CERN&#39;s Open Access Policy.</p>\n\n<p>CERN services implementing DOIs are its institutional repository (CDS, CERN Document Server); INSPIRE-HEP, a digital library for the field of High-Energy Physics run in collaboration with other institutions; or the CERN Open Data Portal, which provides high level and analyzable data and software from the LHC experiments.</p>\n\n<p>Furthermore, CERN is also providing DOIs to ZENODO, a multidisciplinary data repository for the “long tail” of research results. It allows researchers to share and preserve their output independent of size, type of material or discipline.</p>\n",
      "member-type": "allocating",
      "region": "EMEA",
      "country": "Switzerland",
      "year": 2014,
      "logo-url": "https://assets.datacite.org/images/members/CERN.png",
      "email": "doi-service@cern.ch",
      "website": "http://doi.web.cern.ch/",
      "phone": null,
      "updated": "2016-07-31T21:30:25.000Z"
    }
  }
}
{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
 
Suggest Edits

List Members

Returns information about a list of DataCite members.

 
gethttps://api.datacite.org/members

Query Params

query
string

query string, e.g. member name

member-type
string

member type (allocating or non-allocating)

region
string

Geographic region (one of amer, apac, emea)

year
string

Year member joined DataCite

 
curl https://api.datacite.org/members
A binary file was returned

You couldn't be authenticated

{
  "data": [
    {
      "id": "ands",
      "type": "members",
      "attributes": {
        "title": "Australian National Data Service",
        "description": "<p>The Australian National Data Service (ANDS) makes Australia&#39;s research data assets more valuable for researchers, research institutions and the nation.</p>\n\n<p>We do this through working in trusted partnerships on research data projects, delivering reliable national services and enhancing the capability of Australia&#39;s research data system.</p>\n\n<p>A key ANDS service is the <a href=\"http://researchdata.ands.org.au/\">Research Data Australia</a> discovery portal where you can find, access and reuse Australian research data.</p>\n\n<p>ANDS is a partnership led by Monash University, in collaboration with the Australian National University and CSIRO. It is funded by the Australian Government through the National Collaborative Research Infrastructure Strategy (NCRIS).</p>\n\n<p>ANDS involvement in the DataCite consortium ensures that we are active in global initiatives addressing the issues surrounding research data, including those of publication, citation and standards. ANDS has run its <a href=\"http://ands.org.au/services/cite-my-data.html\">Cite My Data</a> service since 2011. This service allows Australian research organisations to assign DOIs to their own research collections. This, in turn, provides researchers with a means of citing their published data and achieving recognition for their research data output.</p>\n\n<p>Subscribe to our discussion list: <a href=\"https://groups.google.com/forum/?hl=en#!forum/ands-general\">ANDS Google Group</a>.</p>\n\n<p>Subscribe to our e-newsletter: <a href=\"http://us7.campaign-archive2.com/home/?u=b542ef52e49302569068046d9&amp;id=22b849a4ee\">andsUP</a>.</p>\n",
        "member-type": "allocating",
        "region": "Asia Pacific",
        "country": "Australia",
        "year": 2010,
        "logo-url": "https://assets.datacite.org/images/members/ands.png",
        "email": "contact@ands.org.au",
        "website": "http://www.ands.org.au",
        "phone": "+61 3 9902 0585",
        "updated": "2017-01-10T19:06:20.000Z"
      }
    },
    {
      "id": "snd",
      "type": "members",
      "attributes": {
        "title": "Swedish National Data Service",
        "description": "<p>The Swedish National Data Service (SND) is a national infrastructure for Swedish research within the humanities, social sciences and health sciences. SND offers support to Swedish research by facilitating researchers’ access to data within and outside of Sweden. SND also provides support and guidance to researchers throughout the whole research process.<br>\nAn important part of SND’s mission is to gain a very good overview of existing research databases and to endeavour to gain full knowledge of future databases. Our main task is to take stock of databases relevant to research as well as support archiving, usage and re-usage of databases and related research materials on a national level within SND’s fields of responsibility.</p>\n\n<p>SND is the Swedish node in an international network of data archives (CESSDA). This network is an important part of the global research infrastructure and helps SND to present Swedish research outside of Sweden.</p>\n",
        "member-type": "allocating",
        "region": "EMEA",
        "country": "Sweden",
        "year": 2010,
        "logo-url": "https://assets.datacite.org/images/members/snd.png",
        "email": "pid@snd.gu.se",
        "website": "http://snd.gu.se/en",
        "phone": "+46 31 786 12 06",
        "updated": "2016-09-01T17:15:12.000Z"
      }
    }
  ],
  "meta": {
    "total": 2,
    "member-types": [
      {
        "id": "allocating",
        "title": "Allocating",
        "count": 2
      }
    ],
    "regions": [
      {
        "id": "apac",
        "title": "Asia and Pacific",
        "count": 1
      },
      {
        "id": "emea",
        "title": "Europe, Middle East and Africa",
        "count": 1
      }
    ],
    "years": [
      {
        "id": "2010",
        "title": "2010",
        "count": 2
      }
    ]
  }
}
 
Suggest Edits

Get Person

Returns information about a person.

 
gethttps://api.datacite.org/people/person-id

Path Params

person-id
string
required
 
curl https://api.datacite.org/peope
A binary file was returned

You couldn't be authenticated

{
  "data": [
    {
      "id": "http://orcid.org/0000-0002-7304-0535",
      "type": "contributors",
      "attributes": {
        "given": "Ronald",
        "family": "Aarts",
        "literal": null,
        "orcid": "0000-0002-7304-0535",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-6914-2224",
      "type": "contributors",
      "attributes": {
        "given": "nurul syakima",
        "family": "ab mutalib",
        "literal": null,
        "orcid": "0000-0001-6914-2224",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1265-4186",
      "type": "contributors",
      "attributes": {
        "given": "Cecilia",
        "family": "Abadie",
        "literal": null,
        "orcid": "0000-0003-1265-4186",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-7214-2986",
      "type": "contributors",
      "attributes": {
        "given": "Naeem",
        "family": "Abas",
        "literal": null,
        "orcid": "0000-0002-7214-2986",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4829-3204",
      "type": "contributors",
      "attributes": {
        "given": "Irina",
        "family": "Abaturova",
        "literal": null,
        "orcid": "0000-0003-4829-3204",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-9345-5407",
      "type": "contributors",
      "attributes": {
        "given": "Simona",
        "family": "Abbà",
        "literal": null,
        "orcid": "0000-0001-9345-5407",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-8001-328X",
      "type": "contributors",
      "attributes": {
        "given": "Eslam",
        "family": "Abbas",
        "literal": null,
        "orcid": "0000-0001-8001-328X",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-3721-6054",
      "type": "contributors",
      "attributes": {
        "given": "Mohammad Reza",
        "family": "Abbasi",
        "literal": null,
        "orcid": "0000-0002-3721-6054",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4805-8714",
      "type": "contributors",
      "attributes": {
        "given": "Iftikhar",
        "family": "Abbasov",
        "literal": null,
        "orcid": "0000-0003-4805-8714",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-0899-0232",
      "type": "contributors",
      "attributes": {
        "given": "Abbas",
        "family": "Abbaszadeh",
        "literal": null,
        "orcid": "0000-0003-0899-0232",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4713-6098",
      "type": "contributors",
      "attributes": {
        "given": "Dallas",
        "family": "Abbott",
        "literal": null,
        "orcid": "0000-0003-4713-6098",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6347-9499",
      "type": "contributors",
      "attributes": {
        "given": "Peter",
        "family": "Abbott",
        "literal": null,
        "orcid": "0000-0002-6347-9499",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-4666-3681",
      "type": "contributors",
      "attributes": {
        "given": "Kasper",
        "family": "Abcouwer",
        "literal": null,
        "orcid": "0000-0002-4666-3681",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4488-3063",
      "type": "contributors",
      "attributes": {
        "given": "Leonardo",
        "family": "Abdala Elias",
        "literal": null,
        "orcid": "0000-0003-4488-3063",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6558-7207",
      "type": "contributors",
      "attributes": {
        "given": "Ahmed",
        "family": "Abdalla Alemam Mohamed",
        "literal": null,
        "orcid": "0000-0002-6558-7207",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-6831-1524",
      "type": "contributors",
      "attributes": {
        "given": "Aly",
        "family": "Abdel-Moemin",
        "literal": null,
        "orcid": "0000-0001-6831-1524",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4438-8572",
      "type": "contributors",
      "attributes": {
        "given": "Ahmed",
        "family": "Abdelhady",
        "literal": null,
        "orcid": "0000-0003-4438-8572",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-3863-3749",
      "type": "contributors",
      "attributes": {
        "given": "Ayman",
        "family": "Abdelhai",
        "literal": null,
        "orcid": "0000-0002-3863-3749",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-8232-1403",
      "type": "contributors",
      "attributes": {
        "given": "Boumediene",
        "family": "Abdellaoui",
        "literal": null,
        "orcid": "0000-0001-8232-1403",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-1014-6922",
      "type": "contributors",
      "attributes": {
        "given": "Usama Ramadan",
        "family": "Abdelmohsen",
        "literal": null,
        "orcid": "0000-0002-1014-6922",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-5618-9637",
      "type": "contributors",
      "attributes": {
        "given": "Noorizan",
        "family": "Abdul Majid",
        "literal": null,
        "orcid": "0000-0002-5618-9637",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6257-876X",
      "type": "contributors",
      "attributes": {
        "given": "Alfie",
        "family": "Abdul-Rahman",
        "literal": null,
        "orcid": "0000-0002-6257-876X",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1745-5952",
      "type": "contributors",
      "attributes": {
        "given": "Ayako",
        "family": "Abe-Ouchi",
        "literal": null,
        "orcid": "0000-0003-1745-5952",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-3915-8342",
      "type": "contributors",
      "attributes": {
        "given": "Daniel",
        "family": "Abel-Schaad",
        "literal": null,
        "orcid": "0000-0003-3915-8342",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1122-6622",
      "type": "contributors",
      "attributes": {
        "given": "Carlos",
        "family": "Abellán",
        "literal": null,
        "orcid": "0000-0003-1122-6622",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    }
  ],
  "meta": {
    "total": 7141
  }
}
{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
 
Suggest Edits

List People

Returns information about a list of people.

 
gethttps://api.datacite.org/contributors/

Query Params

page[size]
int32
page[number]
int32
sort
string

can be deposited, published, updated or score

order
string

can be asc or desc

include
string

comma-separated list from publisher, member, registration-agency, resource-type and work-type

 
curl https://api.datacite.org/contributors
A binary file was returned

You couldn't be authenticated

{
  "data": [
    {
      "id": "http://orcid.org/0000-0002-7304-0535",
      "type": "contributors",
      "attributes": {
        "given": "Ronald",
        "family": "Aarts",
        "literal": null,
        "orcid": "0000-0002-7304-0535",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-6914-2224",
      "type": "contributors",
      "attributes": {
        "given": "nurul syakima",
        "family": "ab mutalib",
        "literal": null,
        "orcid": "0000-0001-6914-2224",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1265-4186",
      "type": "contributors",
      "attributes": {
        "given": "Cecilia",
        "family": "Abadie",
        "literal": null,
        "orcid": "0000-0003-1265-4186",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-7214-2986",
      "type": "contributors",
      "attributes": {
        "given": "Naeem",
        "family": "Abas",
        "literal": null,
        "orcid": "0000-0002-7214-2986",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4829-3204",
      "type": "contributors",
      "attributes": {
        "given": "Irina",
        "family": "Abaturova",
        "literal": null,
        "orcid": "0000-0003-4829-3204",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-9345-5407",
      "type": "contributors",
      "attributes": {
        "given": "Simona",
        "family": "Abbà",
        "literal": null,
        "orcid": "0000-0001-9345-5407",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-8001-328X",
      "type": "contributors",
      "attributes": {
        "given": "Eslam",
        "family": "Abbas",
        "literal": null,
        "orcid": "0000-0001-8001-328X",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-3721-6054",
      "type": "contributors",
      "attributes": {
        "given": "Mohammad Reza",
        "family": "Abbasi",
        "literal": null,
        "orcid": "0000-0002-3721-6054",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4805-8714",
      "type": "contributors",
      "attributes": {
        "given": "Iftikhar",
        "family": "Abbasov",
        "literal": null,
        "orcid": "0000-0003-4805-8714",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-0899-0232",
      "type": "contributors",
      "attributes": {
        "given": "Abbas",
        "family": "Abbaszadeh",
        "literal": null,
        "orcid": "0000-0003-0899-0232",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4713-6098",
      "type": "contributors",
      "attributes": {
        "given": "Dallas",
        "family": "Abbott",
        "literal": null,
        "orcid": "0000-0003-4713-6098",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6347-9499",
      "type": "contributors",
      "attributes": {
        "given": "Peter",
        "family": "Abbott",
        "literal": null,
        "orcid": "0000-0002-6347-9499",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-4666-3681",
      "type": "contributors",
      "attributes": {
        "given": "Kasper",
        "family": "Abcouwer",
        "literal": null,
        "orcid": "0000-0002-4666-3681",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4488-3063",
      "type": "contributors",
      "attributes": {
        "given": "Leonardo",
        "family": "Abdala Elias",
        "literal": null,
        "orcid": "0000-0003-4488-3063",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6558-7207",
      "type": "contributors",
      "attributes": {
        "given": "Ahmed",
        "family": "Abdalla Alemam Mohamed",
        "literal": null,
        "orcid": "0000-0002-6558-7207",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-6831-1524",
      "type": "contributors",
      "attributes": {
        "given": "Aly",
        "family": "Abdel-Moemin",
        "literal": null,
        "orcid": "0000-0001-6831-1524",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-4438-8572",
      "type": "contributors",
      "attributes": {
        "given": "Ahmed",
        "family": "Abdelhady",
        "literal": null,
        "orcid": "0000-0003-4438-8572",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-3863-3749",
      "type": "contributors",
      "attributes": {
        "given": "Ayman",
        "family": "Abdelhai",
        "literal": null,
        "orcid": "0000-0002-3863-3749",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0001-8232-1403",
      "type": "contributors",
      "attributes": {
        "given": "Boumediene",
        "family": "Abdellaoui",
        "literal": null,
        "orcid": "0000-0001-8232-1403",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-1014-6922",
      "type": "contributors",
      "attributes": {
        "given": "Usama Ramadan",
        "family": "Abdelmohsen",
        "literal": null,
        "orcid": "0000-0002-1014-6922",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-5618-9637",
      "type": "contributors",
      "attributes": {
        "given": "Noorizan",
        "family": "Abdul Majid",
        "literal": null,
        "orcid": "0000-0002-5618-9637",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0002-6257-876X",
      "type": "contributors",
      "attributes": {
        "given": "Alfie",
        "family": "Abdul-Rahman",
        "literal": null,
        "orcid": "0000-0002-6257-876X",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1745-5952",
      "type": "contributors",
      "attributes": {
        "given": "Ayako",
        "family": "Abe-Ouchi",
        "literal": null,
        "orcid": "0000-0003-1745-5952",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-3915-8342",
      "type": "contributors",
      "attributes": {
        "given": "Daniel",
        "family": "Abel-Schaad",
        "literal": null,
        "orcid": "0000-0003-3915-8342",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    },
    {
      "id": "http://orcid.org/0000-0003-1122-6622",
      "type": "contributors",
      "attributes": {
        "given": "Carlos",
        "family": "Abellán",
        "literal": null,
        "orcid": "0000-0003-1122-6622",
        "github": null,
        "updated": "1970-01-01T00:00:00Z"
      }
    }
  ],
  "meta": {
    "total": 7141
  }
}
{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
 
Suggest Edits

Get Work

Returns the metadata for the specified DOI

 
gethttps://api.datacite.org/works/doi

Path Params

doi
string
required
 
curl https://api.datacite.org/works/10.5438/0012
A binary file was returned

You couldn't be authenticated

{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
{
  "data": {
    "id": "https://doi.org/10.5438/0012",
    "type": "works",
    "attributes": {
      "doi": "10.5438/0012",
      "url": null,
      "author": [
        {
          "literal": "DataCite Metadata Working Group"
        }
      ],
      "title": "DataCite Metadata Schema Documentation for the Publication and Citation of Research Data v4.0",
      "container-title": "DataCite e.V.",
      "description": "1 Introduction\n1.1 The DataCite Consortium\n1.2 DataCite Community Participation\n1.3 The Metadata Schema\n1.4 Version 4.0 Update\n2 DataCite Metadata Properties\n2.1 Overview\n2.2 Citation\n2.3 DataCite Properties\n3 XML Example\n4 XML Schema\n5 Other DataCite Services\nAppendices\nAppendix 1: Controlled List Definitions\nAppendix 2: Earlier Version Update Notes",
      "resource-type-subtype": "Documentation",
      "publisher-id": "datacite.datacite",
      "member-id": "datacite",
      "registration-agency-id": "datacite",
      "resource-type-id": "text",
      "work-type-id": "report",
      "version": "4.0",
      "license": null,
      "schema-version": "4",
      "results": [],
      "published": "2016",
      "deposited": "2016-09-19T21:53:56Z",
      "updated": "2016-09-19T22:16:45Z",
      "media": null,
      "xml": "<?xml version="1.0" encoding="UTF-8"?>
<resource xmlns="http://datacite.org/schema/kernel-4" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://datacite.org/schema/kernel-4 http://schema.datacite.org/meta/kernel-4/metadata.xsd">
	<identifier identifierType="DOI">10.5438/0012</identifier>
	<creators>
		<creator>
			<creatorName>DataCite Metadata Working Group</creatorName>
		</creator>
	</creators>
	<titles>
		<title>DataCite Metadata Schema Documentation for the Publication and Citation of Research Data v4.0</title>
	</titles>
	<publisher>DataCite e.V.</publisher>
	<publicationYear>2016</publicationYear>
	<contributors>
		<contributor contributorType="ProjectLeader">
			<contributorName>Starr, Joan</contributorName>
			<givenName>Joan</givenName>
			<familyName>Starr</familyName>
			<nameIdentifier nameIdentifierScheme="ORCID" schemeURI="http://orcid.org">0000-0002-7285-027X</nameIdentifier>
			<affiliation>California Digital Library</affiliation>
		</contributor>
		<contributor contributorType="ProjectLeader">
			<contributorName>Smaele, Madeleine de</contributorName>
			<givenName>Madeleine de</givenName>
			<familyName>Smaele</familyName>
			<affiliation>TU Delft</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Ashton, Jan</contributorName>
			<givenName>Jan</givenName>
			<familyName>Ashton</familyName>
			<affiliation>British Library</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Barton, Amy</contributorName>
			<givenName>Amy</givenName>
			<familyName>Barton</familyName>
			<affiliation>Purdue University Library</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Bradford, Tina</contributorName>
			<givenName>Tina</givenName>
			<familyName>Bradford</familyName>
			<affiliation>NRC/CISTI</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Ciolek‐Figiel, Anne</contributorName>
			<givenName>Anne</givenName>
			<familyName>Ciolek-Figiel</familyName>
			<affiliation>Inist‐CNRS</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Dietiker, Stefanie</contributorName>
			<givenName>Stefanie</givenName>
			<familyName>Dietiker</familyName>
			<affiliation>ETH Zürich</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Elliott, Jannean</contributorName>
			<givenName>Jannean</givenName>
			<familyName>Elliot</familyName>
			<affiliation>DOE/OSTI</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Genat, Berrit</contributorName>
			<givenName>Berrit</givenName>
			<familyName>Genat</familyName>
			<affiliation>TIB</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Harzenetter, Karoline</contributorName>
			<givenName>Karoline</givenName>
			<familyName>Harzenetter</familyName>
			<affiliation>GESIS</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Hirschmann, Barbara</contributorName>
			<givenName>Barbara</givenName>
			<familyName>Hirschmann</familyName>
			<nameIdentifier nameIdentifierScheme="ORCID" schemeURI="http://orcid.org">0000-0003-0289-0345</nameIdentifier>
			<affiliation>ETH Zürich</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Jakobsson, Stefan</contributorName>
			<givenName>Stefan</givenName>
			<familyName>Jakobsson</familyName>
			<affiliation>SND</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Mailloux, Jean‐Yves</contributorName>
			<givenName>Jean-Yves</givenName>
			<familyName>Mailloux</familyName>
			<affiliation>NRC/CISTI</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Newbold, Elizabeth</contributorName>
			<givenName>Elizabeth</givenName>
			<familyName>Newbold</familyName>
			<nameIdentifier nameIdentifierScheme="ORCID" schemeURI="http://orcid.org">0000-0002-8255-9013</nameIdentifier>
			<affiliation>British Library</affiliation>
		</contributor>
				<contributor contributorType="Editor">
			<contributorName>Nielsen, Lars Holm </contributorName>
			<givenName>Lars Holm</givenName>
			<familyName>Nielsen</familyName>
			<nameIdentifier nameIdentifierScheme="ORCID" schemeURI="http://orcid.org">0000-0001-8135-3489</nameIdentifier>
			<affiliation>CERN</affiliation>
		</contributor>
		<contributor contributorType="Editor">
			<contributorName>Yahia, Mohamed</contributorName>
			<givenName>Mohamed</givenName>
			<familyName>Yahia</familyName>
			<affiliation>Inist-CNRS</affiliation>
		</contributor>
		<contributor contributorType="Supervisor">
			<contributorName>Ziedorn, Frauke</contributorName>
			<givenName>Frauke</givenName>
			<familyName>Ziedorn</familyName>
			<nameIdentifier nameIdentifierScheme="ORCID" schemeURI="http://orcid.org">0000-0002-1143-781X</nameIdentifier>
			<affiliation>TIB</affiliation>
		</contributor>
	</contributors>
	<language>eng</language>
	<resourceType resourceTypeGeneral="Text">Documentation</resourceType>
	<relatedIdentifiers>
		<relatedIdentifier relatedIdentifierType="DOI" relationType="Documents">10.5438/0013</relatedIdentifier>
		<relatedIdentifier relatedIdentifierType="DOI" relationType="IsNewVersionOf">10.5438/0010</relatedIdentifier>
	</relatedIdentifiers>
	<sizes>
		<size>45 pages</size>
	</sizes>
	<formats>
		<format>application/pdf</format>
	</formats>
	<version>4.0</version>
	<descriptions>
		<description descriptionType="TableOfContents">1 Introduction<br/>
1.1 The DataCite Consortium<br/>
1.2 DataCite Community Participation<br/>
1.3 The Metadata Schema<br/>
1.4 Version 4.0 Update<br/>
2 DataCite Metadata Properties<br/>
2.1 Overview<br/>
2.2 Citation<br/>
2.3 DataCite Properties<br/>
3 XML Example<br/>
4 XML Schema<br/>
5 Other DataCite Services<br/>
Appendices<br/>
Appendix 1: Controlled List Definitions<br/>
Appendix 2: Earlier Version Update Notes</description>
	</descriptions>
</resource>
"
    },
    "relationships": {
      "publisher": {
        "meta": {}
      },
      "member": {
        "meta": {}
      },
      "registration-agency": {
        "meta": {}
      },
      "resource-type": {
        "meta": {}
      },
      "work-type": {
        "meta": {}
      }
    }
  }
}
 
Suggest Edits

List Works

Returns a list of works (datasets, text documents, etc.) with associated metadata.

 
gethttps://api.datacite.org/works

Query Params

page[size]
int32
page[number]
int32
sort
string

.can be deposited, published, updated or score

order
string

can be asc or desc

include
string

comma-separated list from data-center, member and resource-type

sample
int32

A random sample from the query results

sample-group
string

One of client, data-center, provider or resource-type

 
curl https://api.datacite.org/works
A binary file was returned

You couldn't be authenticated

{
  "data": [
    {
      "id": "https://doi.org/10.15468/DL.XALEJ0",
      "type": "works",
      "attributes": {
        "doi": "10.15468/DL.XALEJ0",
        "url": null,
        "author": [
          {
            "literal": "Occdownload Gbif.Org"
          }
        ],
        "title": "GBIF Occurrence Download",
        "container-title": "The Global Biodiversity Information Facility",
        "description": "A dataset containing 61 species occurrences available in GBIF matching the query: TaxonKey: Abarema racemiflora (Donn.Sm.) Barneby & J.W.Grimes. The dataset includes 61 records from 13 constituent datasets: \n 1 records from IAC - Herbário do Instituto Agronômico de Campinas. \n 13 records from Plantae of Costa Rica (INBio). \n 20 records from Tropicos Specimen Data. \n 1 records from Natural History Museum (London) Collection Specimens. \n 2 records from Natural History Museum, Vienna - Herbarium W. \n 6 records from herbario. \n 3 records from Harvard University Herbaria. \n 1 records from Field Museum of Natural History (Botany)  Seed Plant Collection. \n 3 records from The vascular plants collection (P) at the Herbarium of the Muséum national d'Histoire Naturelle (MNHN - Paris). \n 2 records from Royal Botanic Gardens, Kew - Herbarium Specimens. \n 6 records from The New York Botanical Garden Herbarium (NY) - Vascular Plant Collection. \n 1 records from Gothenburg Herbarium - General (GBIF:IH:GB:Herbarium). \n 2 records from Geneva Herbarium – General Collection (G). Data from some individual datasets included in this download may be licensed under less restrictive terms.",
        "resource-type-subtype": null,
        "publisher-id": "dk.gbif",
        "member-id": "dk",
        "registration-agency-id": "datacite",
        "resource-type-id": "dataset",
        "work-type-id": "dataset",
        "version": null,
        "license": "https://creativecommons.org/licenses/by/4.0/",
        "schema-version": "3",
        "results": [],
        "published": "2017",
        "deposited": "2017-01-04T01:57:04Z",
        "updated": "2017-01-04T01:57:04Z",
        "media": null,
        "xml": "PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9InllcyI/Pgo8cmVzb3VyY2UgeHNpOnNjaGVtYUxvY2F0aW9uPSJodHRwOi8vZGF0YWNpdGUub3JnL3NjaGVtYS9rZXJuZWwtMyBodHRwOi8vc2NoZW1hLmRhdGFjaXRlLm9yZy9tZXRhL2tlcm5lbC0zL21ldGFkYXRhLnhzZCIgeG1sbnM9Imh0dHA6Ly9kYXRhY2l0ZS5vcmcvc2NoZW1hL2tlcm5lbC0zIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj4KICAgIDxpZGVudGlmaWVyIGlkZW50aWZpZXJUeXBlPSJET0kiPjEwLjE1NDY4L2RsLnhhbGVqMDwvaWRlbnRpZmllcj4KICAgIDxjcmVhdG9ycz4KICAgICAgICA8Y3JlYXRvcj4KICAgICAgICAgICAgPGNyZWF0b3JOYW1lPm9jY2Rvd25sb2FkIGdiaWYub3JnPC9jcmVhdG9yTmFtZT4KICAgICAgICA8L2NyZWF0b3I+CiAgICA8L2NyZWF0b3JzPgogICAgPHRpdGxlcz4KICAgICAgICA8dGl0bGU+R0JJRiBPY2N1cnJlbmNlIERvd25sb2FkPC90aXRsZT4KICAgIDwvdGl0bGVzPgogICAgPHB1Ymxpc2hlcj5UaGUgR2xvYmFsIEJpb2RpdmVyc2l0eSBJbmZvcm1hdGlvbiBGYWNpbGl0eTwvcHVibGlzaGVyPgogICAgPHB1YmxpY2F0aW9uWWVhcj4yMDE3PC9wdWJsaWNhdGlvblllYXI+CiAgICA8c3ViamVjdHM+CiAgICAgICAgPHN1YmplY3QgeG1sOmxhbmc9ImVuZyI+R0JJRjwvc3ViamVjdD4KICAgICAgICA8c3ViamVjdCB4bWw6bGFuZz0iZW5nIj5iaW9kaXZlcnNpdHk8L3N1YmplY3Q+CiAgICAgICAgPHN1YmplY3QgeG1sOmxhbmc9ImVuZyI+c3BlY2llcyBvY2N1cnJlbmNlczwvc3ViamVjdD4KICAgIDwvc3ViamVjdHM+CiAgICA8ZGF0ZXM+CiAgICAgICAgPGRhdGUgZGF0ZVR5cGU9IkNyZWF0ZWQiPjIwMTctMDEtMDQ8L2RhdGU+CiAgICAgICAgPGRhdGUgZGF0ZVR5cGU9IlVwZGF0ZWQiPjIwMTctMDEtMDQ8L2RhdGU+CiAgICA8L2RhdGVzPgogICAgPHJlc291cmNlVHlwZSByZXNvdXJjZVR5cGVHZW5lcmFsPSJEYXRhc2V0Ii8+CiAgICA8YWx0ZXJuYXRlSWRlbnRpZmllcnM+CiAgICAgICAgPGFsdGVybmF0ZUlkZW50aWZpZXIgYWx0ZXJuYXRlSWRlbnRpZmllclR5cGU9IkdCSUYiPjAwNDY5MTAtMTYwOTEwMTUwODUyMDkxPC9hbHRlcm5hdGVJZGVudGlmaWVyPgogICAgPC9hbHRlcm5hdGVJZGVudGlmaWVycz4KICAgIDxyZWxhdGVkSWRlbnRpZmllcnM+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L3c0OHBpaTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L3Rnbm84YTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L2hqYTY5ZjwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjU1MTkvMDAwMjk2NTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4LzVzbDdzaDwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L3lodmJqODwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L28zcHZuaDwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L254bnF6ZjwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L25jNnJ4eTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L2x5NjBieDwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4LzZlOG5qZTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L2Fma2ZwaTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICAgICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iRE9JIiByZWxhdGlvblR5cGU9IlJlZmVyZW5jZXMiPjEwLjE1NDY4L3J2amR1MTwvcmVsYXRlZElkZW50aWZpZXI+CiAgICA8L3JlbGF0ZWRJZGVudGlmaWVycz4KICAgIDxzaXplcz4KICAgICAgICA8c2l6ZT42NDQ5PC9zaXplPgogICAgPC9zaXplcz4KICAgIDxmb3JtYXRzPgogICAgICAgIDxmb3JtYXQ+RGFyd2luIENvcmUgQXJjaGl2ZTwvZm9ybWF0PgogICAgPC9mb3JtYXRzPgogICAgPHJpZ2h0c0xpc3Q+CiAgICAgICAgPHJpZ2h0cyByaWdodHNVUkk9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL2xpY2Vuc2VzL2J5LzQuMC9sZWdhbGNvZGUiPkNyZWF0aXZlIENvbW1vbnMgQXR0cmlidXRpb24gKENDLUJZKSA0LjA8L3JpZ2h0cz4KICAgIDwvcmlnaHRzTGlzdD4KICAgIDxkZXNjcmlwdGlvbnM+CiAgICAgICAgPGRlc2NyaXB0aW9uIGRlc2NyaXB0aW9uVHlwZT0iQWJzdHJhY3QiIHhtbDpsYW5nPSJlbmciPkEgZGF0YXNldCBjb250YWluaW5nIDYxIHNwZWNpZXMgb2NjdXJyZW5jZXMgYXZhaWxhYmxlIGluIEdCSUYgbWF0Y2hpbmcgdGhlIHF1ZXJ5OiBUYXhvbktleTogQWJhcmVtYSByYWNlbWlmbG9yYSAoRG9ubi5TbS4pIEJhcm5lYnkgJmFtcDsgSi5XLkdyaW1lcy4gVGhlIGRhdGFzZXQgaW5jbHVkZXMgNjEgcmVjb3JkcyBmcm9tIDEzIGNvbnN0aXR1ZW50IGRhdGFzZXRzOiAKIDEgcmVjb3JkcyBmcm9tIElBQyAtIEhlcmLDoXJpbyBkbyBJbnN0aXR1dG8gQWdyb27DtG1pY28gZGUgQ2FtcGluYXMuIAogMTMgcmVjb3JkcyBmcm9tIFBsYW50YWUgb2YgQ29zdGEgUmljYSAoSU5CaW8pLiAKIDIwIHJlY29yZHMgZnJvbSBUcm9waWNvcyBTcGVjaW1lbiBEYXRhLiAKIDEgcmVjb3JkcyBmcm9tIE5hdHVyYWwgSGlzdG9yeSBNdXNldW0gKExvbmRvbikgQ29sbGVjdGlvbiBTcGVjaW1lbnMuIAogMiByZWNvcmRzIGZyb20gTmF0dXJhbCBIaXN0b3J5IE11c2V1bSwgVmllbm5hIC0gSGVyYmFyaXVtIFcuIAogNiByZWNvcmRzIGZyb20gaGVyYmFyaW8uIAogMyByZWNvcmRzIGZyb20gSGFydmFyZCBVbml2ZXJzaXR5IEhlcmJhcmlhLiAKIDEgcmVjb3JkcyBmcm9tIEZpZWxkIE11c2V1bSBvZiBOYXR1cmFsIEhpc3RvcnkgKEJvdGFueSkgIFNlZWQgUGxhbnQgQ29sbGVjdGlvbi4gCiAzIHJlY29yZHMgZnJvbSBUaGUgdmFzY3VsYXIgcGxhbnRzIGNvbGxlY3Rpb24gKFApIGF0IHRoZSBIZXJiYXJpdW0gb2YgdGhlIE11c8OpdW0gbmF0aW9uYWwgZCdIaXN0b2lyZSBOYXR1cmVsbGUgKE1OSE4gLSBQYXJpcykuIAogMiByZWNvcmRzIGZyb20gUm95YWwgQm90YW5pYyBHYXJkZW5zLCBLZXcgLSBIZXJiYXJpdW0gU3BlY2ltZW5zLiAKIDYgcmVjb3JkcyBmcm9tIFRoZSBOZXcgWW9yayBCb3RhbmljYWwgR2FyZGVuIEhlcmJhcml1bSAoTlkpIC0gVmFzY3VsYXIgUGxhbnQgQ29sbGVjdGlvbi4gCiAxIHJlY29yZHMgZnJvbSBHb3RoZW5idXJnIEhlcmJhcml1bSAtIEdlbmVyYWwgKEdCSUY6SUg6R0I6SGVyYmFyaXVtKS4gCiAyIHJlY29yZHMgZnJvbSBHZW5ldmEgSGVyYmFyaXVtIOKAkyBHZW5lcmFsIENvbGxlY3Rpb24gKEcpLiBEYXRhIGZyb20gc29tZSBpbmRpdmlkdWFsIGRhdGFzZXRzIGluY2x1ZGVkIGluIHRoaXMgZG93bmxvYWQgbWF5IGJlIGxpY2Vuc2VkIHVuZGVyIGxlc3MgcmVzdHJpY3RpdmUgdGVybXMuPC9kZXNjcmlwdGlvbj4KICAgIDwvZGVzY3JpcHRpb25zPgo8L3Jlc291cmNlPgo="
      },
      "relationships": {
        "publisher": {
          "meta": {}
        },
        "member": {
          "meta": {}
        },
        "registration-agency": {
          "meta": {}
        },
        "resource-type": {
          "meta": {}
        },
        "work-type": {
          "meta": {}
        }
      }
    },
    {
      "id": "https://doi.org/10.6084/M9.FIGSHARE.4007775.V3",
      "type": "works",
      "attributes": {
        "doi": "10.6084/M9.FIGSHARE.4007775.V3",
        "url": null,
        "author": [
          {
            "family": "Matthis",
            "given": "Jonathan"
          }
        ],
        "title": "Biomechanics Center of Mass Animations [VIDEO COLLECTION]",
        "container-title": "Figshare",
        "description": "Repository of a bunch of biomechanics gifs I made. <br><br>More information (including methods and analysis) at the following links: <br><br>Handstand - http://imgur.com/k9ryJq7<div><br></div><div>Balance beam - http://imgur.com/a/lbARg</div><div><br></div><div>Ballerina -http://imgur.com/a/kskuw</div><div><br></div><div>Hammer Throw - http://imgur.com/a/h1DPc<br><br><br>____________________________________<br>More info on me here - <a href=\"https://utexas.academia.edu/JonMatthis/Papers\" target=\"_blank\">https://utexas.academia.edu/JonMatthis/Papers</a></div><div><br></div>",
        "resource-type-subtype": "Media",
        "publisher-id": "figshare.ars",
        "member-id": "figshare",
        "registration-agency-id": "datacite",
        "resource-type-id": "audiovisual",
        "work-type-id": "motion-picture",
        "version": null,
        "license": "https://creativecommons.org/publicdomain/zero/1.0/",
        "schema-version": "3",
        "results": [],
        "published": "2017",
        "deposited": "2017-01-04T01:56:40Z",
        "updated": "2017-01-04T01:56:40Z",
        "media": null,
        "xml": "PHJlc291cmNlIHhtbG5zPSJodHRwOi8vZGF0YWNpdGUub3JnL3NjaGVtYS9rZXJuZWwtMyIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIgeHNpOnNjaGVtYUxvY2F0aW9uPSJodHRwOi8vZGF0YWNpdGUub3JnL3NjaGVtYS9rZXJuZWwtMyBodHRwOi8vc2NoZW1hLmRhdGFjaXRlLm9yZy9tZXRhL2tlcm5lbC0zL21ldGFkYXRhLnhzZCI+PGlkZW50aWZpZXIgaWRlbnRpZmllclR5cGU9IkRPSSI+MTAuNjA4NC9tOS5maWdzaGFyZS40MDA3Nzc1LnYzPC9pZGVudGlmaWVyPjxjcmVhdG9ycz48Y3JlYXRvcj48Y3JlYXRvck5hbWU+Sm9uYXRoYW4gTWF0dGhpczwvY3JlYXRvck5hbWU+PC9jcmVhdG9yPjwvY3JlYXRvcnM+PHRpdGxlcz48dGl0bGU+QmlvbWVjaGFuaWNzIENlbnRlciBvZiBNYXNzIEFuaW1hdGlvbnMgW1ZJREVPIENPTExFQ1RJT05dPC90aXRsZT48L3RpdGxlcz48ZGVzY3JpcHRpb25zPjxkZXNjcmlwdGlvbiBkZXNjcmlwdGlvblR5cGU9IkFic3RyYWN0Ij5SZXBvc2l0b3J5IG9mIGEgYnVuY2ggb2YgYmlvbWVjaGFuaWNzIGdpZnMgSSBtYWRlLsKgJmx0O2JyJmd0OyZsdDticiZndDtNb3JlIGluZm9ybWF0aW9uIChpbmNsdWRpbmcgbWV0aG9kcyBhbmQgYW5hbHlzaXMpIGF0IHRoZSBmb2xsb3dpbmcgbGlua3M6wqAmbHQ7YnImZ3Q7Jmx0O2JyJmd0O0hhbmRzdGFuZCAtIGh0dHA6Ly9pbWd1ci5jb20vazlyeUpxNyZsdDtkaXYmZ3Q7Jmx0O2JyJmd0OyZsdDsvZGl2Jmd0OyZsdDtkaXYmZ3Q7QmFsYW5jZSBiZWFtIC3CoGh0dHA6Ly9pbWd1ci5jb20vYS9sYkFSZyZsdDsvZGl2Jmd0OyZsdDtkaXYmZ3Q7Jmx0O2JyJmd0OyZsdDsvZGl2Jmd0OyZsdDtkaXYmZ3Q7QmFsbGVyaW5hIC1odHRwOi8vaW1ndXIuY29tL2Eva3NrdXcmbHQ7L2RpdiZndDsmbHQ7ZGl2Jmd0OyZsdDticiZndDsmbHQ7L2RpdiZndDsmbHQ7ZGl2Jmd0O0hhbW1lciBUaHJvdyAtwqBodHRwOi8vaW1ndXIuY29tL2EvaDFEUGMmbHQ7YnImZ3Q7Jmx0O2JyJmd0OyZsdDticiZndDtfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18mbHQ7YnImZ3Q7TW9yZSBpbmZvIG9uIG1lIGhlcmUgLcKgJmx0O2EgaHJlZj0iaHR0cHM6Ly91dGV4YXMuYWNhZGVtaWEuZWR1L0pvbk1hdHRoaXMvUGFwZXJzIiB0YXJnZXQ9Il9ibGFuayImZ3Q7aHR0cHM6Ly91dGV4YXMuYWNhZGVtaWEuZWR1L0pvbk1hdHRoaXMvUGFwZXJzJmx0Oy9hJmd0OyZsdDsvZGl2Jmd0OyZsdDtkaXYmZ3Q7Jmx0O2JyJmd0OyZsdDsvZGl2Jmd0OzwvZGVzY3JpcHRpb24+PC9kZXNjcmlwdGlvbnM+PHN1YmplY3RzPjxzdWJqZWN0IHNjaGVtZVVSST0iaHR0cDovL3d3dy5hYnMuZ292LmF1L2F1c3N0YXRzL2Fic0AubnNmLzAvNkJCNDI3QUI5Njk2QzIyNUNBMjU3NDE4MDAwNDQ2M0UiIHN1YmplY3RTY2hlbWU9IkZPUiI+MTEwNjAxIEJpb21lY2hhbmljczwvc3ViamVjdD48c3ViamVjdCBzY2hlbWVVUkk9Imh0dHA6Ly93d3cuYWJzLmdvdi5hdS9hdXNzdGF0cy9hYnNALm5zZi8wLzZCQjQyN0FCOTY5NkMyMjVDQTI1NzQxODAwMDQ0NjNFIiBzdWJqZWN0U2NoZW1lPSJGT1IiPjExMDYwMyBNb3RvciBDb250cm9sPC9zdWJqZWN0PjxzdWJqZWN0IHNjaGVtZVVSST0iaHR0cDovL3d3dy5hYnMuZ292LmF1L2F1c3N0YXRzL2Fic0AubnNmLzAvNkJCNDI3QUI5Njk2QzIyNUNBMjU3NDE4MDAwNDQ2M0UiIHN1YmplY3RTY2hlbWU9IkZPUiI+MTEwNjk5IEh1bWFuIE1vdmVtZW50IGFuZCBTcG9ydHMgU2NpZW5jZSBub3QgZWxzZXdoZXJlIGNsYXNzaWZpZWQ8L3N1YmplY3Q+PC9zdWJqZWN0cz48cHVibGlzaGVyPkZpZ3NoYXJlPC9wdWJsaXNoZXI+PHB1YmxpY2F0aW9uWWVhcj4yMDE3PC9wdWJsaWNhdGlvblllYXI+PGRhdGVzPjxkYXRlIGRhdGVUeXBlPSJDcmVhdGVkIj4yMDE3LTAxLTA0PC9kYXRlPjxkYXRlIGRhdGVUeXBlPSJVcGRhdGVkIj4yMDE3LTAxLTA0PC9kYXRlPjwvZGF0ZXM+PHJlc291cmNlVHlwZSByZXNvdXJjZVR5cGVHZW5lcmFsPSJBdWRpb3Zpc3VhbCI+TWVkaWE8L3Jlc291cmNlVHlwZT48c2l6ZXM+PHNpemU+NjcwMTY3NDQgQnl0ZXM8L3NpemU+PC9zaXplcz48cmVsYXRlZElkZW50aWZpZXJzPjxyZWxhdGVkSWRlbnRpZmllciByZWxhdGVkSWRlbnRpZmllclR5cGU9IkRPSSIgcmVsYXRpb25UeXBlPSJJc0lkZW50aWNhbFRvIj4xMC42MDg0L205LmZpZ3NoYXJlLjQwMDc3NzU8L3JlbGF0ZWRJZGVudGlmaWVyPjwvcmVsYXRlZElkZW50aWZpZXJzPjxyaWdodHNMaXN0PjxyaWdodHMgcmlnaHRzVVJJPSJodHRwczovL2NyZWF0aXZlY29tbW9ucy5vcmcvcHVibGljZG9tYWluL3plcm8vMS4wLyI+Q0MtMDwvcmlnaHRzPjwvcmlnaHRzTGlzdD48L3Jlc291cmNlPg=="
      },
      "relationships": {
        "publisher": {
          "meta": {}
        },
        "member": {
          "meta": {}
        },
        "registration-agency": {
          "meta": {}
        },
        "resource-type": {
          "meta": {}
        },
        "work-type": {
          "meta": {}
        }
      }
    },
    {
      "id": "https://doi.org/10.13140/RG.2.2.17768.88326",
      "type": "works",
      "attributes": {
        "doi": "10.13140/RG.2.2.17768.88326",
        "url": null,
        "author": [
          {
            "family": "Valenzuela-Rendón",
            "given": "Manuel"
          }
        ],
        "title": "vgGA2.0 (Octave/MATLAB)",
        "container-title": "Unpublished",
        "description": null,
        "resource-type-subtype": "Code",
        "publisher-id": "rg.rg",
        "member-id": "rg",
        "registration-agency-id": "datacite",
        "resource-type-id": "dataset",
        "work-type-id": "dataset",
        "version": null,
        "license": null,
        "schema-version": "4",
        "results": [],
        "published": "2017",
        "deposited": "2017-01-04T01:53:30Z",
        "updated": "2017-01-04T01:53:30Z",
        "media": null,
        "xml": "PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9InllcyI/PjxyZXNvdXJjZSB4c2k6c2NoZW1hTG9jYXRpb249Imh0dHA6Ly9kYXRhY2l0ZS5vcmcvc2NoZW1hL2tlcm5lbC00IGh0dHA6Ly9zY2hlbWEuZGF0YWNpdGUub3JnL21ldGEva2VybmVsLTQvbWV0YWRhdGEueHNkIiB4bWxucz0iaHR0cDovL2RhdGFjaXRlLm9yZy9zY2hlbWEva2VybmVsLTQiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxpZGVudGlmaWVyIGlkZW50aWZpZXJUeXBlPSJET0kiPjEwLjEzMTQwL1JHLjIuMi4xNzc2OC44ODMyNjwvaWRlbnRpZmllcj48Y3JlYXRvcnM+PGNyZWF0b3I+PGNyZWF0b3JOYW1lPk1hbnVlbCBWYWxlbnp1ZWxhLVJlbmTDs248L2NyZWF0b3JOYW1lPjwvY3JlYXRvcj48L2NyZWF0b3JzPjx0aXRsZXM+PHRpdGxlPnZnR0EyLjAgKE9jdGF2ZS9NQVRMQUIpPC90aXRsZT48L3RpdGxlcz48cHVibGlzaGVyPlVucHVibGlzaGVkPC9wdWJsaXNoZXI+PHB1YmxpY2F0aW9uWWVhcj4yMDE3PC9wdWJsaWNhdGlvblllYXI+PHJlc291cmNlVHlwZSByZXNvdXJjZVR5cGVHZW5lcmFsPSJEYXRhc2V0Ij5Db2RlPC9yZXNvdXJjZVR5cGU+PC9yZXNvdXJjZT4="
      },
      "relationships": {
        "publisher": {
          "meta": {}
        },
        "member": {
          "meta": {}
        },
        "registration-agency": {
          "meta": {}
        },
        "resource-type": {
          "meta": {}
        },
        "work-type": {
          "meta": {}
        }
      }
    }
  ],
  "meta": {
    "resource-types": [
      {
        "id": "dataset",
        "title": "Dataset",
        "count": 2923633
      },
      {
        "id": "text",
        "title": "Text",
        "count": 1588230
      },
      {
        "id": "other",
        "title": "Other",
        "count": 882665
      },
      {
        "id": "image",
        "title": "Image",
        "count": 833098
      },
      {
        "id": "collection",
        "title": "Collection",
        "count": 381883
      },
      {
        "id": "software",
        "title": "Software",
        "count": 20790
      },
      {
        "id": "audiovisual",
        "title": "Audiovisual",
        "count": 14110
      },
      {
        "id": "event",
        "title": "Event",
        "count": 6932
      },
      {
        "id": "physical-object",
        "title": "Physical object",
        "count": 6679
      },
      {
        "id": "film",
        "title": "Film",
        "count": 947
      },
      {
        "id": "model",
        "title": "Model",
        "count": 604
      },
      {
        "id": "interactive-resource",
        "title": "Interactive resource",
        "count": 407
      },
      {
        "id": "sound",
        "title": "Sound",
        "count": 344
      },
      {
        "id": "workflow",
        "title": "Workflow",
        "count": 252
      },
      {
        "id": "service",
        "title": "Service",
        "count": 29
      }
    ],
    "years": [
      {
        "id": "2016",
        "title": "2016",
        "count": 834677
      },
      {
        "id": "2015",
        "title": "2015",
        "count": 2080251
      },
      {
        "id": "2014",
        "title": "2014",
        "count": 973996
      },
      {
        "id": "2013",
        "title": "2013",
        "count": 353263
      },
      {
        "id": "2012",
        "title": "2012",
        "count": 232386
      },
      {
        "id": "2011",
        "title": "2011",
        "count": 353464
      },
      {
        "id": "2010",
        "title": "2010",
        "count": 159988
      },
      {
        "id": "2009",
        "title": "2009",
        "count": 144549
      },
      {
        "id": "2008",
        "title": "2008",
        "count": 138810
      },
      {
        "id": "2007",
        "title": "2007",
        "count": 170651
      },
      {
        "id": "2006",
        "title": "2006",
        "count": 155580
      },
      {
        "id": "2005",
        "title": "2005",
        "count": 168750
      },
      {
        "id": "2004",
        "title": "2004",
        "count": 86246
      },
      {
        "id": "2003",
        "title": "2003",
        "count": 80393
      },
      {
        "id": "2002",
        "title": "2002",
        "count": 52403
      }
    ],
    "publishers": [
      {
        "id": "cdl.dplanet",
        "title": "Data-Planet",
        "count": 867774
      },
      {
        "id": "bl.ccdc",
        "title": "The Cambridge Crystallographic Data Centre",
        "count": 639461
      },
      {
        "id": "figshare.ars",
        "title": "figshare Academic Research System",
        "count": 527635
      },
      {
        "id": "ethz.seals",
        "title": "E-Periodica",
        "count": 513892
      },
      {
        "id": "estdoi.bio",
        "title": "TÜ Loodusmuuseum",
        "count": 487449
      },
      {
        "id": "rg.rg",
        "title": "ResearchGate",
        "count": 428070
      },
      {
        "id": "gesis.die",
        "title": "Deutsches Institut für Erwachsenenbildung",
        "count": 373193
      },
      {
        "id": "ethz.epics-ba",
        "title": "E-Pics Bildarchiv",
        "count": 361242
      },
      {
        "id": "tib.pangaea",
        "title": "PANGAEA - Publishing Network for Geoscientific and Environmental Data",
        "count": 351387
      },
      {
        "id": "dk.gbif",
        "title": "Global Biodiversity Information Facility",
        "count": 243978
      },
      {
        "id": "cern.hepdata",
        "title": "HEPData.net",
        "count": 236059
      },
      {
        "id": "cisti.ubc",
        "title": "University of British Columbia",
        "count": 198206
      },
      {
        "id": "bl.imperial",
        "title": "Imperial College London",
        "count": 191300
      },
      {
        "id": "ands.centre72",
        "title": "PARADISEC",
        "count": 153467
      },
      {
        "id": "cern.zenodo",
        "title": "ZENODO - Research. Shared.",
        "count": 116167
      }
    ],
    "schema-versions": [
      {
        "id": "4",
        "title": "Schema 4",
        "count": 108228
      },
      {
        "id": "3",
        "title": "Schema 3",
        "count": 6662751
      },
      {
        "id": "2.2",
        "title": "Schema 2.2",
        "count": 1070998
      },
      {
        "id": "2.1",
        "title": "Schema 2.1",
        "count": 5700
      },
      {
        "id": "2.0",
        "title": "Schema 2.0",
        "count": 756
      }
    ],
    "total": 7848433,
    "sources": [],
    "relation-types": []
  }
}
{
  "errors": [
    {
      "status": "404",
      "title": "The page you are looking for doesn't exist."
    }
  ]
}
 
Suggest Edits

List Report

 
get/reports/report_id

Path Params

report_id
string
required

The report ID is a UUID

 
curl --request GET \
  --url https://api.test.datacite.org/reports
require 'uri'
require 'net/http'

url = URI("https://api.test.datacite.org/reports")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Get.new(url)

response = http.request(request)
puts response.read_body
import requests

url = "https://api.test.datacite.org/reports"

response = requests.request("GET", url)

print(response.text)
A binary file was returned

You couldn't be authenticated

Try the API to see results
 
Suggest Edits

Create Report

 
post/reports

Body Params

json

Headers

Content-Type
string
Accept
string
User-Agent
string
 
curl --request POST \
  --url https://api.test.datacite.org/reports
require 'uri'
require 'net/http'

url = URI("https://api.test.datacite.org/reports")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Post.new(url)

response = http.request(request)
puts response.read_body
import requests

url = "https://api.test.datacite.org/reports"

response = requests.request("POST", url)

print(response.text)
A binary file was returned

You couldn't be authenticated

Try the API to see results
 
Suggest Edits

Update Report

 
put/reports/report_id

Path Params

report_id
string
required

its UUID

Body Params

json

Headers

Content-Type
string
Accept
string
User-Agent
string
 
curl --request POST \
  --url https://api.test.datacite.org/reports
require 'uri'
require 'net/http'

url = URI("https://api.test.datacite.org/reports")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Post.new(url)

response = http.request(request)
puts response.read_body
import requests

url = "https://api.test.datacite.org/reports"

response = requests.request("POST", url)

print(response.text)
A binary file was returned

You couldn't be authenticated

Try the API to see results
 
 

Version History

  • v.2: September 1, 2011
  • v3: July 16, 2018

Overview

The MDS (Metadata Store) API can be used to register and manage DOI names and associated metadata. The API requires authentication and is available to DataCite providers and their clients. The basic API endpoint is at https://mds.datacite.org, with the following three resource endpoints:

  • https://mds.datacite.org/doi
  • https://mds.datacite.org/metadata
  • https://mds.datacite.org/media

Authentication

All requests to the MDS API require authentication. For this reason, only traffic via a secure connection (HTTPS) is supported. The DataCite Metadata Store (MDS) uses HTTP Basic authentication.

To start interacting with our DataCite Metadata Store (MDS) API you must request an account:

  • If you are a DataCite Provider, DataCite will provide you a username and password
  • If you are a DataCite Client, your Provider will provide you a username and password
  • If you are not yet a DataCite Provider or Client, you can obtain a demo account

Remember that you will be allowed to register DOI names only under the prefixes that have been assigned to you.

API Response Codes

  • 200 OK - operation successful
  • 201 OK - content created
  • 204 No Content - DOI is known to MDS, but is not registered
  • 401 Unauthorized - no login
  • 403 Forbidden - login problem or DOI belongs to another party
  • 404 Not Found - DOI does not exist in our database
  • 422 Unprocessable Entity - metadata not validating against DataCite schema
  • 500 Internal Server Error - internal server error

Testing

There are three ways you can test the MDS without registering a permanent DOI:

Use draft DOIs

DOIs with registered metadata, but no URL registered, are in draft state, and can be deleted. Read more about DOI states here. Note that draft DOIs will behave like any other DOI, but will not be registered in the Handle system, our Search index, or any other DataCite service outside of DOI registration.

Use demo DOIs with prefix 10.5072

The special demo prefix 10.5072 is available to all clients. All DOIs with this prefix are draft DOIs. In addition, these DOIs can not be transitioned to other DOI states, and are automatically deleted after 30 days. All demo accounts use only the demo prefix.

Use the test MDS

The test MDS at https://mds.test.datacite.org is available to all providers and clients, but special registration is necessary. Please contact [DataCite Support](mailto:support@datacite.org}. DOIs registered in the test MDS will not resolve using the doi.org proxy.

Your own prefixes should not be used for testing DOIs in the production MDS service.

 
Suggest Edits

Get URL for DOI

This request returns an URL associated with a given DOI.

 

Basic Auth

 Authentication is required for this endpoint.
gethttps://mds.test.datacite.org/doi/doi

Path Params

doi
string
required
 
curl --user USERNAME:PASSWORD https://mds.test.datacite.org/doi/10.5438/0012 
A binary file was returned

You couldn't be authenticated

https://schema.datacite.org/meta/kernel-4.0/index.html
An Authentication object was not found in the SecurityContext
DOI not found
 
Suggest Edits

List all DOIs

This request returns a list of all DOIs for the requesting datacentre. There is no guaranteed order.

 

Basic Auth

 Authentication is required for this endpoint.
gethttps://mds.test.datacite.org/doi
 
curl --user USERNAME:PASSWORD https://mds.test.datacite.org/doi 
A binary file was returned

You couldn't be authenticated

10.23725/0000-03VC
10.23725/0000-0A53
10.23725/GQZDGNZW
 
Suggest Edits

Create DOI

Will register a new DOI if the specified DOI doesn’t exist. This method will attempt to update the URL if you specify an existing DOI. Creating a DOI requires authentication credentials.
Note that metadata must be registered for a DOI first, using the create metadata call

 

Basic Auth

 Authentication is required for this endpoint.
puthttps://mds.test.datacite.org/doi/doi

Path Params

doi
string
required

Form Data

string

doi and url separated by newline, e.g. "doi=10.5072/0000-03VC\nurl=http://example.org/"

Headers

Content-Type
string
required
charset
string
required

The MDS API also accepts POST requests using the same format.

curl  -X PUT -H "Content-Type: text/plain;charset=UTF-8" --user USERNAME:PASSWORD --data $'doi=10.5072/0000-03VC\nurl=http://example.org/' https://mds.test.datacite.org/doi/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

 
Suggest Edits

Delete DOI

Deletes a DOI if DOI is in draft status.

 

Basic Auth

 Authentication is required for this endpoint.
deletehttps://mds.test.datacite.org/doi/doi

Path Params

doi
string
required

Headers

Content-Type
string
charset
string
 
curl  -X DELETE -H "Content-Type: text/plain;charset=UTF-8" --user USERNAME:PASSWORD https://mds.test.datacite.org/doi/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

 
Suggest Edits

Get Metadata for DOI

This request returns the most recent version of metadata associated with a given DOI.

 

Basic Auth

 Authentication is required for this endpoint.
gethttps://mds.test.datacite.org/metadata/doi

Path Params

doi
string
required

Headers

Accept
string
required
 
curl -H "Content-Type: application/xml" --user USERNAME:PASSWORD https://mds.test.datacite.org/metadata/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

<?xml version="1.0" encoding="UTF-8"?>
<resource xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://datacite.org/schema/kernel-4" xsi:schemaLocation="http://datacite.org/schema/kernel-4 http://schema.datacite.org/meta/kernel-4/metadata.xsd">
  <identifier identifierType="DOI">10.5072/0000-03VC</identifier>
  <creators>
    <creator>
      <creatorName>Miller, Elizabeth</creatorName>
      <givenName>Elizabeth</givenName>
      <familyName>Miller</familyName>
      <nameIdentifier schemeURI="http://orcid.org/" nameIdentifierScheme="ORCID">0000-0001-5000-0007</nameIdentifier>
    </creator>
  </creators>
  <titles>
    <title>Full DataCite XML Example</title>
  </titles>
  <publisher>DataCite</publisher>
  <publicationYear>2014</publicationYear>
  <resourceType resourceTypeGeneral="Software">XML</resourceType>
  <dates/>
</resource>
 
Suggest Edits

Create Metadata for DOI

This request stores a new version of metadata. The request body must contain valid DataCite XML, or another supported metadata format. Authentication credentials are required.

 

Basic Auth

 Authentication is required for this endpoint.
puthttps://mds.test.datacite.org/metadata/doi

Path Params

doi
string
required

DOI. Auto-generates random DOI if only prefix is provided.

Form Data

string

Metadata in DataCite XML, or another supported metadata format.

Headers

Content-Type
string
required
charset
string
required

The MDS API also accepts POST requests using the same format.

curl -X PUT -H "Content-Type:application/xml;charset=UTF-8" -i --user USERNAME:PASSWORD  -d @10.5072/0000-03VC.xml https://mds.test.datacite.org/metadata/10.5072/0000-03VC
A binary file was returned

You couldn't be authenticated

OK (10.5072/0000-03VC)
 
Suggest Edits

Delete Metadata for DOI

This request marks a dataset as inactive. To activate it again, PUT new metadata.

 

Basic Auth

 Authentication is required for this endpoint.
deletehttps://mds.test.datacite.org/metadata/doi

Path Params

doi
string
required
 
curl -X DELETE --user USERNAME:PASSWORD  https://mds.test.datacite.org/metadata/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

 
Suggest Edits

Get Media for DOI

This request returns list of pairs of media type and URLs associated with a given DOI.

 

Basic Auth

 Authentication is required for this endpoint.
gethttps://mds.test.datacite.org/media/doi

Path Params

doi
string
required

Headers

head
string
 
curl --user USERNAME:PASSWORD https://mds.test.datacite.org/media/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

application/pdf=http://www.datacite.org/cirneco-test.pdf
 
Suggest Edits

Create Media for DOI

POST will add/update media type/URLs pairs to a DOI. Standard domain restrictions check will be performed.

 

Basic Auth

 Authentication is required for this endpoint.
posthttps://mds.test.datacite.org/media/doi

Path Params

doi
string
required

Headers

Content-Type
string
required
charset
string
required
 
curl -X POST -H "Content-Type: text/plain" --user USERNAME:PASSWORD --data "application/pdf=http://www.datacite.org/cirneco-test.pdf" https://mds.datacite.org/media/10.5072/0000-03VC 
A binary file was returned

You couldn't be authenticated

 

The DataCite EZ API allows registration of DOIs and DOI metadata, and tries to be as compatible as possible with the EZID API from the California Digital Library. The service launched in March 2018. While we try to implement features added to the EZID service going forward, no guarantees are made doing so. Because of some fundamental differences between the services provided by EZID and DataCite, some functionalities make no sense as a DataCite service and have not been implemented, including

  • Registration of identifiers other than DataCite DOIs, including ARKs
  • Crossref registration

Some features have not yet been implemented as of March 2018, but are planned for Q1 and Q2 2018 (see DataCite roadmap for details):

  • Registration of metadata in other formats, e.g. Dublin Core
  • Tombstone page for all registered DOIs

Requests for the functionality of the EZID service not (yet) implemented will return appropriate error codes, e.g. a status 501 not implemented.

Some features of the DataCite service are not available in the EZID service, for example the following metadata profiles:

  • bibtex
  • ris
  • schema.org (use profile schema_org)
  • Citeproc JSON (using profile citeproc)

The crossref metadata profile will register a DataCite DOI using metadata in Crossref Unixref format instead of registering the DOI with Crossref.

The base URL of the service is https://ez.datacite.org.

API vs. UI

The EZID-compatible API provided by DataCite is complemented by the user interface of the DOI Fabrica service available at https://doi.datacite.org. The UI can be used to manage registered DOIs, and to reset the password.

Authentication

Most requests require authentication. The API supports HTTP Basic authentication, using the same username and password as for the Metadata Store (MDS) and DOI Fabrica service. With this method, the client supplies HTTP Basic authentication credentials on every request.

In contrast to the EZID API, the DataCite EZ API does not support one-time login via the /login path, with login credentials then stored in a session cookie. Instead, an error message will be returned.

For example, credentials for HTTP basic authentication can be added manually in Python as follows:

import base64, urllib2
r = urllib2.Request("https://ez.datacite.org/...")
r.add_header("Authorization", "Basic " + base64.b64encode("username:password"))

But most programming libraries provide higher-level support for authentication. For example, Python provides HTTPBasicAuthHandler:

import urllib2
h = urllib2.HTTPBasicAuthHandler()
h.add_password("ez.datacite.org", "https://ez.datacite.org", "username", "password")
o = urllib2.build_opener(h)
o.open("https://ez.datacite.org/...")

The downside of using higher-level authentication mechanisms is that they often do not supply credentials initially, but only in response to a challenge from the service, thus doubling the number of HTTP transactions.

To manually provide credentials in Java, using Apache Commons Codec to do the Base64 encoding:

import java.net.*;
import org.apache.commons.codec.binary.*;

URL u = new URL("https://ez.datacite.org.org/...);
URLConnection c = u.openConnection();
c.setRequestProperty("Accept", "text/plain");
c.setRequestProperty("Authorization", "Basic " +
  new String(Base64.encodeBase64("username:password".getBytes())));
c.connect();

Java also provides an Authenticator class:

import java.net.*;

class MyAuthenticator extends Authenticator {
  protected PasswordAuthentication getPasswordAuthentication () {
    return new PasswordAuthentication("username", "password".toCharArray());
  }
}

Authenticator.setDefault(new MyAuthenticator());

If authentication is required and credentials are either missing or invalid, the service returns a 401 HTTP status code and the status line "error: unauthorized" (see Error handling below). If authentication is successful but the request is still not authorized, the service returns a 403 HTTP status code and the status line "error: forbidden".

Request & response bodies

Request and response bodies are used to transmit identifier metadata. The HTTP content type for all bodies is "text/plain" using UTF-8 charset encoding. In request bodies, if no charset encoding is declared in the HTTP Content-Type header, it is assumed to be UTF-8.

The service's data model for metadata is a dictionary of element name/value pairs. The dictionary is single-valued: an element name may not be repeated. Names and values are strings. Leading and trailing whitespace in names and values is not significant. Neither element names nor element values may be empty. (When modifying an identifier, an uploaded empty value is treated as a command to delete the element entirely.)

Metadata dictionaries are serialized using a subset of A Name-Value Language (ANVL) rules:

  • One element name/value pair per line.
  • Names separated from values by colons.

For example:

who: Proust, Marcel
what: Remembrance of Things Past
when: 1922

In addition, two ANVL features may be used when uploading metadata to the service (but clients can safely assume that DataCite will never use these features when returning metadata):

  • A line beginning with a number sign ("#", U+0023) is a comment and will be ignored.
  • A line beginning with whitespace continues the previous line (the intervening line terminator and whitespace are converted to a single space).

For example:

# The following two elements are identical:
who: Proust,
  Marcel
who: Proust, Marcel

Care must be taken to escape structural characters that appear in element names and values, specifically, line terminators (both newlines ("\n", U+000A) and carriage returns ("\r", U+000D)) and, in element names, colons (":", U+003A). EZID employs percent-encoding as the escaping mechanism, and thus percent signs ("%", U+0025) must be escaped as well. In Python, a dictionary of Unicode metadata element names and values, metadata, is serialized into a UTF-8 encoded string, anvl, with the following code:

import re

def escape (s):
  return re.sub("[%:\r\n]", lambda c: "%%%02X" % ord(c.group(0)), s)

anvl = "\n".join("%s: %s" % (escape(name), escape(value)) for name,
  value in metadata.items()).encode("UTF-8")

Conversely, to parse a UTF-8 encoded string, anvl, producing a dictionary, metadata:

import re

def unescape (s):
  return re.sub("%([0-9A-Fa-f][0-9A-Fa-f])",
    lambda m: chr(int(m.group(1), 16)), s)

metadata = dict(tuple(unescape(v).strip() for v in l.split(":", 1)) \
  for l in anvl.decode("UTF-8").splitlines())

In Java, to serialize a HashMap of metadata element names and values, metadata, into an ANVL-formatted Unicode string, anvl:

import java.util.*;

String escape (String s) {
  return s.replace("%", "%25").replace("\n", "%0A").
    replace("\r", "%0D").replace(":", "%3A");
}

Iterator<Map.Entry<String, String>> i = metadata.entrySet().iterator();
StringBuffer b = new StringBuffer();
while (i.hasNext()) {
  Map.Entry<String, String> e = i.next();
  b.append(escape(e.getKey()) + ": " + escape(e.getValue()) + "\n");
}
String anvl = b.toString();

And conversely, to parse a Unicode ANVL-formatted string, anvl, producing a HashMap, metadata:

import java.util.*;

String unescape (String s) {
  StringBuffer b = new StringBuffer();
  int i;
  while ((i = s.indexOf("%")) >= 0) {
    b.append(s.substring(0, i));
    b.append((char) Integer.parseInt(s.substring(i+1, i+3), 16));
    s = s.substring(i+3);
  }
  b.append(s);
  return b.toString();
}

HashMap<String, String> metadata = new HashMap<String, String>();
for (String l : anvl.split("[\\r\\n]+")) {
  String[] kv = l.split(":", 2);
  metadata.put(unescape(kv[0]).trim(), unescape(kv[1]).trim());
}

The first line of an EZID response body is a status indicator consisting of "success" or "error", followed by a colon, followed by additional information. Two examples:

success: ark:/99999/fk4test
error: bad request - no such identifier

Error handling

An error is indicated by both an HTTP status code and an error status line of the form "error: reason". For example:

⇒ GET /id/doi:/10.5072/bogus HTTP/1.1
⇒ Host: ez.datacite.org

⇐ HTTP/1.1 400 BAD REQUEST
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 39
⇐
⇐ error: bad request - no such identifier

Some programming libraries make it a little difficult to read the content following an error status code. For example, from Java, it is necessary to explicitly switch between the input and error streams based on the status code:

java.net.HttpURLConnection c;
java.io.InputStream s;
...
if (c.getResponseCode() < 400) {
  s = c.getInputStream();
} else {
  s = c.getErrorStream();
}
// read from s...

Ownership model

The service maintains ownership information about identifiers and uses that information to enforce access control.

The ownership model employed by DataCite is based on clients: each identifier is owned by one client. Permission to create identifiers is governed by the prefixes that have been assigned to a client by it's DOI Service Provider. But once created, permission to subsequently modify an identifier is governed solely by the identifier's ownership.

Clients in turn are managed by DOI service providers, including the assignment of prefixes and users to clients.

Identifier status

Each identifier in the service has a status. The status is recorded as the value of the "_status" reserved metadata element (see Internal metadata below) and may be one of:

  • public. The default value.
  • reserved. The identifier is known only to DataCite. This status may be used to reserve an identifier name within DataCite without advertising the identifier's existence to resolvers and other external services. A reserved identifier may be deleted.
  • unavailable. The identifier is public, but the object referenced by the identifier is not available. A reason for the object's unavailability may optionally follow the status separated by a pipe character ("|", U+007C), e.g., "unavailable | withdrawn by author". The identifier redirects to a "tombstone" page (an HTML page that displays the identifier's citation metadata and the reason for the object's unavailability) regardless of its target URL.

An identifier's status may be changed by setting a new value for the aforementioned "_status" metadata element. DataCite permits only certain status transitions:

  • A status of "reserved" may be specified only at identifier creation time.
  • A reserved identifier may be made public. At this time the identifier will be registered with resolvers and other external services.
  • A public identifier may be marked as unavailable. At this time the identifier will be removed from any external services.
  • An unavailable identifier may be returned to public status. At this time the identifier will be re-registered with resolvers and other external services.
 
Suggest Edits

Get Metadata for DOI

This request returns metadata for a given DOI.

 

Metadata can be retrieved for any existing identifier; no authentication is required. Simply issue a GET request to the identifier's URL.

⇒ GET /id/doi:10.5072/test9999 HTTP/1.1
⇒ Host: ez.datacite.org

⇐ HTTP/1.1 200 OK
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 208
⇐
⇐ success: doi:10.5072/test9999
⇐ _created: 1300812337
⇐ _updated: 1300913550
⇐ _target: http://www.gutenberg.org/ebooks/7178
⇐ _profile: datacite

The first line of the response body is a status line. Assuming success, the remainder of the status line echoes the canonical form of the requested identifier.

The remaining lines are metadata element name/value pairs serialized per ANVL rules; see Request & response bodies above. The order of elements is undefined. Element names beginning with an underscore ("_", U+005F) are reserved for use by the system; their meanings are described in Internal metadata below. Some elements may be drawn from citation metadata standards; see Metadata profiles.

 
Suggest Edits

Create DOI

Will register a new DOI if the specified DOI doesn’t exist. Will not update an existing DOI, but will return an error.

 

An identifier can be "created" by sending a PUT request to the identifier's URL. Here, identifier creation means establishing a record of the identifier (to be successful, no such record can already exist). Authentication is required, and the user must have permission to create DOIs using the DOI prefix. Users can view the prefixes available to them by visiting the DOI Fabrica service and navigating to the Prefixes tab.

A request body is optional; if present, it defines the identifier's starting metadata. There are no restrictions on what metadata elements can be submitted, but a convention has been established for naming metadata elements, and the service has built-in support for certain sets of metadata elements; see Metadata profiles. A few of the internal service metadata elements may be set; see Internal metadata.

⇒ PUT /id/doi:10.5072/test9999 HTTP/1.1
⇒ Host: ez.datacite.org
⇒ Content-Type: text/plain; charset=UTF-8
⇒ Content-Length: 30
⇒
⇒ _target: https://ez.datacite.org/
⇒ _status: reserved

⇐ HTTP/1.1 201 CREATED
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 27
⇐
⇐ success: doi:/10.5072/test9999

The return is a status line. If a DOI was created successfully, the normalized form of the identifier is returned as shown above.

 
Suggest Edits

Mint DOI

Will register a new DOI, but instead of supplying a complete identifier, the client specifies only a partial namespace (shoulder).

 

Minting an identifier is the same as creating an identifier, but instead of supplying a complete identifier, the client specifies only a namespace (or "shoulder") that forms the first part of the identifier's suffix, and the service generates an opaque, random string for the full identifier suffix. An identifier can be minted by sending a POST request to the URL https://ez.datacite.org/shoulder/myshoulder where myshoulder is the desired namespace.

⇒ POST /shoulder/doi:10.5072 HTTP/1.1
⇒ Host: ez.datacite.org
⇒ Content-Type: text/plain; charset=UTF-8
⇒ Content-Length: 30
⇒
⇒ _target: https://ez.datacite.org/
⇒ _status: reserved

⇐ HTTP/1.1 201 CREATED
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 29
⇐
⇐ success: doi:10.5072/testc9cz3dh0

Aside from specifying a complete identifier versus specifying a shoulder only, the create and mint operations operate identically. Authentication is required to mint an identifier; namespace permission is required, and prefixes can be viewed in the DOI Fabrica service under the Prefixes tab. The request and response bodies are identical.

The service automatically embeds the newly-minted identifier in certain types of uploaded metadata. See Metadata profiles for when this is performed.

 
Suggest Edits

Modify DOI

 

An identifier's metadata can be modified by sending a POST request to the identifier's URL. Authentication is required; only the identifier's owner and certain other users may modify the identifier (see Ownership model below).

Metadata elements are operated on individually. If the identifier already has a value for a metadata element included in the request body, the value is overwritten, otherwise, the element and its value are added. Only a few of the reserved metadata elements may be modified; see Internal metadata.

⇒ POST /id/doi:10.5072/test9999 HTTP/1.1
⇒ Host: ez.datacite.org
⇒ Content-Type: text/plain; charset=UTF-8
⇒ Content-Length: 30
⇒
⇒ _target: https://ez.datacite.org/

⇐ HTTP/1.1 200 OK
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 29
⇐
⇐ success: doi:10.5072/test9999

The return is a status line. Assuming success (see Error handling), the remainder of the status line echoes the canonical form of the identifier in question.

To delete a metadata element, set its value to an empty string.

 
Suggest Edits

Delete DOI

 

A reserved DOI can be deleted by sending a DELETE request to the identifier's URL. We emphasize that only reserved identifiers may be deleted; see Identifier status. Authentication is required; only the identifier's owner and certain other users may delete the identifier (see Ownership model).

⇒ DELETE /id/doi:10.5072/test9999 HTTP/1.1
⇒ Host: ez.datacite.org

⇐ HTTP/1.1 200 OK
⇐ Content-Type: text/plain; charset=UTF-8
⇐ Content-Length: 29
⇐
⇐ success: doi:/10.5072/test9999

The return is a status line. Assuming success (see Error handling), the remainder of the status line echoes the canonical form of the identifier just deleted.