SBOMgensbomgen

Creating SBOMs from PHP projects

Introduction

This tutorial illustrates how to produce an SBOM from PHP Composer projects using the Cyclonedx-PHP-Composer CLI.

Requirements

Installation

Run the command:

composer global require cyclonedx/cyclonedx-php-composer

Verify installation with the command:

composer CycloneDX:make-sbom --help

You should get the resultant output:

Description:
  Generate a CycloneDX Bill of Materials from a PHP Composer project.

Usage:
  CycloneDX:make-sbom [options] [--] [<composer-file>]

Arguments:
  composer-file                                       Path to Composer config file.
                                                      [default: "composer.json" file in current working directory]

Options:
      --output-format=OUTPUT-FORMAT                   Which output format to use.
                                                      {choices: "JSON", "XML"} [default: "XML"]
      --output-file=OUTPUT-FILE                       Path to the output file.
                                                      Set to "-" to write to STDOUT [default: "-"]
      --omit=OMIT                                     Omit dependency types.
                                                      {choices: "dev", "plugin"} (multiple values allowed)
      --spec-version=SPEC-VERSION                     Which version of CycloneDX spec to use.
                                                      {choices: "1.1", "1.2", "1.3", "1.4", "1.5"} [default: "1.4"]
      --output-reproducible|--no-output-reproducible  Whether to go the extra mile and make the output reproducible.
                                                      This might result in loss of time- and random-based-values.
      --validate|--no-validate                        Formal validate the resulting BOM.
      --mc-version=MC-VERSION                         Version of the main component.
                                                      This will override auto-detection.
  -h, --help                                          Display help for the given command. When no command is given display help for the list command
  -q, --quiet                                         Do not output any message
  -V, --version                                       Display this application version
      --ansi|--no-ansi                                Force (or disable --no-ansi) ANSI output
  -n, --no-interaction                                Do not ask any interactive question
      --profile                                       Display timing and memory usage information
      --no-plugins                                    Whether to disable plugins.
      --no-scripts                                    Skips the execution of all scripts defined in composer.json file.
  -d, --working-dir=WORKING-DIR                       If specified, use the given directory as working directory.
      --no-cache                                      Prevent use of the cache
  -v|vv|vvv, --verbose                                Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug 

Usage

Run the command:

composer CycloneDX:make-sbom <composer.json-file> --output-format=<output-format> --output-file=<filepath-to-sbom-name>.<output-format> --spec-version=<cyclonedx-specversion>

The resulting SBOM of your set filename, format and cyclonedx specversion will appear in the path designated.

Notes

Example SBOM

The following section illustrates a CycloneDX JSON SBOM of the project FreshRSS, created by CycloneDX-PHP-Composer.

Pretty JSON Display

freshrss


    

References