A curated list of open technology projects to sustain a stable climate, energy supply, biodiversity and natural resources.

National Carbon Credit Registry

As an online database using national and international standards for quantifying and verifying greenhouse gas emissions reductions by programmes.
https://github.com/undp/carbon-registry

Keywords

carbon-emissions climate digital-public-goods sustainable-development-goals

Keywords from Contributors

greenhouse-gas-emissions measure archiving transforms communicator observability optimize compose certificate animals

Last synced: 24 days ago
JSON representation

Acceptance Criteria

Repository metadata

National Carbon Credit Registry Digital Public Good (DPG) by Digital For Climate (D4C) collaboration. Code coordinated by ExO/CDO & BPPS/Climate.

README.md

GitHub last commit
Uptime
GitHub Workflow Status (with branch)
GitHub Workflow Status (with branch)

National Carbon Credit Registry (NEW RELEASE END OF APRIL 2025)

CURRENTLY UNDER CONSTRUCTION. New updated release end of April 2025 will include improvements for UI/UX, credit serialisation and issuance, as well as reporting modules. Please check back then.

About

The National Carbon Credit Registry is an open-source toolkit developed by UNDP to help countries develop a national registry to fulfil the requirements of Article 6 (Paris Agreement).

It allows countries to track, record, issue, monitor, and trade credits from various mitigation activities, all while ensuring data integrity through a secure ledger. The system tracks the entire process of carbon credits, from issuance to retirement, and makes the data publicly available to enhance transparency.

The UNDP hosts and maintains a free standard code base on this Github, with basic feature functionality. Countries can customize and deploy their version of the registry, so that it meets national requirements, linking it to other national and international systems. Using open-source code helps reduce costs, avoid duplication, and ensure compatibility with existing systems, simplifying the creation of domestic carbon markets.

More information about the project’s background, vision, policy context, support provided can be found in the demo site https://www.demo.carbreg.org/. Please contact the UNDP DPG team [email protected] to request a walkthrough demonstration and to discuss further support and collaboration.

πŸ”΄ ANNOUNCEMENT: Following recent announcements and outcomes of COP29, the open-source carbon registry will undergo updates to align with the latest requirements and guidelines under Article 6 of the Paris Agreement. These updates aim to enhance transparency, interoperability, and environmental integrity in international carbon transactions, as well as to support Parties in meeting their Nationally Determined Contributions (NDCs) more effectively.

Index

Standards and License

This codebase follows the digital public goods standard: https://digitalpublicgoods.net/standard/ It is built according to the Principles for Digital Development: https://digitalprinciples.org/

The tool is developed and maintained by UNDP and is licensed under the GNU Affero General Public License (AGPL-3.0), which permits free use, modification, and sharing of the software.

We kindly ask users to inform us of your usage by contacting [email protected], as this helps us track the tool’s impact and guide future improvements.

Under AGPL-3.0, any modifications to the code must be made publicly available by creating a new branch on GitHub. The software cannot be relicensed under more restrictive terms without adhering to the AGPL-3.0 guidelines.

Changelog

CURRENTLY UNDER CONSTRUCTION. NEW RELEASE PLANNED FOR APRIL 2025.
Learn about the latest improvements.

Features and User Flow

Every country has distinct carbon market policies, processes, and governance structures and will need to customize the Carbon Registry to accommodate local needs.

The open-source code (demo version) includes the following common set of steps (features) that will be needed in most countries.

  • User registration: Users (within government, certifiers, project developers, ministries) can register and be approved for the tool.

  • Project registration: Projects aimed at reducing or removing carbon emissions are registered. Baseline emissions and expected credits are calculated, and ownership is determined.

  • Validation by Third Parties: Independent entities validate and approve the projects, authorizing them for publication in the registry.

  • Monitoring & Reporting: Once projects are implemented, emissions reductions are monitored and reported. Verified carbon credits are issued based on these results.

  • Trading & Tracking: Issued credits can be traded, tracked, and retired within the registry, ensuring proper ownership transfer and preventing double counting.

The demo version provides an example user flow that can act as a starting point for customization:
Example Carbon Registry Workflows

