-
Notifications
You must be signed in to change notification settings - Fork 2.4k
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
Analyzer support for git-based dependencies #3067
Comments
Sorry for the ping again here, just wondering if these types of analyzers is something you'd consider for core trivy, or if you think it's better to have them as some kind of community plugins? :) |
Also related: #3662 |
This issue is stale because it has been labeled with inactivity. |
Still relevant but let's wait and see what the outcome of #3345 (comment) is eventually. |
This issue is stale because it has been labeled with inactivity. |
For anyone following, I'll probably try to convert the existing PRs into a community plugin when I find some time, as they are unlikely to make it into upstream repos I think from what I can tell. |
@nejch I think this is something that we will be happy to see incorporated in Trivy eventually (at least the git submodule). I realize this has been dragging along for too long, I'll try to see if we can give this more attention in the next release |
I'd like to clarify your use case if you don't mind. I'm assuming you use Trivy to find vulnerabilities in code (C code by the sound of it). But even if Trivy detects a git submodule dependency (as suggested here), it won't detect a vulnerability in it. because:
|
Thanks a lot for the response @itaysk! As I might have mentioned above or in the PR, I see value already in being able to produce a standard CycloneDX SBOM with these generic dependencies, even if trivy itself is not aware of vulnerabilities associated with them. Just like trivy itself can analyze an SBOM, other tools can provide their own analyses potentially. But even just including them is a win for me as it would increase visibility in the software supply chain. Rather than trying to classify them as a language (it might be mixed in a submodule), I'd treat them more like the existing non-packaged deps in https://github.com/aquasecurity/trivy/blob/main/pkg/fanal/analyzer/const.go#L93. Does that make sense? There are other analyzers that currently also only support SBOM generation - see https://github.com/aquasecurity/trivy/blob/main/pkg/detector/library/driver.go#L63. |
I think it makes sense. to treat git submodules as dependencies. I'll wait for @knqyf263 for his feedback. |
Hey people, I'd like to add support for a few types of analyzers and parsers that all intersect a bit, so would like to get some feedback first.
.gitmodules
, but version info is retrieved from the.git/index
binary viagit submodule status
(this matters, see below)kas-*.yml
,kas/**.yml
(convention)include:project:
keyword, possibly laterinclude:remote
).gitlab-ci.yml
,.gitlab/ci/**.yml
(convention)image:
.gitlab-ci.yml
,.gitlab/ci/**.yml
(convention)include:
aboveMy use case is mostly for SBOM creation, but could be useful for vulnerabilities as well. Imagine a GitLab project that builds in CI in a Debian container using
image:
, uses an external pipeline template usinginclude:
, pulls in a boost library via a submodule and a yocto layer via kasrepo:
. Silly example, but I know projects covering 3 out of 4 here in a single repo. It could also be used to detect tokens committed to git URLs accidentally perhaps.I have a rough but working draft including some testing for the first three, but before opening PRs I would like to clarify a few things
First, for kas, gitlab-ci includes, and gitlab-ci docker images, we are parsing a yaml file, so this could IMO be done in
go-dep-parser
. As they are technically not a "language" parser, would they need special namespacing likeframeworks/wordpress
? Maybe something like this:For git submodules, since we're not analyzing a file but a command (well, via
go-git
), I think the parser would need to stay in trivy itself, like for example,apk
packages. Also, trivy already has go-git as a dependency. How would the analyzers then be placed? Maybe something like:I'm not sure if this is the best way, especially for
image:
as it might be similar to future analyzers that use the same data source (#1984), so/docker/
might make more sense for that. Just want to start somewhere. Some other managers also take git deps (e.g. go, ansible-galaxy,...) so it's all a bit of gray zone. 😁Ok this is a bit of a wall of text - but thanks in advance for any feedback! ❤️ I'll start opening draft PRs referencing this issue in the coming days for consistency.
Edit: I just noticed #3019 by @knqyf263 might also be relevant here as it deals with another kind of generic type of dependency.
The text was updated successfully, but these errors were encountered: