Skip to main content

ICS SBoM libs is a set of libraries developed by Integrated Computer Solutions (ICS) for handling Software Bill of Materials (SBoM) documentaion.

Project description

ICS SBoM Libs GitHub Actions Workflow Status REUSE status PyPI - Version PyPI - Downloads

This is re-usable python tools for working with SBoMs

Description

This project contains libraries for working with SBoMs

Installation

Most users will want to use SBOMGuard or icsbom and not these libraries directly.

Package are on pypi pip install ics-sbom-libs

Development

We suggest a workflow involving the following tools:

  • pyenv -- to manage python versions (and virtual environments on MacOS + Linux)
  • poetry -- to manage dependency resolution, installation, building, packaging, publishing, and running of the code
  • pyinstaller -- to build executables that can be ran without requiring a python installation on the target system

PYENV

Install PyEnv
  1. MacOS: brew install pyenv
  2. Ubuntu:
    % sudo apt-get install -y make build-essential libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev wget
    curl llvm libncurses5-dev libncursesw5-dev xz-utils tk-dev libffi-dev liblzma-dev python-openssl git
    % curl https://pyenv.run | bash
    ...
    # This sets up pyenv into your profile
    % echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc
    % echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc
    % echo -e 'if command -v pyenv 1>/dev/null 2>&1; then\n eval "$(pyenv init -)"\nfi' >> ~/.bashrc
    
  3. Windows: Follow instructions here
  • PowerShell: give permission to execute scripts:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope LocalMachine
  • Install pyenv
Invoke-WebRequest -UseBasicParsing -Uri 'https://raw.githubusercontent.com/pyenv-win/pyenv-win/master/pyenv-win/install-pyenv-win.ps1' -OutFile "./install-pyenv-win.ps1"; \&'./install-pyenv-win.ps1'
  • Disable Python App Installers: Start > "Manage App Execution Aliases" and turning off the "App Installer" aliases for Python
  • Pyenv only exists on MacOS and Linux - the windows version is a fork which does not support the full functionality – e.g., it does not support creating virtual envs. Consider using the linux environment on windows (e.g., cygwin), and install the original pyenv.
  • Sometimes PowerShell does not reflect the correct PATH variable (though set correctly in system env vars). In that case, set it manually:
$env:PATH='$HOME\.pyenv\pyenv-win\bin;' + $env:PATH
$env:PATH='$HOME\.pyenv\pyenv-win\shims;' + $env:PATH
Use PyEnv
  • Checking for what versions of python are available to install
pyenv install --list
  • Checking for what versions of python are installed
pyenv versions
  • Install desired python version:
pyenv install 3.11
  • Set the global python version
pyenv global 3.11
  • Set the local (dependent on directory) python version
pyenv local 3.9
  • Install pip (if it wasn’t already installed)
wget https://bootstrap.pypa.io/get-pip.py -OutFile get-pip.py
python ./get-pip.py
rm get-pip.py

POETRY

Install Poetry
  • General installation instructions here
  1. Mac:
% brew install poetry
  1. Ubuntu:
% sudo apt-get install pipx
% pipx install poetry
  1. PowerShell:
(Invoke-WebRequest -Uri https://install.python-poetry.org -UseBasicParsing).Content | python -
  • Add poetry’s bin dir to $PATH: $HOME\AppData\Roaming\Python\Scripts

Limitations of pyenv/poetry on Windows (which DO NOT EXIST ON POSIX):

  • Pyenv cannot create virtual environment
  • Pyenv does not install pip with the python version (must be installed manually)
  • Poetry must be installed with the target python version (poetry does not respect the active environment selected with pyenv; this makes pyenv almost redundant)
Use Poetry

A few important commands using poetry are:

  • Install python package: poetry install
  • Update dependencies (resolving dependencies): poetry lock
  • Run tools, e.g., black: poetry run black .
  • Build package: poetry build
  • Run a poetry script: poetry run <script_name>

Each poetry run creates a virtual environment in which the script is executed. If pyenv controls the virtual environments, poetry should be configured to not create virtual environments. In this case, poetry will respect and use the pyenv virtual environment.

NVD API Key

Downloading the NVD database into the cache can take a very long time. To help with this they have created a way to use an API key that will allow you to access the NVD database at a faster rate. You can find the instructions to receive and activate an API key here.

Once you have the API key you can copy it into the cache_dir (default: ${HOME}/.cache/icsbom) in a file called api_key.txt. Another way that you can use your API key is as an argument to the CLI tools using --api_key ${your key}.

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

ics_sbom_libs-1.3.0.tar.gz (51.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ics_sbom_libs-1.3.0-py3-none-any.whl (65.4 kB view details)

Uploaded Python 3

File details

Details for the file ics_sbom_libs-1.3.0.tar.gz.

File metadata

  • Download URL: ics_sbom_libs-1.3.0.tar.gz
  • Upload date:
  • Size: 51.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for ics_sbom_libs-1.3.0.tar.gz
Algorithm Hash digest
SHA256 e063e945d0d446119573288dea944ec35905191c055b840847a2b0ca6e5f1f3d
MD5 55a68aefa9a63416260c461b8d11acde
BLAKE2b-256 bff76a625e4304e4a60eb995623e7d750211265d2abd198f9b0702b10e557da1

See more details on using hashes here.

File details

Details for the file ics_sbom_libs-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: ics_sbom_libs-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 65.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for ics_sbom_libs-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b756aab50f575e81753044577f6e7b9b2cc2baeec10dbd24d3616a63174ebcfc
MD5 8e0d8b0f105bf4306ad0a413bb4cada7
BLAKE2b-256 5d9436abbef94d4eafe142226a3a7d98f89cd714d4cbdad56386b3bb5320dfca

See more details on using hashes here.

Supported by

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