Key features of the software include:

  • Issuing Carbon Credits: Each verified project credit is assigned a unique serial number, based on UNFCCC-CDM methodology. All transfers and retirements are immutably recorded, enhancing the efficiency and reliability of carbon credit transactions. This ensures transparency and accountability in the carbon market.

  • Dashboard and Insights: Users can access an interactive dashboard with dynamic data visualizations, including graphs, maps, and regional statistics. This provides a clear overview of progress and trends, along with a visual timeline of activities for each project, showing a detailed history of actions and users involved.

  • Interoperable and Exportable data: The Carbon Registry's data model is aligned with the CAD Trust Data Model, ensuring interoperability. It can also integrate with the ITMO Voluntary Bilateral Cooperation Platform, managed by UNDP. An open RESTful API allows for the development of innovative transparency tools and seamless integration with other external systems.

Demo Site

A demo site at https://www.demo.carbreg.org/login illustrates the basic functionality of the carbon registry for your country. Please contact the UNDP DPG team to request a walkthrough of the demo and to be added to the user list for the demo site.

System Architecture

UNDP Carbon Registry is based on service oriented architecture (SOA). Following diagram visualize the basic components in the system.

alt text

System Services

National Service

Authenticate, Validate and Accept user (Government, Project Developer/Certifier) API requests related to the following functionalities,

  • User and company CRUD operations.
  • User authentication.
  • Project life cycle management.
  • Credit life cycle management.

Service is horizontally scalable and state maintained in the following locations,

  • File storage.
  • Operational Database.
  • Ledger Database.

Uses the Carbon Credit Calculator and Serial Number Generator node modules to estimate the project carbon credit amount and issue a serial number.
Uses Ledger interface to persist project and credit life cycles.

Analytics Service

Serve all the system analytics. Generate all the statistics using the operational database.
Horizontally scalable.

Replicator Service

Asynchronously replicate ledger database events in to the operational database. During the replication process it injects additional information to the data for query purposes (Eg: Location information).
Currently implemented for QLDB and PostgresSQL ledgers. By implementing replicator interface can support more ledger replicators.
Replicator select based on the LEDGER_TYPE environment variable. Support types QLDB, PGSQL(Default).

Deployment

System services can deploy in 2 ways.

External Service Providers

All the external services access through a generic interface. It will decouple the system implementation from the external services and enable extendability to multiple services.

Geo Location Service

Currently implemented for 2 options.

  1. File based approach. User has to manually add the regions with the geo coordinates. Sample File. To apply new file changes, replicator service needs to restart.
  2. Mapbox. Dynamically query geo coordinates from the Mapbox API.

Can add more options by implementing location interface

Change by environment variable LOCATION_SERVICE. Supported types MAPBOX, FILE(Default)

File Service

Implemented 2 options for static file hosting.

  1. NestJS static file hosting using the local storage and container volumes.
  2. AWS S3 file storage.

Can add more options by implementing file handler interface

Change by environment variable FILE_SERVICE. Supported types S3, LOCAL(Default)

Database Architecture

Primary/secondary database architecture used to store carbon project and account balances.
Ledger database is the primary database. Add/update projects and update account balances in a single transaction. Currently implemented only for AWS QLDB

Operational Database is the secondary database. Eventually replicated to this from primary database via data stream. Implemented based on PostgresSQL

Why Two Database Approach?

  1. Cost and Query capabilities - Ledger database (blockchain) read capabilities can be limited and costly. To support rich statistics and minimize the cost, data is replicated in to a cheap query database.
  2. Disaster recovery
  3. Scalability - Primary/secondary database architecture is scalable since additional secondary databases can be added as needed to handle more read operations.

Why Ledger Database?

  1. Immutable and Transparent - Track and maintain a sequenced history of every carbon project and credit change.
  2. Data Integrity (Cryptographic verification by third party).
  3. Reconcile carbon credits and company account balance.

Ledger Database Interface

This enables the capability to add any blockchain or ledger database support to the carbon registry without functionality module changes. Currently implemented for PostgresSQL and AWS QLDB.

