mirror of
https://github.com/anchore/syft.git
synced 2025-11-17 16:33:21 +01:00
* remove existing spdxjson presenter + helpers Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add new spdx22json format Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add common sdpxhelpers (migrated) Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * use new common spdx helpers Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * wire up new spdx22json format object Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * remove lossless syft-specific property bags Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * remove spdxjson decoder and validator Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add nil checks in spdx test helpers Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * remove empty default case Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * use explicit golden snapshot Signed-off-by: Alex Goodman <alex.goodman@anchore.com>
44 lines
1.1 KiB
Go
44 lines
1.1 KiB
Go
package spdxhelpers
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/anchore/syft/syft/pkg"
|
|
)
|
|
|
|
func SourceInfo(p *pkg.Package) string {
|
|
if !packageExists(p) {
|
|
return ""
|
|
}
|
|
|
|
answer := ""
|
|
switch p.Type {
|
|
case pkg.RpmPkg:
|
|
answer = "acquired package info from RPM DB"
|
|
case pkg.ApkPkg:
|
|
answer = "acquired package info from APK DB"
|
|
case pkg.DebPkg:
|
|
answer = "acquired package info from DPKG DB"
|
|
case pkg.NpmPkg:
|
|
answer = "acquired package info from installed node module manifest file"
|
|
case pkg.PythonPkg:
|
|
answer = "acquired package info from installed python package manifest file"
|
|
case pkg.JavaPkg, pkg.JenkinsPluginPkg:
|
|
answer = "acquired package info from installed java archive"
|
|
case pkg.GemPkg:
|
|
answer = "acquired package info from installed gem metadata file"
|
|
case pkg.GoModulePkg:
|
|
answer = "acquired package info from go module information"
|
|
case pkg.RustPkg:
|
|
answer = "acquired package info from rust cargo manifest"
|
|
default:
|
|
answer = "acquired package info from the following paths"
|
|
}
|
|
var paths []string
|
|
for _, l := range p.Locations {
|
|
paths = append(paths, l.RealPath)
|
|
}
|
|
|
|
return answer + ": " + strings.Join(paths, ", ")
|
|
}
|