Isometric Certify Data Ingestion API

The Certify API (MRV API) is the supplier-facing data ingestion surface for carbon removal projects. It covers sources and evidence uploads, datapoints, components and component blueprints, removals and removal templates, GHG statements, project storage units and locations, monitoring submissions, measurement locations and samples, sensors and time-series data uploads, feedstock types and batches, production batches, and biochar applications. Operates against /mrv/v0 on both sandbox and production environments using bearer + x-client-secret authentication. Includes 53 paths and 170 schemas.

Isometric Certify Data Ingestion API is one of 2 APIs that Isometric publishes on the APIs.io network, described by a machine-readable OpenAPI specification.

Tagged areas include Certify, MRV, Carbon Removal, Lifecycle Assessment, and GHG Statements. The published artifact set on APIs.io includes API documentation, authentication docs, an OpenAPI specification, and a changelog.

OpenAPI Specification

isometric-certify-api-openapi.json Raw ↑
{"openapi":"3.1.0","info":{"title":"Isometric Certify Data Ingestion API","description":"# Standards\n\n## Versioning\n\nThis API will be safely versioned using root path versioning, in the format `/v{major}`. For example, `/registry/v0/supplier`.\n\n### Compatibility\n\nWe won't make breaking changes to existing API services or endpoints for API versions higher than `v0`. If breaking changes are necessary, we'll release a new major version.\nWe may deprecate APIs that have been replaced by a newer version. When doing so, we will expect\nintegrated partners to manage a transition to new resources within the deprecation timeline of old ones.\n\nWe will make the following sort of changes we do not consider to be breaking:\n\n- Adding new endpoints\n- Adding optional query parameters to API endpoints\n- Adding new properties to existing API responses\n- Reordering properties in existing API responses\n\nIt is important that clients are built to be robust to these changes.\n\n## Pagination\n\nOur API is based on the [Relay](https://relay.dev/docs/tutorial/connections-pagination/) pagination spec. Paginated endpoints\nwill return a `PaginatedListResource` which contains:\n\n- `page_info` - Containing information regarding pagination cursors and the total number of entities.\n- `nodes` - Each node is a paginated entity.\n- `total_count` - The total size of the list across all pages.\n\n### Pagination Parameters\n\nPaginated endpoints also accepted a standard set of query parameters:\n\n- `last` - An integer number of items to retrieve **before** the item represented by the cursor passed in the `before` parameter. Defaults to 10 with a maximum value of 50.\n- `before` - An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page's `start_cursor` here when paginated backwards.\n- `first` - An integer number of items to retrieve **after** the item represented by the cursor passed in the `after` parameter. Defaults to 10 with a maximum value of 50.\n- `after` - An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page's `end_cursor` here when paginated forwards.\n\nFor example, querying `/registry/v0/beneficiaries` will return a `PaginatedListResource` of the first page of 10 items:\n\n```json\n{\n    \"page_info\": {\n        \"has_previous_page\": false,\n        \"start_cursor\": ...,\n        \"has_next_page\": true,\n        \"end_cursor\": \"mpG5kcuoFBYtlH\",\n    },\n    \"nodes\": [{\n        \"id\": \"org_12345iso678\",\n        \"name\": \"My Org\",\n        ...\n    }],\n    \"total_count\": 100\n}\n```\n\nThen querying `/registry/v0/beneficiaries?first=15&after=mpG5kcuoFBYtlH` will return a `PaginatedListResource` of the next 15 items.\n\n## Dates\n\nDatetime fields in the APIs conform to the [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) date and time format in UTC. For example: `2024-01-22T11:56:48.520641Z`.\n\n## Country Codes\n\nCountries are identified in the APIs via [ISO 3166-1 Alpha-3](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3) codes. For example: `GBR` and `USA`.\n# Authentication\n\nMost API requests will need to authenticate against the Isometric API in two ways simultaneously:\n\n- By passing a **client secret** in the `X-Client-Secret` header to identify the system integrating with the API.\n- By passing an **access token** in the `Authorization` header to authenticate as a specific organization, in order to gain access to its private data.\n\n### Client Authentication\n\nEvery API call to Isometric must include a **client secret** identifying the client application.\n\nThis client secret is tied to a particular environment - sandbox or production.\n\nThe client secret should be submitted on every API request via the `X-Client-Secret` header. For example `X-Client-Secret: uPrO...wxAh`.\n\n### Organization Authentication\n\nIn addition, a large number of API requests will require an **access token** in order for the caller to identify themselves and act as a specific Organization.\n\nTo authenticate as an Organization you will need to submit a JWT bearer access token via the `Authorization` header. For example: `Authorization: Bearer eyJh...sw5c`.\nIf you are going to be acting on behalf of other Organizations, they will need to generate the access token and pass it securely to you.\nAccess tokens should be treated as highly sensitive, kept secret and stored accordingly.\n\nAccess tokens are scoped to a single Organization - so if you are acting on behalf of multiple particular organizations, you will need to submit the appropriate access token on each request.\n\n### Managing Credentials\n\nCredentials can be managed through Certify UI in the [Team settings](https://registry.isometric.com/account/team-settings) section. Access tokens will expire after 1 year from generation. When you are approaching expiry, a new token will need to be generated.\n\nBoth client secrets and access tokens can be created and invalidated through UI.\nClient secrets do not expire and do not need to be rotated.\nIf either secret becomes compromised, it should be invalidated through the UI.\n# Key Certify Concepts\n\nThis page defines concepts used in Certify, and the [Certify API](/api-reference/certify/certify-introduction), which are helpful to understand when submitting information for verification via Certify. For a broader understanding of Isometric's verification processes on the Isometric Registry, please refer to the [Isometric Standard](https://isometric.com/standard).\n\n## Resource visibility\n\n- Until resources are submitted as part of a GHG statement, they are visible only to members of your organization.\n- After statement submission, they are visible to the verifier assigned to the GHG statement.\n- Once credits have been issued, removals are added to the [public registry](https://registry.isometric.com), and associated resources are visible publicly, with the exception of source documents.\n- Sources uploaded in the Certify platform are kept private by default once published on the Isometric registry (file names will be displayed). Contact Isometric to update public source visibility. Sources [added via the API](/api-reference/certify/post-source) can be set `public` on submission.\n\n## Resources\n\nThe main resources used in Certify are sources, datapoints, components and removals.\n\n### Sources\n\n- Sources represent a piece of evidence for a particular datapoint used in carbon accounting calculations.\n- Source documents are private, and only shared with the verifier assigned to a related removal.\n- Other information associated with a source, such as its display name, is visible publicly once the removal is on the public registry.\n- Verifiers are not notified when new sources are added to datapoints in a submitted removal, but they will immediately have access to the source documentation. Please notify the Isometric Registry Operations team when sources are added on a verifier's request so that we can ensure that the verifier is aware.\n\n### Datapoints\n\n- Datapoints represent any value used in carbon accounting calculations.\n- When creating datapoints, sources should be referenced to provide evidence for the value used.\n- A standard deviation should be provided if the datapoint is to be included in the variance propagation method of uncertainty analysis.\n- All datapoints are considered statistically independent for the purpose of variance propagation, although if a datapoint is used twice within a removal calculation, this dependence is captured.\n\n### Components\n\n- Components represent physical activities whose CO₂e flux needs to be accounted for.\n- Components are created from [component blueprints](/user-guides/certify/component-blueprint-library) that contain sets of equations used to calculate a transfer of CO₂e into or out of the atmosphere.\n- A blueprint defines a set of inputs that are the datapoints to be used in the calculation. For instance, a transport emissions blueprints would ask for datapoints representing a distance, mass and carbon intensity.\n- When creating a component from a blueprint, the blueprint must be specified, as well as a list of datapoints for the expected blueprint inputs. Learn more about components in [Identifying Components](/user-guides/certify/identifying-components).\n\n### Removals\n\n- Removals represent a series of activities that result in CO₂e being removed from the atmosphere.\n- The carbon accounting of a removal typically contains sequestrations, counterfactuals and activities (emissions).\n- Removals are structured using a template, [defined in your LCA](/user-guides/certify/lca).\n- Templates are divided into component groups. For instance, a biochar template may contain a `Feedstock sourcing` group.\n- Groups can contain multiple components.\n- Components can also be partially attributed to removals, if the activity the component represents contributed to multiple removals.\n- The final uncertainty discounting is done on the removal level - the API will return the CO₂e removed with and without discounting.\n- See the [Create a removal](/user-guides/certify/removal) guide for more details.\n\n### Feedstock types\n\n- Many carbon removal methods involve a feedstock, for instance biomass feedstock in BiCRS or silicate rock in enhanced weathering.\n- Feedstock types are used to describe the feedstock used in a removal.\n- When creating a removal, a feedstock type can be optionally specified so that Isometric and verifiers can see which removals use which feedstocks.\n- This is important if different feedstocks are used in a single GHG statement.\n- See the [Add feedstock](/user-guides/certify/add-feedstock) guide for more details.\n","version":"v0"},"servers":[{"url":"/mrv/v0"},{"url":"https://api.sandbox.isometric.com/mrv/v0","description":"Sandbox Isometric MRV API"},{"url":"https://api.isometric.com/mrv/v0","description":"Production Isometric MRV API"}],"paths":{"/component_blueprints":{"get":{"summary":"Get Component Blueprints","description":"Lists component blueprints in the Isometric system","operationId":"get_component_blueprints_component_blueprints_get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"last","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve before the item represented by the cursor passed in the before parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"Last"}},{"name":"before","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page’s start_cursor here when paginated backwards.","title":"Before"}},{"name":"first","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve after the item represented by the cursor passed in the after parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"First"}},{"name":"after","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page’s end_cursor here when paginated forwards.","title":"After"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/PaginatedListResource_ComponentBlueprint_"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/component_blueprints/{key}":{"get":{"summary":"Get Component Blueprint","operationId":"get_component_blueprint_component_blueprints__key__get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"key","in":"path","required":true,"schema":{"type":"string","title":"Key"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ComponentBlueprint"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/projects/{project_id}/removal_templates":{"get":{"summary":"Get Removal Templates","description":"Lists all removal templates within the given project","operationId":"get_removal_templates_projects__project_id__removal_templates_get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"project_id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_Project_"}},{"name":"last","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve before the item represented by the cursor passed in the before parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"Last"}},{"name":"before","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page’s start_cursor here when paginated backwards.","title":"Before"}},{"name":"first","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve after the item represented by the cursor passed in the after parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"First"}},{"name":"after","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page’s end_cursor here when paginated forwards.","title":"After"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/PaginatedListResource_RemovalTemplate_"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/projects/{project_id}/removal_templates/{id}":{"get":{"summary":"Get Removal Template","description":"Gets a single removal template within the given project","operationId":"get_removal_template_projects__project_id__removal_templates__id__get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"project_id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_Project_"}},{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntryTemplate_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/RemovalTemplate"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/removals/{id}":{"patch":{"summary":"Patch Removal","description":"Updates a removal in the Isometric system. The removal will be recalculated, if it is are not in an immutable state.","operationId":"patch_removal_removals__id__patch","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntry_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/PatchRemovalRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Removal"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}},"get":{"summary":"Get Removal","operationId":"get_removal_removals__id__get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntry_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Removal"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}},"delete":{"summary":"Delete Removal","description":"This endpoint deletes a removal - this is irreversible and the removal cannot be recovered.\n\nIt will return an error if the removal is not in DRAFT status.","operationId":"delete_removal_removals__id__delete","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntry_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"204":{"description":"Successful Response"},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/removals":{"get":{"summary":"Get Removals","operationId":"get_removals_removals_get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"supplier_reference_id","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1,"maxLength":100,"description":"A string that must be unique for all resources created by a specific supplier. It can be used by a client to identify the correct objects in their system."},{"type":"null"}],"title":"Supplier Reference Id"}},{"name":"last","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve before the item represented by the cursor passed in the before parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"Last"}},{"name":"before","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page’s start_cursor here when paginated backwards.","title":"Before"}},{"name":"first","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve after the item represented by the cursor passed in the after parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"First"}},{"name":"after","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page’s end_cursor here when paginated forwards.","title":"After"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/PaginatedListResource_Removal_"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}},"post":{"summary":"Post Removal","operationId":"post_removal_removals_post","security":[{"HTTPBearer":[]}],"parameters":[{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateRemovalRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Removal"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/removals/{id}/component_attributions":{"get":{"summary":"Get Removal Components","operationId":"get_removal_components_removals__id__component_attributions_get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntry_"}},{"name":"last","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve before the item represented by the cursor passed in the before parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"Last"}},{"name":"before","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page’s start_cursor here when paginated backwards.","title":"Before"}},{"name":"first","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve after the item represented by the cursor passed in the after parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"First"}},{"name":"after","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page’s end_cursor here when paginated forwards.","title":"After"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/PaginatedListResource_ComponentAttribution_"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}},"patch":{"summary":"Patch Removal Components","description":"Change component attributions for the removal.","operationId":"patch_removal_components_removals__id__component_attributions_patch","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgEntry_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/PatchRemovalComponentAttributionsRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Removal"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/ghg_statements":{"post":{"summary":"Post Ghg Statement","description":"Submits a series of removals for verification","operationId":"post_ghg_statement_ghg_statements_post","security":[{"HTTPBearer":[]}],"parameters":[{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateGhgStatementRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GhgStatement"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}},"get":{"summary":"Get Ghg Statements","description":"Lists GHG statements in the Isometric system","operationId":"get_ghg_statements_ghg_statements_get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"last","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve before the item represented by the cursor passed in the before parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"Last"}},{"name":"before","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the first item in the previously requested page to select items ordered before it. Submit the previously requested page’s start_cursor here when paginated backwards.","title":"Before"}},{"name":"first","in":"query","required":false,"schema":{"type":"integer","maximum":50,"exclusiveMinimum":0,"description":"An integer number of items to retrieve after the item represented by the cursor passed in the after parameter. Defaults to 10 with a maximum value of 50.","default":10,"title":"First"}},{"name":"after","in":"query","required":false,"schema":{"anyOf":[{"type":"string","minLength":1},{"type":"null"}],"description":"An opaque cursor representing the last item in the previously requested page to select items ordered after it. Submit the previously requested page’s end_cursor here when paginated forwards.","title":"After"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/PaginatedListResource_GhgStatement_"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/ghg_statements/{id}/submit":{"post":{"summary":"Post Ghg Statement Submit","operationId":"post_ghg_statement_submit_ghg_statements__id__submit_post","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgStatement_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"anyOf":[{"$ref":"#/components/schemas/SubmitGhgStatementRequest"},{"$ref":"#/components/schemas/ResubmitGhgStatementRequest"}],"title":"Ghg Statement Request"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GhgStatement"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/ghg_statements/{id}":{"get":{"summary":"Get Ghg Statement","description":"Get a single GHG statement","operationId":"get_ghg_statement_ghg_statements__id__get","security":[{"HTTPBearer":[]}],"parameters":[{"name":"id","in":"path","required":true,"schema":{"$ref":"#/components/schemas/IsometricIDPathParam_GhgStatement_"}},{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GhgStatement"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/ghg_statement_components":{"post":{"summary":"Post Ghg Statement Component","description":"Creates a component that will be automatically and evenly attributed to all removals with the GHG Statement.","operationId":"post_ghg_statement_component_ghg_statement_components_post","security":[{"HTTPBearer":[]}],"parameters":[{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"description":"A secret token identifying the client connecting to the API"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateGhgStatementComponentRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Component"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}},"/project_components":{"post":{"summary":"Post Project Component","description":"Creates a component that will be automatically attributed to GHG statements in the project based on the provided allocation strategy.","operationId":"post_project_component_project_components_post","security":[{"HTTPBearer":[]}],"parameters":[{"name":"x-client-secret","in":"header","required":true,"schema":{"type":"string","title":"Client secret","description":"A secret token identifying the client connecting to the API","examples":["Syou3EZiO5vuMEgNyBeA8cjEMYOnQDwP"]},"descripti

# --- truncated at 32 KB (246 KB total) ---
# Full source: https://raw.githubusercontent.com/api-evangelist/isometric-co/refs/heads/main/openapi/isometric-certify-api-openapi.json