Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Describe multiple SBOM scan targets #562

Open
wagoodman opened this issue Oct 16, 2021 · 0 comments
Open

Describe multiple SBOM scan targets #562

wagoodman opened this issue Oct 16, 2021 · 0 comments
Labels
enhancement New feature or request multiple-sources Issues that are dependent on supporting multiple sources

Comments

@wagoodman
Copy link
Contributor

wagoodman commented Oct 16, 2021

What would you like to be added:
Be able to specify multiple targets that where one or more SBOMs are created. Take the following examples for illustrative purposes:

# syft.yaml

inputs:
- type: image
  id: my-image-sbom
  value: docker.io/me/my-image:latest
  format: spdxjson
  
- type: directory
  id: my-source-sbom
  value: ./src
  format: spdx

This would allow for scanning an artifact and source and produce two different sboms, such that in CI invocation would simply be:

# syft.yaml is automatically assumed...
syft
# ...output "my-image-sbom.json" and "my-source-sbom.spdx" files

You could combine the output from multiple cataloging efforts into the same SBOM by using the same id for each input:

# syft.yaml

inputs:
- type: image
  id: my-sbom
  root-package: container
  value: docker.io/me/my-image:latest
  format: spdxjson
  
- type: directory
  root-package: source
  id: my-sbom
  value: ./src

Where the result would be a single my-sbom.json in the spdxjson output. Additionally, anything found in the container will have a relationship tied to a phantom "container" package and anything in the source scanning would have a relationship to a phantom "source" package.

I'm not 100% in love with the proposed format above as it would be easy to abuse when it comes to combining incompatible formats, but it suits for illustrative purposes.

We could surface a small set of this functionality via the CLI by allowing for multiple scan targets:

syft  dir:./  image:docker.io/me/my-image:latest -o spdxjson

Why is this needed:
For more complicated workflows it would be ideal to encode what needs to be cataloged into a description instead of relying on the consumer to orchestrate multiple syft calls with bash.

Additionally there is no way to deal with "multiple" SBOMs with syft, or grouping related items with relationships, which could be a powerful pattern.

@wagoodman wagoodman added the enhancement New feature or request label Oct 16, 2021
@wagoodman wagoodman added this to the Stabilize user surfaces milestone Oct 19, 2021
@wagoodman wagoodman added the I/O Describes bug or enhancement around application input or output label Dec 22, 2021
@wagoodman wagoodman removed this from the Stabilize user surfaces milestone Apr 4, 2022
@wagoodman wagoodman added this to OSS Feb 7, 2024
@wagoodman wagoodman added multiple-sources Issues that are dependent on supporting multiple sources and removed I/O Describes bug or enhancement around application input or output labels Aug 12, 2024
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
enhancement New feature or request multiple-sources Issues that are dependent on supporting multiple sources
Projects
Status: No status
Development

No branches or pull requests

1 participant