Skip to main content

REST API on top of greenbone-scap

Project description

Greenbone Logo

greenbone-scap-api

GitHub releases PyPI release

A REST API on top of greenbone-scap based on FastAPI to mirror the NIST NVD CVE API.

It provides a very similar CVE API compared to NVD NIST at https://services.nvd.nist.gov/rest/json/cves/2.0.

Table of Contents

Requirements

Python 3.11 and later is supported.

Install using pipx

You can install the latest stable release of greenbone-scap-api from the Python Package Index (pypi) using pipx

python3 -m pipx install greenbone-scap-api

Install using pip

[!NOTE] The pip install command does no longer work out-of-the-box in newer distributions like Ubuntu 23.04 because of PEP 668. Please use the installation via pipx instead.

You can install the latest stable release of greenbone-scap-api from the Python Package Index (pypi) using pip

python3 -m pip install --user greenbone-scap-api

Usage

A simple web server to serve the API can be started by running greenbone-scap-api. The settings of the web server can be controlled via environment variables.

Internally the greenbone-scap-api script uses uvicorn

It's also possible to serve the API with uvicorn directly

uvicorn greenbone.scap.api.app:app --reload

Using uvicorn directly allows for more flexibility regarding the settings for serving the API.

After starting the web server the CVE API is available at http://127.0.0.1:8000/cves (by default). Interactive API docs are served at http://127.0.0.1:8000/docs.

Settings

greenbone-scap-api can be configured via the following environment variables

Name Description Default
DATABASE_USER Username for the connection to the PostgreSQL database. scap
DATABASE_PASSWORD Username for the connection to the PostgreSQL database.
DATABASE_NAME Name of the PostgreSQL database. scap
DATABASE_HOST Host where the PostgreSQL database is running. IP or DNS name. 127.0.0.1
DATABASE_PORT Port on which the PostgreSQL database is listening. 5432
ECHO_SQL Log SQL statements. true or 1 to enable. disabled
API_HOST IP address or DNS name to listen on 127.0.0.1
API_PORT Port to listen on 8000
LOG_LEVEL Log level for server output. Options are critical, error, warning, info, debug and trace. info

Docker Compose

The API is easiest to use via the provided docker compose file. The compose file extends the compose file of greenbone-scap. Please take a look at the README of greenbone-scap for the initial setup of the containers.

For a quick setup the following commands can be used:

cd docker
echo "DATABASE_PASSWORD=my-super-safe-password" > .env
docker compose up

After starting the containers the CVE API is available at http://127.0.0.1:8000/cves (by default). Interactive API docs are served at http://127.0.0.1:8000/docs.

[!NOTE] On the initial startup all CVE will be downloaded from the NIST NVD CVE API Downloading the data may take several hours and due to unreliable servers at NIST may even fail. After a successful full download of the data at NIST, only the changed and new CVEs will be downloaded. To trigger a download docker compose up cve can be used.

Development

greenbone-scap-api uses poetry for its own dependency management and build process.

First install poetry via pipx

python3 -m pipx install poetry

Afterwards run

poetry install

in the checkout directory of greenbone-scap-api (the directory containing the pyproject.toml file) to install all dependencies including the packages only required for development.

Afterwards activate the git hooks for auto-formatting and linting via autohooks.

poetry run autohooks activate

Validate the activated git hooks by running

poetry run autohooks check

Maintainer

This project is maintained by Greenbone AG

License

Copyright (C) 2024 Greenbone AG

Licensed under the GNU Affero General Public License v3.0 or later.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

greenbone_scap_api-25.3.1.tar.gz (23.3 kB view details)

Uploaded Source

Built Distribution

greenbone_scap_api-25.3.1-py3-none-any.whl (25.1 kB view details)

Uploaded Python 3

File details

Details for the file greenbone_scap_api-25.3.1.tar.gz.

File metadata

  • Download URL: greenbone_scap_api-25.3.1.tar.gz
  • Upload date:
  • Size: 23.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.10

File hashes

Hashes for greenbone_scap_api-25.3.1.tar.gz
Algorithm Hash digest
SHA256 9e756552ab88203ffc67b0719efc4b31172d8c445e0d41be8f62d5c7ad40792e
MD5 195cea5e91a6c7d10b5b6cf919e2e6b9
BLAKE2b-256 79bf3811b2394913ca300379aafc96f395bdb5163e6b57825be20add6ab33407

See more details on using hashes here.

Provenance

The following attestation bundles were made for greenbone_scap_api-25.3.1.tar.gz:

Publisher: deploy-pypi.yml on greenbone/greenbone-scap-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file greenbone_scap_api-25.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for greenbone_scap_api-25.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 de183f94d93a4c00221ef17b25ec6ce17e95780d11ca6f3967dd111766da5bff
MD5 ca63eebfc0cae38bfe45b6d4fa88ffe2
BLAKE2b-256 6da78428d83fb944f1cd736708663842326f0ca0dde07d1e79220b6aa291442e

See more details on using hashes here.

Provenance

The following attestation bundles were made for greenbone_scap_api-25.3.1-py3-none-any.whl:

Publisher: deploy-pypi.yml on greenbone/greenbone-scap-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page