DataCite Support

DataCite Support

Welcome to DataCite's support site. Here you will find helpful information about our services. We have included comprehensive technical guides, training materials, and tips to help you successfully use DataCite services.

Get Started    API Reference

Creating DOIs with the REST API

DOIs can be created using the https://api.datacite.org/dois endpoint. Only Repositories have the ability to create DOIs. This section of the guide will show you how to create first a Draft DOI and then a Findable DOI. (Learn more about DOI States.)

Create a Draft DOI

To create a Draft DOI, you will need to create a JSON file containing the minimum information necessary for creating a DOI, which is the DOI string. It should look like the following, but using a DOI prefix associated with your Repository account:

{
  "data": {
    "type": "dois",
    "attributes": {
      "doi": "10.5438/0012"
    }
  }
}
Next, submit that information using the following call, replacing `YOUR_REPOSITORY_ID:YOUR_PASSWORD` with your DataCite repository credentials and replacing `my_draft_doi.json` with the name of the file you created earlier.
$ curl -X POST -H "Content-Type: application/vnd.api+json" --user YOUR_REPOSITORY_ID:YOUR_PASSWORD -d @my_draft_doi.json https://api.test.datacite.org/dois

📘

Auto-generated DOI's

If you want to auto-generate the DOI name you can make the above call removing the "doi" attribute in the json payload and adding just the "prefix" attribute. This generates a random DOI suffix.

{
  "data": {
    "type": "dois",
    "attributes": {
      "prefix": "10.5438"
    }
  }
}

Your response will look something like the following, but containing your Repository information:

{
  "data": {
    "id": "10.5438/0012",
    "type": "dois",
    "attributes": {
      "doi": "10.5438/0012",
      "prefix": "10.5438",
      "suffix": "0012",
      "identifiers": [{
        "identifier": "https://doi.org/10.5438/0012",
        "identifierType": "DOI"
      }],
      "creators": [],
      "titles": [],
      "publisher": null,
      "container": {},
      "publicationYear": null,
      "subjects": [],
      "contributors": [],
      "dates": [],
      "language": null,
      "types": {},
      "relatedIdentifiers": [],
      "sizes": [],
      "formats": [],
      "version": null,
      "rightsList": [],
      "descriptions": [],
      "geoLocations": [],
      "fundingReferences": [],
      "xml": null,
      "url":null,
      "contentUrl": null,
      "metadataVersion": 1,
      "schemaVersion": "http://datacite.org/schema/kernel-4",
      "source": null,
      "isActive": true,
      "state": "draft",
      "reason": null,
      "created": "2016-09-19T21:53:56.000Z",
      "registered": null,
      "updated": "2019-02-06T14:31:27.000Z"
    },
    "relationships": {
      "client": {
        "data": {
          "id": "datacite.datacite",
          "type": "clients"
        }
      },
      "media": {
        "data": []
      }
    }
  },
  "included": [{
    "id": "datacite.datacite",
    "type": "clients",
    "attributes": {
      "name": "DataCite",
      "symbol": "DATACITE.DATACITE",
      "year": 2011,
      "contactName": "DataCite",
      "contactEmail": "[email protected]",
      "description": null,
      "domains": "*",
      "url": null,
      "created": "2011-12-07T13:43:39.000Z",
      "updated": "2019-01-02T17:33:06.000Z",
      "isActive": true,
      "hasPassword": true
    },
    "relationships": {
      "provider": {
        "data": {
          "id": "datacite",
          "type": "providers"
        }
      },
      "prefixes": {
        "data": [{
          "id": "10.5438",
          "type": "prefixes"
        }]
      }
    }
  }]
}
The command will fail with an error message if the prefix you used is not associated with your Repository ID.

You have now created a Draft DOI. It has a DOI string assigned, but is not visible for users, so it will not be functional.  

# Create a Findable DOI
To create a DOI in Findable state with a URL and metadata you need to include all of the required DOI metadata fields (DOI, creators, title, publisher, publicationYear, resourceTypeGeneral).


[block:callout]
{
  "type": "info",
  "title": "What metadata should I include?",
  "body": "The [DataCite Metadata Schema documentation](https://schema.datacite.org) contains information on required metadata, optional metadata, and those metadata elements that are recommended for enhancing data discovery. You will also find descriptions of controlled vocabulary for those fields that require it."
}
[/block]
{
  "data": {
    "id": "10.5438/0012",
    "type": "dois",
    "attributes": {
      "event": "publish",
      "doi": "10.5438/0012",
      "creators": [{
        "name": "DataCite Metadata Working Group"
      }],
      "titles": [{
        "title": "DataCite Metadata Schema Documentation for the Publication and Citation of Research Data v4.0"
      }],
      "publisher": "DataCite e.V.",
      "publicationYear": 2016,
      "types": {
        "resourceTypeGeneral": "Text"
      },
      "url": "https://schema.datacite.org/meta/kernel-4.0/index.html",
      "schemaVersion": "http://datacite.org/schema/kernel-4"
    }
  }
}

You can also include optional metadata. To autogenerate the DOI, remember to remove the "id" field and and replace the "doi" field with "prefix".

📘

A word on states - publishing to findable

In the previous examples you can see an "event" attribute added to our json payload, this corresponds to the action you want to trigger for the DOI.

In the case of reaching a findable state, we parse "publish" this pushes it through to the findable DOI state.

Possible actions:

  • publish - Triggers a state move from draft or registered to findable
  • register - Triggers a state move from draft to registered
  • hide - Triggers a state move from findable to registered

Provide metadata in formats other than JSON

As an alternative to providing metadata attributes directly in JSON, you can also provide metadata in other formats.

The following metadata formats can be used to register DOIs:

  • DataCite XML
  • Schema.org JSON-LD
  • Crossref Unixref
  • Citeproc JSON
  • RIS
  • BibTeX

You do this by 1.) base64-encoding the metadata and 2.) including them in the xml attribute.

For example:

{
  "data": {
    "id": "10.5438/0012",
    "type": "dois",
    "attributes": {
      "event": "publish",
      "doi": "10.5438/0012",
      "url": "https://schema.datacite.org/meta/kernel-4.0/index.html",
      "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>
"
  }
}
}

You will then need to make a call on this file, like this:

curl -X POST -H "Content-Type: application/vnd.api+json" --user YOUR_CLIENT_ID:YOUR_PASSWORD -d @my_metadata.json https://api.test.datacite.org/dois 

Keep learning with the API Reference!

Updated 20 days ago

Creating DOIs with the REST API


Suggested Edits are limited on API Reference Pages

You can only suggest edits to Markdown body content, but not to the API spec.