PostgresSQL Ledger Implementation storage all the carbon project and credit events in a separate event database with the sequence number. Support all the ledger functionalities except immutability.

Single database approach used for user and company management.

Ledger Layout

Carbon Registry contains 3 ledger tables.

  1. Project ledger - Contains all the project and credit transactions.
  2. Company Account Ledger (Credit) - Contains company accounts credit transactions.
  3. Country Account Ledger (Credit) - Contains country credit transactions.

The below diagram demonstrates the the ledger behavior of project create, authorise, issue and transfer processes. Blue color document icon denotes a single data block in a ledger.

alt text

Authentication

  • JWT Authentication - All endpoints based on role permissions.
  • API Key Authentication - MRV System connectivity.

Project Structure

.
β”œβ”€β”€ .github                         # CI/CD [Github Actions files]
β”œβ”€β”€ deployment                      # Declarative configuration files for initial resource creation and setup [AWS Cloudformation]
β”œβ”€β”€ backend                         # System service implementation
    β”œβ”€β”€ services                    # Services implementation [NestJS application]
        β”œβ”€β”€ src
            β”œβ”€β”€ national-api        # National API [NestJS module]      
            β”œβ”€β”€ stats-api           # Statistics API [NestJS module]
            β”œβ”€β”€ ledger-replicator   # Blockchain Database data replicator [QLDB to Postgres]
            β”œβ”€β”€ shared              # Shared resources [NestJS module]     
        β”œβ”€β”€ serverless.yml          # Service deployment scripts [Serverless + AWS Lambda]
β”œβ”€β”€ libs
    β”œβ”€β”€ carbon-credit-calculator    # Implementation for the Carbon credit calculation library [Node module + Typescript]
    β”œβ”€β”€ serial-number-gen           # Implementation for the carbon project serial number calculation [Node module + Typescript]
β”œβ”€β”€ web                             # System web frontend implementation [ReactJS]
β”œβ”€β”€ .gitignore
β”œβ”€β”€ docker-compose.yml              # Docker container definitions
└── README.md

Run Services As Containers

  • Update docker compose file env variables as required.
    • Currently all the emails are disabled using env variable IS_EMAIL_DISABLED. When the emails are disabled email payload will be printed on the console. User account passwords needs to extract from this console log. Including root user account, search for a log line starting with Password (temporary) on national container (docker logs -f undp-carbon-registry-national-1).
    • Add / update following environment variables to enable email functionality.
      • IS_EMAIL_DISABLED=false
      • SOURCE_EMAIL (Sender email address)
      • SMTP_ENDPOINT
      • SMTP_USERNAME
      • SMTP_PASSWORD
    • Use DB_PASSWORD env variable to change PostgresSQL database password
    • Configure system root account email by updating environment variable ROOT EMAIL. If the email service is enabled, on the first docker start, this email address will receive a new email with the root user password.
    • By default frontend does not show map images on dashboard and project view. To enable them please update REACT_APP_MAP_TYPE env variable to Mapbox and add new env variable REACT_APP_MAPBOXGL_ACCESS_TOKEN with MapBox public access token in web container.
  • Add user data
    • Update organisations.csv file to add organisations.
    • Update users.csv file to add users.
    • When updating files keep the header and replace existing dummy data with your data.
    • These users and companys add to the system each docker restart.
  • Run docker-compose up -d --build. This will build and start containers for following services,
    • PostgresDB container
    • National service
    • Analytics service
    • Replicator service
    • React web server with Nginx.
  • Web frontend on http://localhost:3030/
  • API Endpoints,

Run Services Locally

  • Setup postgreSQL locally and create a new database.
  • Update following DB configurations in the .env.local file (If the file does not exist please create a new .env.local)
    • DB_HOST (Default localhost)
    • DB_PORT (Default 5432)
    • DB_USER (Default root)
    • DB_PASSWORD
    • DB_NAME (Default carbondbdev)
  • Move to folder cd backend/service
  • Run yarn run sls:install
  • Initial user data setup serverless invoke local --stage=local --function setup --data '{"rootEmail": "<Root user email>","systemCountryCode": "<System country Alpha 2 code>", "name": "<System country name>", "logoBase64": "<System country logo base64>"}'
  • Start all the services by executing sls offline --stage=local
  • Now all the system services are up and running. Swagger documentation will be available on http://localhost:3000/local/national

