Getting Started Guide
Welcome! Whether you’re new to Data Commons or are just looking for a refresher, this guide gives an overview of what you need to know to get started using our REST API.
Use the links below to jump to any section:
What is a REST API?
Our REST API follows the RESTful architectural style to allow you to query the Data Commons Knowledge Graph via HTTP. This allows you to explore the local graph and query data from specific variables and entities programatically.
How to Use the REST API
Our REST API can be used with any tool or language that supports HTTP. You can make queries on the command line (e.g. using cURL), by scripting HTTP requests in another language like javascript, or even by entering an endpoint into your web browser!
Following HTTP, a REST API call consists of a request that you provide, and a response from our servers with the data you requested in JSON format. The next section details how to assemble a request.
Assembling a Request
Endpoints
Requests are made through API endpoints. We provide endpoints for many different queries (see the list of available endpoints here).
Each endpoint can be acessed using its unique URL, which is a combination of a base URL and the endpoint’s URI.
The base URL for all REST endpoints is:
https://api.datacommons.org
And a URI looks like /v1/observation/point
. To access a particular endpoint, append the URI to the base URL (e.g. https://api.datacommons.org/v1/observation/point
).
Parameters
Endpoints take a set of parameters which allow you to specify which entities, variables, timescales, etc. you are interested in. There are two kinds of parameters: path parameters and query parameters.
Path Parameters
Path parameters must be passed in a specific order as part of the URL. For example, /v1/observations/point
requires the DCIDs of the entity and variable to query, in that order. This would look something like:
https://api.datacommons.org/v1/observations/point/entity_DCID/variable_DCID
Query Parameters
Query parameters are chained at the end of a URL behind a ?
symbol. Separate multiple parameter entries with an &
symbol. For example, this would look like:
https://api.datacommons.org/v1/observations/point/variable_DCID/entity_DCID?date=YYYY&facet=XXXXXXXXXXX
Still confused? Each endpoint’s documentation page has examples at the bottom tailored to the endpoint you’re trying to use.
Finding Available Entities, Variables, and their DCIDs
Most requests require the DCID of the entity or variable you wish to query. Curious what entities and variables are available? Want to find a DCID? Take a look at our explorer tools:
- Search Search Data Commons
- Knowledge Graph Click through the knowledge graph
- Place Browser Summaries of data available for entities that are geographic locations
- Statistical Variable Explorer See metadata for variables
Finding Datetimes for Observations
Many endpoints allow the user to filter their results to specific dates. When querying for data at a specific date, the string passed for the date queried must match the date format (in ISO-8601) used by the target variable. An easy way to see what date format a variable uses is to look up your variable of interest in the Statistical Variable Explorer.
Bulk Retrieval
Many of our APIs come in both “simple” and “bulk” versions. The simple versions of endpoints have prefix /v1/
and are designed for handling single requests with a simplified return structure. The bulk versions of endpoints have prefix /v1/bulk/
and are meant for querying multiple variables or entities at once, and provide richer details in the response.
POST requests
Some bulk endpoints allow for POST
requests. For POST
requests, feed all parameters in JSON format. For example, in cURL, this would look like:
curl -X POST \
--url https://api.datacommons.org/v1/bulk/observations/point \
--data '{
"entities": [
"entity_dcid_1",
"entity_dcid_2",
...
],
"variables: [
"variable_dcid_1",
"variable_dcid_2",
...
]
}'
Authentication
API keys are now required. To use the REST API, a valid API key must be included in all requests.
Using API Keys
API keys are required in any REST API request. To include an API key, add your API key to the URL as a query parameter by appending ?key=<YOUR_API_KEY_HERE>
.
For GET requests, this looks like:
https://api.datacommons.org/v1/end/point?key=<YOUR_KEY_HERE>
If the key is not the first query parameter, use &key=<YOUR_API_KEY_HERE>
instead. This looks like:
https://api.datacommons.org/v1/end/point?query=value&key=<YOUR_KEY_HERE>
For POST requests, pass the key as a header. For example, in cURL, this looks like:
curl -X POST \
--url https://api.datacommons.org/v1/bulk/end/point \
--header 'X-API-Key: <YOUR_KEY_HERE>' \
--data '{
"entities": [
"entity_dcid_1",
"entity_dcid_2",
...
],
"variables: [
"variable_dcid_1",
"variable_dcid_2",
...
]
}'
Getting API Keys
We’ve provided a trial API key for general public use. This key will let you try the API and make single requests.
AIzaSyCTI4Xz-UW_G2Q2RfknhcfdAnTHq5X5XuI
The trial key is capped with a limited quota for requests. If you are planning on using our APIs more rigorously (e.g. for personal or school projects, developing applications, etc.) please go to the portal at https://apikeys.datacommons.org and request a key for api.datacommons.org
.
Pagination
When the response to a request is too long, the returned payload is
paginated. Only a subset of the response is returned, along with a long string
of characters called a token. To get the next set of entries, repeat the
request with nextToken
as an query parameter, with the token as its value.
For example, the request:
$ curl --request GET \
`https://api.datacommons.org/v1/triples/in/geoId/06`
will return something like:
{
"triples": {
< ... output truncated for brevity ...>
{
"name":"Business Fire 2014 (472130)",
"types":["WildlandFireEvent"],
"dcid":"fire/imsrBusinessFire2014472130",
"provenanceId":"dc/y6lf8n"
}
},
"nextToken":"SoME_veRy_L0ng_S+rIng"
}
To get the next set of entries, use the command:
$ curl --request GET \
`https://api.datacommons.org/v1/triples/in/geoId/06?nextToken=SoME_veRy_L0ng_S+rIng`
Similarly for POST requests, this would look like:
$ curl --request POST \
--url https://api.datacommons.org/v1/bulk/triples/in \
--data '{
"entities": "geoId/06",
"nextToken": "SoME_veRy_L0ng_S+rIng"
}'
Troubleshooting
Common Error Responses
“Method does not exist”
{
"code": 5,
"message": "Method does not exist.",
"details": [
{
"@type": "type.googleapis.com/google.rpc.DebugInfo",
"stackEntries": [],
"detail": "service_control"
}
]
}
This is most commonly seen when the endpoint is misspelled or otherwise malformed. Check the spelling of your endpoint and that all required path parameters are provided in the right order.
“Invalid request URI”
{
"code": 3,
"message": "Invalid request URI",
"details": [
{
"@type": "type.googleapis.com/google.rpc.DebugInfo",
"stackEntries": [],
"detail": "internal"
}
]
}
This is most commonly seen when your request is missing a required path parameter. Make sure endpoints and parameters are both spelled correctly and provided in the right order.
Empty Response
{}
Sometimes your query might return an empty result. This is most commonly seen when the value provided for a parameter is misspelled or doesn’t exist. Make sure the values you are passing for parameters are spelled correctly.
“Could not find field <field> in the type”
{
"code": 3,
"message": "Could not find field \"variables\" in the type \"datacommons.v1.BulkVariableInfoRequest\".",
"details": [
{
"@type": "type.googleapis.com/google.rpc.DebugInfo",
"stackEntries": [],
"detail": "internal"
}
]
}
This is most commonly seen when a query parameter is misspelled or incorrect. Check the spelling of query parameters.