Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Only take top-level binary dependencies into account for BOM generation #124

Merged
merged 1 commit into from
Aug 14, 2024

Conversation

hertrste
Copy link

@hertrste hertrste commented Jul 29, 2024

The current sbom generation for a rust project like e.g. the cloud hypervisor also contains dependencies that are test or development only. In general, we do not care about those dev dependencies. These dependencies get included because bombon collects the *.cdx.json files in all subfolders and not only of relevant binaries.

A potential fix is to change the cyclone dx invocation to only generate the bom for top-level binaries that will be a result of the rust crate.

This MR is more of a discussion basis and there are some questions to resolve:

  • Is this a valid solution?
  • Should the behavior be the default or does the user have to configure it?
  • What about library crates?

Following is an example bom for the cloud hypervisor project before and after the change:

@blitz

@hertrste hertrste force-pushed the fix-rust-dependencies branch from 92ebe66 to 2080087 Compare July 29, 2024 10:54
@nikstur
Copy link
Owner

nikstur commented Jul 29, 2024

cc @thillux

@nikstur
Copy link
Owner

nikstur commented Jul 29, 2024

This might also be related/relevant for the discussion: CycloneDX/cyclonedx-rust-cargo#755

@thillux
Copy link
Contributor

thillux commented Jul 29, 2024

I guess this is only sufficient if a Rust workspace has lets say 3 binary crates in its repository and you use all of them. What about the 1 out of 3 or 2 out of 3 case?

@hertrste
Copy link
Author

I guess this is only sufficient if a Rust workspace has lets say 3 binary crates in its repository and you use all of them. What about the 1 out of 3 or 2 out of 3 case?

That is true. But it's the same in the current state of bombon + you get all the dev dependencies currently?

I think handling your 1/3 or 2/3 use cases is only possible if the user is able to specify the names of the binary dependencies explicitly e.g. as arguments to the passthruVendoredSbom.rust function.

@blitz
Copy link
Contributor

blitz commented Jul 29, 2024

I think handling your 1/3 or 2/3 use cases is only possible if the user is able to specify the names of the binary dependencies explicitly e.g. as arguments to the passthruVendoredSbom.rust function.

In general, the BOM should only include the dependencies of the binaries that are actually installed, shouldn't it? This coincides with all the top-level binary BOMs that cargo-cyclonedx produces. If people select a different set of binaries to install that will require manual configuration. Also if someone installs libraries.

I'm also ok with overestimating the SBOM by including everything and adding a config option. YMMV.

@thillux @nikstur Do you have a preference? We (Cyberus) can provide a patch either way.

Copy link
Owner

@nikstur nikstur left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm fine with describing just the binaries since that's the thing you're usually concerned with. Collecting SBOMs for libs doesn't really make sense for Rust dependencies in Nix as cargo usually takes care of handling the libraries (and thus cargo-cyclonedx will find them correctly without help from Nix).

bombon makes a configurable distinction between runtime (the things that end up in the Nix closure) and buildtime dependencies (everything else). We should uphold this if possible. This might mean that we should run cargo-cyclonedx twice: once without --describe, to collect builtime dependencies and once with --describe binaries to collect the runtime dependenies. The transformer can the decide (based on the passed parameter) which SBOMs to merge into the final SBOM.

nix/passthru-vendored.nix Outdated Show resolved Hide resolved
@hertrste hertrste force-pushed the fix-rust-dependencies branch from 2080087 to 3b7e038 Compare July 31, 2024 12:57
@hertrste
Copy link
Author

hertrste commented Aug 1, 2024

bombon makes a configurable distinction between runtime (the things that end up in the Nix closure) and buildtime dependencies (everything else). We should uphold this if possible. This might mean that we should run cargo-cyclonedx twice: once without --describe, to collect builtime dependencies and once with --describe binaries to collect the runtime dependenies. The transformer can the decide (based on the passed parameter) which SBOMs to merge into the final SBOM.

It looks like currently the passthruVendoredSbom does not make a difference between runtime and buildtime. How would you like to have those reported separately?

@blitz
Copy link
Contributor

blitz commented Aug 1, 2024

@nikstur Not passing --describe binaries doesn't give you the build time dependencies. It gives you all dependencies, even those not used for build or runtime. So I don't see how this is relevant.

Do you think we should set up a quick call to discuss this?

Previously, the SBOm would contain all dependencies of the Rust
program, including development dependencies that are irrelevant for
the installed software.

Now we check which binaries actually get installed and only consider
the dependencies of those.
@hertrste hertrste force-pushed the fix-rust-dependencies branch from 3b7e038 to a00be5c Compare August 13, 2024 13:58
@blitz
Copy link
Contributor

blitz commented Aug 13, 2024

@nikstur The PR is updated!

@nikstur nikstur merged commit c84ac58 into nikstur:main Aug 14, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants