# ibm-envizi-emissions-api-nodejs-sdk **Repository Path**: mirrors_ibm/ibm-envizi-emissions-api-nodejs-sdk ## Basic Information - **Project Name**: ibm-envizi-emissions-api-nodejs-sdk - **Description**: IBM Envizi - Emissions API Node.js SDK - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-09-09 - **Last Updated**: 2026-03-29 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # IBM Envizi - Emissions API Node.js SDK [IBM Envizi - Emissions API](https://www.ibm.com/products/envizi/emissions-api) (Emissions API) is a managed factor database and calculation engine for embedding greenhouse gas (GHG) emissions calculations into operational decision making. The `emissions-api-sdk` is a Node.js SDK for using Emissions API in your projects. ## Sign up for the Preview To get started with the Emissions API follow these steps: - Sign up for the preview waitlist [IBMid sign up](https://www.ibm.com/account/reg/us-en/signup?formid=urx-53999) page. - You will be sent an invite email to join to create an account. - Read the [Introduction](https://developer.ibm.com/apis/catalog/ghgemissions--ibm-envizi-emissions-api/Introduction) page to get an overview of the Emissions API. ## Installation ```bash npm install emissions-api-sdk # or yarn install emissions-api-sdk ``` ## Quick Start ```javascript import { Client, LocationEmission } from 'emissions-api-sdk'; // Initialize client await Client.getClient({ apiKey: process.env.ENVIZI_API_KEY, clientId: process.env.ENVIZI_CLIENT_ID, orgId: process.env.ENVIZI_ORG_ID }); // Calculate emissions const result = await LocationEmission.calculate({ "location": { "country": "USA", "stateProvince": "california" }, "activity": { "type": "electricity", "value": 1, "unit": "kWh" } }); ``` ## Metadata APIs The Metadata API provides a unified way to query metadata for any endpoint: ```javascript import { Metadata } from 'emissions-api-sdk'; // Get types for any endpoint (defaults to 'calculation') const allTypes = await Metadata.getTypes(); const locationTypes = await Metadata.getTypes('location'); const stationaryTypes = await Metadata.postTypes('stationary'); // Get areas for any endpoint const allAreas = await Metadata.getArea(); const mobileAreas = await Metadata.getArea('mobile'); const fugitiveAreas = await Metadata.postArea('fugitive'); // Get units for any type const allUnits = await Metadata.getUnits(); // All units const typeUnits = await Metadata.getUnits('Natural Gas'); // Units for specific type ``` **Supported endpoints**: `calculation`, `location`, `stationary`, `mobile`, `fugitive`, `factor`, `search`, `transportation-and-distribution`, `economic-activity`, `real-estate` ### Get Organization Usage ```javascript import { Usage } from 'emissions-api-sdk'; // Retrieves current billing period or historical usage data for the Organization // History Flag to retrieve current billing or historical usage data. const usage = await Usage.getUsage(true); ``` ## Authentication The SDK supports two authentication methods: ### API Key (Recommended) ```javascript await Client.getClient({ apiKey: process.env.ENVIZI_API_KEY, clientId: process.env.ENVIZI_CLIENT_ID, orgId: process.env.ENVIZI_ORG_ID }); ``` ### Pre-generated Token ```javascript await Client.getClient({ token: process.env.JWT_TOKEN, clientId: process.env.ENVIZI_CLIENT_ID }); ``` ## Documentation For detailed [documentation](https://ibm.github.io/ibm-envizi-emissions-api-nodejs-sdk/), see: - [Getting Started](https://ibm.github.io/ibm-envizi-emissions-api-nodejs-sdk/getting_started.html) - [Authentication](https://ibm.github.io/ibm-envizi-emissions-api-nodejs-sdk/authentication.html) - [Client Configuration](https://ibm.github.io/ibm-envizi-emissions-api-nodejs-sdk/client.html) - [API Reference](https://ibm.github.io/ibm-envizi-emissions-api-nodejs-sdk/reference.html) Other resources: - [APIHub](https://developer.ibm.com/apis/catalog/ghgemissions--ibm-envizi-emissions-api/api/API--ghgemissions--authentication) - API documentation (OpenAPI) - [Tutorials & Sample Applications](https://ibm.github.io/ibm-envizi-emissions-api/) - [IBM Envizi for Excel](https://ibm.github.io/ibm-envizi-emissions-api-excel-addin) - Emissions API Excel Add-in. ## License This project is licensed under the terms of the [LICENSE](LICENSE) file.