Deploy System on the AWS Cloud

  • Execute to create all the required resources on the AWS.
    aws cloudformation deploy --template-file ./deployment/aws-formation.yml --stack-name carbon-registry-basic --parameter-overrides EnvironmentName=<stage> DBPassword=<password> --capabilities CAPABILITY_NAMED_IAM
    
  • Setup following Github Secrets to enable CI/CD
    • AWS_ACCESS_KEY_ID
    • AWS_SECRET_ACCESS_KEY
  • Run it manually to deploy all the lambda services immediately. It will create 2 lambda layers and following lambda functions,
    • national-api: Handle all carbon registry user and program creation. Trigger by external http request.
    • replicator: Replicate Ledger database entries in to Postgres database for analytics. Trigger by new record on the Kinesis stream.
    • setup: Function to add initial system user data.
  • Create initial user data in the system by invoking setup lambda function by executing
    aws lambda invoke \
        --function-name carbon-registry-services-dev-setup --cli-binary-format raw-in-base64-out\
        --payload '{"rootEmail": "<Root user email>","systemCountryCode": "<System country Alpha 2 code>", "name": "<System country name>", "logoBase64": "<System country logo base64>"}' \
        response.json
    

External Connectivity

UNDP'S ITMO Platform

The Carbon Registry is designed to be linked to the ITMO Voluntary Bilateral Cooperation Platform, https://carboncooperation.undp.org/, managed by UNDP. This enables countries to automatically sync projects created/authorised and credits issued within its national registry to the international trading platform. The system does this by:

  1. Carbon Registry make a daily to the retrieve ITMO platform projects.
  2. Projects create in the Carbon Registry when projects are authorized in the ITMO Platform
  3. The Carbon Registry update when the projects are Issued with credits in the ITMO Platform

Lifecycle

alt text

Project Creation and Authorisation

  • Authorisation of projects in the ITMO Platform identified by the event name: "ITMO-Design Document (DD) & Validation Report / Upload on National Public Registry".
  • If the Company Tax Id doesn’t exist in the Carbon Registry, that company created in the Carbon Registry.
  • When creating the project:
    • The project created with the state β€œPending”
    • The credit estimate set to 100 by default
    • The company percentage set to 100%
    • The serial number for the project generated the same as any other project in the Carbon Registry.
  • Projects retrieved from the ITMO Platform and created in the Carbon Registry can Authorised/Rejected by a Government user the same as any other project in the Carbon Registry
  • When a project is authorised, the authorised credits will be the default credit estimate mentioned above. The project can be issued with credits by a Government user the same as any other project in the Carbon Registry.

Credit Issuance

  • Credits can be issued for projects retrieved from the ITMO Platform and created in the Carbon Registry in two ways;
    • By a Government user the same as any other project.
    • Credit issuance in the ITMO Platform which should be reflected in the Carbon Registry.
  • In the case of 2 above,
    • Credit issuance identified by the event name: "Upload Final Monitoring Report" in the ITMO Platform.

Field Mapping

Company

Name in the Carbon Registry Mandatory in the Carbon Registry Name in the ITMO Platform
Tax ID (taxId) Yes company
Name (name) Yes company
Email (email) Yes Set default : nce.digital+[organisation]@undp.org
Phone Number (phoneNo) Yes Set default : 00
Website
Address Set default : Country if the Registry
Logo
Country (country) Set default : Country of the Registry
Role (companyRole) Yes Set default : ProgrammeDeveloper

User

Name in the Carbon Registry Mandatory in the Carbon Registry Name in the ITMO Platform
Email (email) Yes Set default : nce.digital+[organisation]@undp.org
Role (role) Yes Set default : Admin
Phone Number (phoneNo) Set default : 00

Project

