Reporting
API User Guide
 
          Matt Cooper
Created: Jan 1, 2023 - Updated: Aug 20, 2023
Sust Global's Climate Explorer API is a RESTful API interface to Sust Global's climate intelligence capabilities. The API currently enables users to access generated physical risk exposure datasets programmatically. This guide helps users learn how to work with the API directly.
Quickstart
To quickly get up and going with the Climate Explorer API, you first must retrieve your API key. Navigate to your Climate Explorer User Profile and copy the value of API Key. This value will be referenced below as $APIKEY.
Open a local terminal, then run the following curl command:
curl "https://explorer.sustglobal.io/api/portfolios" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
A successful response from the portfolios endpoint will contain a set of all portfolios you currently may access. For example, a single portfolio named “MRTG_demo”:
{
"portfolio_id": "632b0c0aae178b6e",
"portfolio_name": "MRTG_demo_portfolio",
"created_at": "2022-06-08T09:24:50Z",
"updated_at": "2022-10-03T15:02:02Z",
"status": "Risk data available"
}
This response status (“Risk data available”) tells us that the MRTG_demo_portfolio portfolio already contains physical risk exposure data. Before we fetch any risk-related data, we will first retrieve the assets from the portfolio:
curl "https://explorer.sustglobal.io/api/portfolios/MRTG_demo_portfolio/assets" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
The output below is a single object from the list of assets you will observe:
{
"portfolio_name": "MRTG_demo_portfolio",
"portfolio_index": 1,
"entity_id": "",
"entity_name": "282",
"labels": {
  "type": "Land",
  "price": "$3,950,000.00",
  "address": "Lower Buckeye Road, Buckeye, AZ, 85326"
},
"lat": 33.4210302,
"lng": -112.6298175
}
Now, we can fetch a summary of the risk exposure data pertaining to this portfolio with the following command:
curl "https://explorer.sustglobal.io/api/portfolios/MRTG_demo_portfolio/datasets/physical/summary" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
A single object from the response is displayed below:
{
"portfolio_name": "MRTG_demo_portfolio",
"portfolio_index": 0,
"entity_name": "26",
"entity_id": "",
"window": 5,
"window_start_year": 2022,
"scenario": "ssp126",
"risk_summaries": [
  {
    "hazard": "cyclone",
    "risk_class": "LOW",
    "risk_score": 0.0344486861607962
  },
  {
    "hazard": "flood_potential",
    "risk_class": "LOW",
    "risk_score": 0
  },
  {
    "hazard": "heatwave",
    "risk_class": "LOW",
    "risk_score": 0.055
  },
  {
    "hazard": "sea_level_rise",
    "risk_class": "LOW",
    "risk_score": 0
  },
  {
    "hazard": "water_stress",
    "risk_class": "LOW",
    "risk_score": 0.0756378421175013
  },
  {
    "hazard": "wildfire",
    "risk_class": "LOW",
    "risk_score": 0.0080123366443584
  }
 ]
}
Extended Summary
We can also use the extended parameter to query for more information, including geometry and more detailed scenario-based analytics. For more information, see Visual Summary
curl "https://explorer.sustglobal.io/api/portfolios/MRTG_demo_portfolio/datasets/physical/summary?extended=true" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
Below is a truncated response:
{
  "portfolio_name": "MRTG_demo_portfolio",
  "portfolio_index": 360,
  "entity_id": "",
  "entity_name": "300",
  "geometry": { ... },
  "labels": { ... },
  "scenario_analytics": {
    "ssp245": {
      "heatwave": {
        "business_interruption_2030": 0.00142,
        "business_interruption_2030_lbd": 0.00075,
        "business_interruption_2030_ubd": 0.0024,
        "business_interruption_2050": 0.00078,
        "business_interruption_2050_lbd": 0.00069,
        "business_interruption_2050_ubd": 0.00084,
        "business_interruption_2080": 0.00193,
        "business_interruption_2080_lbd": 0.00167,
        "business_interruption_2080_ubd": 0.00241,
        "business_interruption_baseline": 0.00065,
        "business_interruption_baseline_lbd": 0.00012,
        "business_interruption_baseline_ubd": 0.00142,
        "indicator_2030": 0.04359,
        "indicator_2030_lbd": 0.02017,
        "indicator_2030_ubd": 0.08269,
        "indicator_2050": 0.06824,
        "indicator_2050_lbd": 0.03661,
        "indicator_2050_ubd": 0.10262,
        "indicator_2080": 0.09664,
        "indicator_2080_lbd": 0.06575,
        "indicator_2080_ubd": 0.13624,
        "indicator_baseline": 0.02964,
        "indicator_baseline_lbd": 0.01121,
        "indicator_baseline_ubd": 0.05405,
        "structural_damage_2030": 0,
        "structural_damage_2030_lbd": 0,
        "structural_damage_2030_ubd": 0,
        "structural_damage_2050": 0,
        "structural_damage_2050_lbd": 0,
        "structural_damage_2050_ubd": 0,
        "structural_damage_2080": 0,
        "structural_damage_2080_lbd": 0,
        "structural_damage_2080_ubd": 0,
        "structural_damage_baseline": 0,
        "structural_damage_baseline_lbd": 0,
        "structural_damage_baseline_ubd": 0,
        "summary_label_15yr": "LOW",
        "summary_label_30yr": "LOW",
        "summary_score_15yr": 0.06027,
        "summary_score_30yr": 0.07945
      },
      "flood": { ... },
      "cyclone": { ... },
      "sea_level_rise": { ... },
      "water_stress": { ... },
      "wildfire": { ... }
    },
    "ssp585": { ... }
  }
}
Filtering by Variable
To fetch the more granular timeseries data, we can use the “items” endpoint. We can also apply some filters this time around: hazard=wildfire, scenario=ssp585, and start_date=2022
curl "https://explorer.sustglobal.io/api/portfolios/MRTG_demo_portfolio/datasets/physical/items?hazard=wildfire&scenario=ssp585&start_date=2022" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
Below is a truncated object from the response:
{
"portfolio_name": "MRTG_demo_portfolio",
"portfolio_index": 5,
"entity_id": "",
"entity_name": "171",
"hazard": "wildfire",
"indicator": "wildfire_unified_prob",
"scenario": "ssp585",
"measure": "mid",
"risk_exposure": {
  "2022": 0.0024577002041041,
  "2023": 0.0397371985018253,
  "2024": 0.0130443815141916,
  "2025": 0.0121267260983586,
  "2026": 0.0074249189347028,
  "2027": 0.0198366455733776,
  "2028": 0.0168143846094608,
  "2029": 0.0275528505444526,
  "2030": 0.0196106024086475,
   ...
Read through the remainder of this document from here to learn about other aspects of the API.
API Mechanics
Authentication
All API requests must be authenticated using an API key. Find your own API key at in your Climate Explorer User Profile.
To authenticate an API request, simply pass your API key as an HTTP header named X-SustGlobal-APIKey. For example, if your API key were FOOBAR then you would authenticate your request like so:
curl "https://explorer.sustglobal.io/api/portfolios/" --header "X-SustGlobal-APIKey: FOOBAR"
Projects
Note that a project must typically be indicated via a project HTTP header. You can programmatically identify which projects you may access via the /api/projects/ endpoint:
curl "https://explorer.sustglobal.io/api/projects/" --header "X-SustGlobal-APIKey: $APIKEY"
[
  {
    "project_id": "a19b6282de313211",
    "project_name": "ec-DEMO"
  }
]
You may use either the project_id or project_name value in the HTTP headers. For example, using the project name:
curl "https://explorer.sustglobal.io/api/portfolios/" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: ec-DEMO"
…or the project ID:
curl "https://explorer.sustglobal.io/api/portfolios/" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: a19b6282de313211"
Pagination
Many API endpoints support paginated requests. This allows a consumer of the API to make a series of API requests, each time reading a subset of the total result set.
Users control pagination with the page and rows query parameters. The value of rows sets the maximum number of results that the API should return for a given page.
The default rows value is 50, meaning that a client is forced to paginate their requests if more than 50 items exist in a given list. The max value of rows is 250, and datasets over this limit will require multiple API calls to load. This can be accelerated by using filters such as hazard=wildfire, as described above. An example of fetching with pagination in Python can be found here.
An example of pagination over a set of 120 items might work like so:
- Request one sets page=1 and rows=50, receiving 50 items
- Request two sets page=2 and rows=50, receiving 50 items
- Request two sets page=3 and rows=50, receiving 20 items
Note that once a set of items smaller in number than the value of rows is received from a paginated request, the client should halt any further requests.
Error Responses
When an API request fails, clients should always consider the HTTP status code. Status codes are used as accurately as possible. For example, when an invalid request is made, a 400 Bad Request code will be returned.
In addition to the status code, clients should also attempt to parse a JSON-encoded error response available in the HTTP response body. The JSON object contains one of more human-readable errors, represented as an array of strings. For example:
{
    "errors": [
        "lat: coordinate out of bounds"
    ]
}
It is inadvisable to attempt to parse meaningful data from error strings, as they will evolve over time as Sust Global capabilities expand. In other words, there is no contract established in the content of error strings.
API Examples
This section contains a set of example commands you can run on your machine to interact with the API.
Note that many of the examples refer to environment variables that must be set manually:
- Your API key, must be set in the $APIKEY environment variable. See Authentication to learn more about this.
- The $PORTFOLIO environment variable refers to the name of the portfolio you wish to work with. You determine this value.
Create a Portfolio
To create a new portfolio, simply run the following cURL command:
curl -i -X POST "https://explorer.sustglobal.io/api/portfolios/" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT" --data-raw "{\"portfolio_name\": \"$PORTFOLIO\"}"
Upload Assets to a Portfolio
Once you have created a portfolio, you may upload a CSV file containing your assets using the following command. The value of $ASSET_FILE must be the location of a local CSV file containing assets. Please see the Climate Explorer Guide for more information about assets and CSV file requirements.
curl -i -F asset=@$ASSET_FILE "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/assets/import/" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
Export Portfolio Assets
It may be useful to download all assets in a given portfolio to a local CSV file. This is primarily useful when you intend to re-upload a modified set of assets to a portfolio.
curl -OJ "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/assets/export" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
A CSV file will be written to the filesystem.
Fetch Physical Risk Exposure Timeseries Data
After physical risk exposure data has been generated, one may interact with it natively via the API:
curl -i "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/datasets/physical/items" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
Note that this endpoint will contain a lot of data, so you should be familiar with pagination controls. Documentation is available earlier in this guide.
Additional query parameters that may be useful include scenario, hazard, indicator and measure. An example of filtering the risk exposure dataset to SSP2-4.5 for a specific wildfire-related indicator:
curl -i "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/datasets/physical/items?scenario=ssp245&hazard=wildfire&indicator=unfied_prob&measure=mid" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
Please review the API Reference for documentation of all supported query parameters.
Summarize Physical Risk Exposure
A summary of physical risk exposure data with an optional scenario filter is available via API:
curl -i "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/datasets/physical/summary" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
Export Physical Risk Exposure
Download a ZIP archive containing the physical risk exposure data for a specific portfolio using the following command:
curl -OJ "https://explorer.sustglobal.io/api/portfolios/$PORTFOLIO/datasets/physical/export" --header "X-SustGlobal-APIKey: $APIKEY" --header "X-SustGlobal-Project: $PROJECT"
A ZIP file will be written to the filesystem.
API Endpoint Reference
You may access the Climate Explorer API Reference, which describes every REST endpoint, parameter, request and response.
OpenAPI / Swagger
The Climate Explorer API is documented using OpenAPI (Swagger). You may access the document at the following URI:
https://explorer.sustglobal.io/swagger.json
This URL is publicly-accessible and is automatically updated as the API evolves.
Citing Sust Global API
From a concept to adoption by an emerging group of early adopters, many people have invested time and energy in developing and enabling access to Sust Global’s capabilities. Please cite Sust Global when using our data and insights. To cite Sust Global’s data in publications, please use the following:
Sust Inc (2021). Sust Global Application Programming Interface: Transforming frontier climate science to actionable data. https://developers.sustglobal.com.
@Misc{,
  author       = {Sust Global Team},
  organization = {Sust Inc},
  title        = {Sust Global Application Programming Interface: Transforming frontier climate science to actionable data},
  year         = {2021--},
  url          = "https://developers.sustglobal.com"
}
