feat(detector, contrib/trivy-to-vuls): collect vendor severity and cvss (#1921)

This commit is contained in:
MaineK00n
2024-05-17 19:11:51 +09:00
committed by GitHub
parent e4728e3881
commit 878c25bf5a
6 changed files with 800 additions and 28 deletions

View File

@@ -5,6 +5,7 @@ import (
"sort"
"time"
trivydbTypes "github.com/aquasecurity/trivy-db/pkg/types"
ftypes "github.com/aquasecurity/trivy/pkg/fanal/types"
"github.com/aquasecurity/trivy/pkg/types"
@@ -68,16 +69,35 @@ func Convert(results types.Results) (result *models.ScanResult, err error) {
lastModified = *vuln.LastModifiedDate
}
vulnInfo.CveContents = models.CveContents{
models.Trivy: []models.CveContent{{
Cvss3Severity: vuln.Severity,
References: references,
for source, severity := range vuln.VendorSeverity {
vulnInfo.CveContents[models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source))] = append(vulnInfo.CveContents[models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source))], models.CveContent{
Type: models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source)),
CveID: vuln.VulnerabilityID,
Title: vuln.Title,
Summary: vuln.Description,
Cvss3Severity: trivydbTypes.SeverityNames[severity],
Published: published,
LastModified: lastModified,
}},
References: references,
})
}
for source, cvss := range vuln.CVSS {
vulnInfo.CveContents[models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source))] = append(vulnInfo.CveContents[models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source))], models.CveContent{
Type: models.CveContentType(fmt.Sprintf("%s:%s", models.Trivy, source)),
CveID: vuln.VulnerabilityID,
Title: vuln.Title,
Summary: vuln.Description,
Cvss2Score: cvss.V2Score,
Cvss2Vector: cvss.V2Vector,
Cvss3Score: cvss.V3Score,
Cvss3Vector: cvss.V3Vector,
Published: published,
LastModified: lastModified,
References: references,
})
}
// do only if image type is Vuln
if isTrivySupportedOS(trivyResult.Type) {
pkgs[vuln.PkgName] = models.Package{