Name in the Carbon Registry Mandatory in the Carbon Registry Name in the ITMO Platform
Project Name (title) Yes Name
External ID (externalId) Yes id
Credit Issuance Serial Number
Current Status Set default : Pending
Applicant Type Set default : Project Developer
Sector (sector) Yes Sector
Sectoral Scope (sectoralScope) Yes Sector
Project Start Date (startTime) Yes createdAt
Project End Date (endTime) Yes createdAt + 10 years
Geographical Location (Regional) (geographicalLocation) Yes country (Name not mentioned as ISO3 or actual name)
Buyer Country Eligibility
Project Cost (USD) (programmeCostUSD) Yes Set default : Null
Financing Type
Grant Equivalent Amount
Carbon Price (Dollars per ton)
Company company
Company Tax ID (proponentTaxVatId) Yes company
Company Percentage (proponentPercentage) Yes Set default : 100%
Type of Mitigation Action/Activity (typeOfMitigation) Yes Sector
GHGs Covered (greenHouseGasses) Yes Set default : CO2
Credits Authorised Set default : 100
Credits Issued Set default : 10
Credits Transferred
Credits Frozen
Credits Retired
Credits authorised for international transfer and use (Total cumulative maximum amount of Mitigation Outcomes for which international transfer and use is authorized)
Crediting Period (years)
Project Materials Files *
Project Materials Files *
Credit Calculation Fields / Mitigation Type Calculation
Agriculture
Land Area
Land Area Unit
Solar
energy generation
energy generation unit
consumer group

ITMO Sector Mapping

ITMO Sector Field Value Sector Sectoral Scope Type Of Mitigation
energy-distribution Energy Energy Distribution Energy Distribution
agriculture Agriculture Agriculture Agriculture
energy-industries Energy Energy Industry EE Industry
Default Other Energy Industry EE Industry

Assumptions

  • Project estimated credit amount is 100.
  • Project issued credit amount is always 10.

Docker Integration Setup

  1. Append data-importer to docker-compose file replicator service RUN_MODULE env variable with comma separated.
  2. Update following env variables in the docker-compose file replicator service.
    • ITMO_API_KEY
    • ITMO_EMAIL
    • ITMO_PASSWORD
    • ITMO_ENDPOINT
  3. Projects will import on each docker restart.

User Onboarding and Permissions Model

User Roles

System pre-defined user roles are as follows,

  • Root
  • Company Level (National Government, Project and Certification Company come under this level)
    • Admin
    • Manager
    • View Only

User Onboarding Process

  1. After the system setup, the system have a Root User for the setup email (one Root User for the system)
  2. Root User is responsible for creating the Government entity and the Admin of the Government
  3. The Government Admin is responsible for creating the other companies and Admins of each company.
  4. Admin of the company has the authority to add the remaining users (Admin, Managers, View Only Users) to the company.
  5. When a user is added to the system, a confirmation email should be sent to users including the login password.

User Management

All the CRUD operations can be performed as per the following table,

Company Role New User Role Authorized User Roles (Company)
Government Root Cannot create new one other than the default system user and Can manage all the users in the system
Government AdminManagerView Only RootAdmin(Government)
All other Company Roles AdminManagerView Only RootAdmin(Government)Admin(Company)
  • All users can edit own user account except Role and Email.
  • Users are not allowed to delete the own account from the system.

Web Frontend

Web frontend implemented using ReactJS framework. Please refer getting started with react app for more information.

Localization

  • Languages (Current): English
  • Languages (In Progress): French. Spanish
    Please refer here for adding a new language translation file.

Application Programming Interface (API)

For integration, reference RESTful Web API Documentation documentation via Swagger. To access

  • National API: api.APP_URL/national
  • Status API: api.APP_URL/stats

Resource Requirements

Resource Minimum Recommended
Memory 4 GB 8 GB
CPU 4 Cores 4 Cores
Storage 20 GB 50 GB
OS Linux Windows Server 2016 and later versions.

Note: Above resource requirement mentioned for a single instance from each microservice.

Status Page

For transparent uptime monitoring go to status.APP_URL
Open source code available at https://github.com/undp/carbon-registry-status

Governance and Support

