Skip to content

Latest commit

 

History

History
48 lines (36 loc) · 5.92 KB

README.md

File metadata and controls

48 lines (36 loc) · 5.92 KB

TrivyDepsFalsePositive

This repo exists as a minimal example to illustrate what I believe to be a false positive flag in Trivy, based upon a misunderstanding of how dependencies are managed in .NET. It's motivated by aquasecurity/trivy#2706. I've posted a link to this repo here aquasecurity/trivy#4282 (comment)

In this illustration, Trivy highlights two vulnerabilities on our example image, with the following output:

App/TrivyDepsJsonFalsePositive.deps.json (dotnet-core)
======================================================
Total: 2 (UNKNOWN: 0, LOW: 0, MEDIUM: 0, HIGH: 2, CRITICAL: 0)

┌────────────────────────────────┬───────────────┬──────────┬────────┬───────────────────┬───────────────┬───────────────────────────────────────────────────────────┐
│            Library             │ Vulnerability │ Severity │ Status │ Installed Version │ Fixed Version │                           Title                           │
├────────────────────────────────┼───────────────┼──────────┼────────┼───────────────────┼───────────────┼───────────────────────────────────────────────────────────┤
│ System.Net.Http                │ CVE-2018-8292 │ HIGH     │ fixed  │ 4.3.0             │ 4.3.4         │ .NET Core: information disclosure due to authentication   │
│                                │               │          │        │                   │               │ information exposed in a redirect...                      │
│                                │               │          │        │                   │               │ https://avd.aquasec.com/nvd/cve-2018-8292                 │
├────────────────────────────────┼───────────────┤          │        │                   ├───────────────┼───────────────────────────────────────────────────────────┤
│ System.Text.RegularExpressions │ CVE-2019-0820 │          │        │                   │ 4.3.1         │ dotnet: timeouts for regular expressions are not enforced │
│                                │               │          │        │                   │               │ https://avd.aquasec.com/nvd/cve-2019-0820                 │
└────────────────────────────────┴───────────────┴──────────┴────────┴───────────────────┴───────────────┴───────────────────────────────────────────────────────────┘

In order to reproduce this output, run RunTrivy.sh.

I've simulated this scenario by referencing a single dependency - xunit v2.6.2. This library tries to be as permissive as possible, so sets a minimum .NET Standard version of 1.6. System.Net.Http and System.Text.RegularExpressions enter the fold via this transitive dependency. I've used this example because if you look over at the xunit project, it's flooded with people raising issues for these exact violations (and that's how I became aware of this problem). But I'm sure similar things are happening for other library maintainers that set low minimum .NET Standard versions.

In /bin/Release/net6.0/publish, the *.deps.json file does indeed feature references to System.Net.Http v4.3.0 and System.Text.RegularExpressions v4.3.0. But this does not mean these are the versions that will be used at runtime. Others have called this out in aquasecurity/trivy#2706 (comment)

Indeed neither dll exist under /bin/Release/net6.0/publish, nor under /App within the core-counter container.

In fact, on the container, the only reference to them is under /usr/share/dotnet/shared/Microsoft.NETCore.App/6.0.25/ - try find / | grep "System.Net.Http.dll" - i.e. using the version that comes with the runtime.

It's not sufficient to do a simple scan of the *.deps.json folder looking for vulnerable packages. What's there needs to be interpreted within the framing of the runtime that's targeted.

We can appease Trivy by 'pinning' to a 'secure' version of the library dotnet add package System.Net.Http -v 4.3.4. If we re-run RunTrivy.sh:

  • Trivy no longer emits a vulnerability for System.Net.Http.
  • v4.3.0 still appears in the *.deps.json file. But the entry under "NETStandard.Library/1.6.1" changes to v4.3.4 - I suspect this is the difference Trivy cares about.
  • Still no System.Net.Http.dll in the output folder (locally or in the container).
  • We still use the runtime version.

The problem with getting around Trivy in this way is that we've now we've taken this incredibly confusing artificial dependency, which we then need to document the lifecycle of within our project. Or we need to need to filter Trivy's output, which is also far from ideal.