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

fix(java): add flag for java scan options #6375

Closed

Conversation

DmitriyLewen
Copy link
Contributor

@DmitriyLewen DmitriyLewen commented Mar 22, 2024

Description

After #6171, increased Trivy runtime for pom.xml files.
This is due to repositories which contains in pom.xml files, but don't contain dependencies (e.g. when we try to find release dependencies, but repository only contains snapshot dependencies).

To avoid this, we add new flag - java-scan-options.
This flag is required to set options to scan java files:

  • trivy-java-db - to allow the use of trivy-java-db when scanning jar files (without this flag Trivy doesn't download/use trivy-java-db).
  • maven-central to enable maven central as repository to search dependencies, if local cache doesn't contain them.
  • releases - to enable release repositories for pom.xml files.
  • snapshots - to enable snapshot repositories for pom.xml files.
  • offline1 - to disable all previous options.
    • With this option Trivy doesn't use trivy-java-db (take GAV2 only from pom.properties and MANIFEST.MF files).
    • Also Trivy checks only local cache directory to detect dependencies of pom.xml files.

By default we enable trivy-java-db and maven-central options (as it was before #6171).

Warning

This PR marks the --offline-scan flag as deprecated. --java-scan-options offline should be used instead of the flag.

Related issues

Related PRs

Checklist

  • I've read the guidelines for contributing to this repository.
  • I've followed the conventions in the PR title.
  • I've added tests that prove my fix is effective or that my feature works.
  • I've updated the documentation with the relevant information (if needed).
  • I've added usage information (if the PR introduces new options)
  • I've included a "before" and "after" example to the description (if the PR is a user interface change).

Footnotes

  1. This option replace --offline-scan flag.

  2. GroupID, ArtifactID and Version of artifact.

@DmitriyLewen DmitriyLewen changed the title fix(java): add flag for java repository options fix(java): add flag for java remote options Mar 22, 2024
@DmitriyLewen DmitriyLewen changed the title fix(java): add flag for java remote options fix(java): add flag for java scan options Mar 25, 2024
@DmitriyLewen DmitriyLewen self-assigned this Mar 25, 2024
@DmitriyLewen DmitriyLewen marked this pull request as ready for review March 25, 2024 07:50
@DmitriyLewen DmitriyLewen requested a review from knqyf263 as a code owner March 25, 2024 07:50
@knqyf263
Copy link
Collaborator

This is due to repositories which contains in pom.xml files, but don't contain dependencies (e.g. when we try to find release dependencies, but repository only contains snapshot dependencies).

Could you give me an example? Maven works in the same way, no? Why is Trivy so slow?

@DmitriyLewen
Copy link
Contributor Author

@knqyf263
When I started making an example for you, I doubted this PR.
It looks like I've made a difficult decision again.

I'm exploring the Maven repository.
If I understand correctly - they separate snapshot and release repositories and use them for snapshots and other artifacts.
I created #6412 to reproduce this logic.
Sorry to waste your time on this PR.

@DmitriyLewen
Copy link
Contributor Author

Closed in favor of #6412

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.

0.50.0 : big time increase of FS scanning vs 0.49.1
2 participants