The United Nations Development Program (UNDP) is responsible for managing the application. To ensure alignment with international demand, Digital For Climate (D4C)β€―will act as an advisory body to the Digital Public Good Carbon Registry codebase. D4C is a collaboration between European Bank for Reconstruction and Development (EBRD), United Nations Development Program (UNDP), United Nations Framework Convention on Climate Change (UNFCCC), International Emissions Trading Association (IETA), European Space Agency (ESA), and World Bank Groupβ€― that aims to coordinate respective workflows and create a modular and interoperable end-to-end digital ecosystem for the carbon market. The overarching goal is to support a transparent, high integrity global carbon market that can channel capital for impactful climate action and low-carbon development.

This code is managed by United Nations Development Programme as custodian, detailed in theβ€―press release. For technical questions, please visit the community of practice β€˜Keeping Track of the Paris Agreement’ or submit through the open forum. For any other questions, contact us atβ€―[email protected].


Owner metadata


GitHub Events

Total
Last Year

Committers metadata

Last synced: 3 months ago

Total Commits: 2,365
Total Committers: 22
Avg Commits per committer: 107.5
Development Distribution Score (DDS): 0.504

Commits in past year: 79
Committers in past year: 9
Avg Commits per committer in past year: 8.778
Development Distribution Score (DDS) in past year: 0.506

Name Email Commits
palindaa p****a@x****m 1172
Yathurshan Thurairajah y****t@x****m 322
dhanushkaxep d****p@x****m 182
Dhanuxeptagon d****s@x****m 147
lochana l****f@x****m 140
gayanath8 g****r@x****m 74
tharindugayanga t****g@x****m 63
Mark Belinsky m@m****m 60
Uvinduabeykoon u****a@x****m 59
Aaketk17 t****a@g****m 40
dependabot[bot] 4****] 34
leshanw l****w@x****m 19
shanika s****w@x****m 18
Zung Nguyen v****n@u****g 12
OmaMorkie t****e@g****m 6
ravinduf09 r****f@x****m 4
PruthuviXeptagon 1****n 4
Kalindhu Navanjana k****d@x****m 3
Kaarina 1****e 2
reinaotsuka 7****a 2
Athavan Theivendram 1****t 1
fossabot b****s@f****o 1

Committer domains:


Issue and Pull Request metadata

Last synced: 3 months ago

Total issues: 148
Total pull requests: 104
Average time to close issues: 4 months
Average time to close pull requests: 9 days
Total issue authors: 11
Total pull request authors: 9
Average comments per issue: 1.46
Average comments per pull request: 0.2
Merged pull request: 70
Bot issues: 0
Bot pull requests: 36

Past year issues: 4
Past year pull requests: 30
Past year average time to close issues: 6 months
Past year average time to close pull requests: 6 days
Past year issue authors: 3
Past year pull request authors: 4
Past year average comments per issue: 0.0
Past year average comments per pull request: 0.0
Past year merged pull request: 19
Past year bot issues: 0
Past year bot pull requests: 21

More stats: https://issues.ecosyste.ms/repositories/lookup?url=https://github.com/undp/carbon-registry

Top Issue Authors

  • mbelinsky (134)
  • timschloe (4)
  • kaarinadev (2)
  • martinvalenta (1)
  • davidnjagah (1)
  • Louvani (1)
  • pavankumarkona (1)
  • humanitariantechie (1)
  • C0D3Name (1)
  • Z-zzim (1)
  • JUDOKICK (1)

Top Pull Request Authors

  • palindaa (58)
  • dependabot[bot] (36)
  • zungundp (4)
  • Louvani (1)
  • fossabot (1)
  • Neurone (1)
  • ravinduf09 (1)
  • mbelinsky (1)
  • omahs (1)

Top Issue Labels

  • enhancement (107)
  • Transparency (28)
  • bug (20)
  • Registry (5)
  • capacity-building (3)
  • question (3)

Top Pull Request Labels

  • dependencies (36)

Package metadata

proxy.golang.org: github.com/undp/carbon-registry

  • Homepage:
  • Documentation: https://pkg.go.dev/github.com/undp/carbon-registry#section-documentation
  • Licenses: agpl-3.0
  • Latest release: v0.8.2 (published almost 2 years ago)
  • Last Synced: 2025-03-09T00:05:04.514Z (about 2 months ago)
  • Versions: 8
  • Dependent Packages: 0
  • Dependent Repositories: 0
  • Rankings:
    • Forks count: 5.609%
    • Stargazers count: 7.451%
    • Average: 8.016%
    • Dependent packages count: 8.39%
    • Dependent repos count: 10.611%
npmjs.org: @undp/serial-number-gen

Serial Number Generator

  • Homepage: https://github.com/undp/carbon-registry/tree/main#readme
  • Licenses: MIT
  • Latest release: 1.0.3 (published over 1 year ago)
  • Last Synced: 2025-03-09T00:05:05.354Z (about 2 months ago)
  • Versions: 4
  • Dependent Packages: 0
  • Dependent Repositories: 1
  • Downloads: 63 Last month
  • Rankings:
    • Downloads: 4.623%
    • Forks count: 6.007%
    • Stargazers count: 7.625%
    • Dependent repos count: 10.768%
    • Average: 16.521%
    • Dependent packages count: 53.583%
  • Maintainers (4)

Dependencies

.github/workflows/server-deployments.yml actions
  • actions/checkout v3 composite
  • actions/setup-node v3 composite
  • serverless/github-action v3.1 composite
libs/carbon-credit-calculator/package.json npm
  • @types/jest ^29.2.3 development
  • jest ^29.3.1 development
  • ts-jest ^29.0.3 development
  • typescript ^4.8.4 development
  • @types/node ^18.11.9
  • convert-units ^2.3.4
libs/carbon-credit-calculator/yarn.lock npm
  • 301 dependencies
libs/serial-number-gen/package.json npm
  • typescript ^4.8.4 development
libs/serial-number-gen/yarn.lock npm
  • typescript 4.8.4
web/package.json npm
  • @types/sha1 ^1.1.3 development
  • eslint ^8.2.0 development
  • eslint-config-airbnb 19.0.4 development
  • eslint-config-airbnb-typescript ^17.0.0 development
  • eslint-config-prettier ^8.5.0 development
  • eslint-import-resolver-typescript ^3.5.2 development
  • eslint-plugin-import ^2.25.3 development
  • eslint-plugin-jsx-a11y ^6.5.1 development
  • eslint-plugin-prettier ^4.2.1 development
  • husky ^8.0.2 development
  • lint-staged ^13.0.3 development
  • prettier 2.7.1 development
  • react-scripts 5.0.1 development
  • tslint-config-prettier ^1.18.0 development
  • @ant-design/icons ^4.7.0
  • @testing-library/jest-dom ^5.16.5
  • @testing-library/react ^13.4.0
  • @testing-library/user-event ^13.5.0
  • @types/jest ^27.5.2
  • @types/node ^16.18.3
  • @types/react ^18.0.25
  • @types/react-dom ^18.0.8
  • @types/styled-components ^5.1.26
  • antd ^4.24.1
  • apexcharts ^3.36.3
  • axios ^1.1.3
  • bcrypt ^5.1.0
  • bootstrap-icons ^1.10.2
  • env-cmd ^10.1.0
  • i18next ^22.0.6
  • i18next-browser-languagedetector ^7.0.1
  • i18next-http-backend ^2.0.1
  • jwt-decode ^3.1.2
  • luxon ^3.1.0
  • mapbox-gl ^2.11.0
  • node-sass ^7.0.3
  • react ^18.2.0
  • react-apexcharts ^1.4.0
  • react-bootstrap-icons ^1.10.2
  • react-dom ^18.2.0
  • react-i18next ^12.0.0
  • react-mapbox-gl ^5.1.1
  • react-phone-number-input ^3.2.12
  • react-router-dom ^6.4.3
  • sha1 ^1.1.1
  • styled-components ^5.3.6
  • typescript ^4.8.4
  • web-vitals ^2.1.4
web/yarn.lock npm
  • 1510 dependencies
.github/workflows/frontend-deployment-dev.yml actions
  • actions/cache v1 composite
  • actions/checkout v3 composite
  • actions/setup-node v3 composite
  • aws-actions/amazon-ecr-login v1 composite
  • aws-actions/configure-aws-credentials v1 composite
.github/workflows/frontend-deployment-prod.yml actions
  • actions/cache v1 composite
  • actions/checkout v3 composite
  • actions/setup-node v3 composite
  • aws-actions/configure-aws-credentials v1 composite
backend/services/Dockerfile docker
  • node 16-alpine build
docker-compose-image.yml docker
  • 302213478610.dkr.ecr.us-east-1.amazonaws.com/carbon-services latest
  • 302213478610.dkr.ecr.us-east-1.amazonaws.com/carbon-web latest
  • postgres latest
docker-compose.yml docker
  • postgres latest
web/Dockerfile docker
  • nginx stable-alpine build
  • node 16-alpine build
backend/services/package.json npm
  • @nestjs/cli ^9.0.0 development
  • @nestjs/schematics ^9.0.0 development
  • @nestjs/testing ^9.0.0 development
  • @types/express ^4.17.13 development
  • @types/jest 28.1.8 development
  • @types/node ^16.0.0 development
  • @types/passport-jwt ^3.0.7 development
  • @types/passport-local ^1.0.34 development
  • @types/supertest ^2.0.11 development
  • @typescript-eslint/eslint-plugin ^5.0.0 development
  • @typescript-eslint/parser ^5.0.0 development
  • eslint ^8.0.1 development
  • eslint-config-prettier ^8.3.0 development
  • eslint-plugin-prettier ^4.0.0 development
  • jest 28.1.3 development
  • prettier ^2.3.2 development
  • serverless ^3.25.1 development
  • serverless-offline ^12.0.4 development
  • serverless-plugin-optimize ^4.2.1-rc.1 development
  • serverless-plugin-typescript ^2.1.4 development
  • serverless-ssm-fetch ^2.0.0 development
  • source-map-support ^0.5.20 development
  • supertest ^6.1.3 development
  • ts-jest 28.0.8 development
  • ts-loader ^9.2.3 development
  • ts-node ^10.0.0 development
  • tsconfig-paths 4.1.0 development
  • typescript ^4.7.4 development
  • @aws-sdk/client-qldb ^3.209.0
  • @aws-sdk/client-qldb-session ^3.204.0
  • @casl/ability ^6.3.2
  • @drdgvhbh/postgres-error-codes ^0.0.6
  • @nestjs/common ^9.0.0
  • @nestjs/config ^2.2.0
  • @nestjs/core ^9.0.0
  • @nestjs/jwt ^10.0.0
  • @nestjs/passport ^9.0.0
  • @nestjs/platform-express ^9.0.0
  • @nestjs/swagger ^6.1.3
  • @nestjs/typeorm ^9.0.1
  • @undp/carbon-credit-calculator ../../libs/carbon-credit-calculator
  • @undp/serial-number-gen ../../libs/serial-number-gen
  • amazon-qldb-driver-nodejs ^3.0.1
  • aws-kinesis-agg ^4.2.6
  • aws-lambda ^1.0.7
  • aws-serverless-express ^3.4.0
  • axios ^1.2.4
  • class-transformer ^0.5.1
  • class-validator ^0.14.0
  • dotenv-flow ^3.2.0
  • fs ^0.0.1-security
  • ion-js ^4.3.0
  • jsbi ^4.3.0
  • nanoid 3.3.4
  • nest-winston ^1.8.0
  • nestjs-i18n ^10.2.6
  • nodemailer ^6.8.0
  • passport ^0.6.0
  • passport-headerapikey ^1.2.2
  • passport-jwt ^4.0.0
  • passport-local ^1.0.0
  • pg ^8.8.0
  • reflect-metadata ^0.1.13
  • rimraf ^3.0.2
  • rxjs ^7.2.0
  • typeorm ^0.3.10
  • winston ^3.8.2
backend/services/yarn.lock npm
  • 1477 dependencies

Score: 11.587216277550478