mirror of
https://github.com/anchore/syft.git
synced 2025-11-21 18:33:18 +01:00
* add kernel handler Signed-off-by: Avi Deitcher <avi@deitcher.net> * [wip] combine kernel and kernel module cataloging Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * [wip] combine kernel and kernel module cataloging Signed-off-by: Alex Goodman <alex.goodman@anchore.com> Signed-off-by: Avi Deitcher <avi@deitcher.net> * rename Kernel package to LinuxKernel package Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * split kernel and module packages within cataloger Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * wire up application configuration with kernel cataloger options Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * dont use references for packages on relationships Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix linting and tests Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * kernel cataloger should be resistent to partial failure Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * log upon kernel module metadata missing Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add tests for linux kernel cataloger Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update integration tests Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update cli package test counts Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add evidence annotations for kernel packages Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * reduce noise in cli test output Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * missed cli test to reduce noise for Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix package counts Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update docs with linux kernel cataloging refs Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * bump json schema with new metadata fields Signed-off-by: Alex Goodman <alex.goodman@anchore.com> --------- Signed-off-by: Avi Deitcher <avi@deitcher.net> Signed-off-by: Alex Goodman <alex.goodman@anchore.com> Signed-off-by: <> Co-authored-by: Alex Goodman <alex.goodman@anchore.com>
200 lines
6.5 KiB
Go
200 lines
6.5 KiB
Go
/*
|
|
Package cataloger provides the ability to process files from a container image or file system and discover packages
|
|
(gems, wheels, jars, rpms, debs, etc). Specifically, this package contains both a catalog function to utilize all
|
|
catalogers defined in child packages as well as the interface definition to implement a cataloger.
|
|
*/
|
|
package cataloger
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/anchore/syft/internal/log"
|
|
"github.com/anchore/syft/syft/pkg"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/alpm"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/apkdb"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/binary"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/cpp"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/dart"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/deb"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/dotnet"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/elixir"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/erlang"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/golang"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/haskell"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/java"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/javascript"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/kernel"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/nix"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/php"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/portage"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/python"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/rpm"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/ruby"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/rust"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/sbom"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/swift"
|
|
)
|
|
|
|
const AllCatalogersPattern = "all"
|
|
|
|
// ImageCatalogers returns a slice of locally implemented catalogers that are fit for detecting installations of packages.
|
|
func ImageCatalogers(cfg Config) []pkg.Cataloger {
|
|
return filterCatalogers([]pkg.Cataloger{
|
|
alpm.NewAlpmdbCataloger(),
|
|
ruby.NewGemSpecCataloger(),
|
|
python.NewPythonPackageCataloger(),
|
|
php.NewComposerInstalledCataloger(),
|
|
javascript.NewPackageCataloger(),
|
|
deb.NewDpkgdbCataloger(),
|
|
rpm.NewRpmDBCataloger(),
|
|
java.NewJavaCataloger(cfg.Java()),
|
|
java.NewNativeImageCataloger(),
|
|
apkdb.NewApkdbCataloger(),
|
|
golang.NewGoModuleBinaryCataloger(cfg.Go()),
|
|
dotnet.NewDotnetDepsCataloger(),
|
|
portage.NewPortageCataloger(),
|
|
nix.NewStoreCataloger(),
|
|
sbom.NewSBOMCataloger(),
|
|
binary.NewCataloger(),
|
|
kernel.NewLinuxKernelCataloger(cfg.Kernel()),
|
|
}, cfg.Catalogers)
|
|
}
|
|
|
|
// DirectoryCatalogers returns a slice of locally implemented catalogers that are fit for detecting packages from index files (and select installations)
|
|
func DirectoryCatalogers(cfg Config) []pkg.Cataloger {
|
|
return filterCatalogers([]pkg.Cataloger{
|
|
alpm.NewAlpmdbCataloger(),
|
|
ruby.NewGemFileLockCataloger(),
|
|
python.NewPythonIndexCataloger(),
|
|
python.NewPythonPackageCataloger(),
|
|
php.NewComposerLockCataloger(),
|
|
javascript.NewLockCataloger(),
|
|
deb.NewDpkgdbCataloger(),
|
|
rpm.NewRpmDBCataloger(),
|
|
rpm.NewFileCataloger(),
|
|
java.NewJavaCataloger(cfg.Java()),
|
|
java.NewJavaPomCataloger(),
|
|
java.NewNativeImageCataloger(),
|
|
java.NewJavaGradleLockfileCataloger(),
|
|
apkdb.NewApkdbCataloger(),
|
|
golang.NewGoModuleBinaryCataloger(cfg.Go()),
|
|
golang.NewGoModFileCataloger(cfg.Go()),
|
|
rust.NewCargoLockCataloger(),
|
|
dart.NewPubspecLockCataloger(),
|
|
dotnet.NewDotnetDepsCataloger(),
|
|
swift.NewCocoapodsCataloger(),
|
|
cpp.NewConanCataloger(),
|
|
portage.NewPortageCataloger(),
|
|
haskell.NewHackageCataloger(),
|
|
sbom.NewSBOMCataloger(),
|
|
binary.NewCataloger(),
|
|
elixir.NewMixLockCataloger(),
|
|
erlang.NewRebarLockCataloger(),
|
|
kernel.NewLinuxKernelCataloger(cfg.Kernel()),
|
|
nix.NewStoreCataloger(),
|
|
}, cfg.Catalogers)
|
|
}
|
|
|
|
// AllCatalogers returns all implemented catalogers
|
|
func AllCatalogers(cfg Config) []pkg.Cataloger {
|
|
return filterCatalogers([]pkg.Cataloger{
|
|
alpm.NewAlpmdbCataloger(),
|
|
ruby.NewGemFileLockCataloger(),
|
|
ruby.NewGemSpecCataloger(),
|
|
python.NewPythonIndexCataloger(),
|
|
python.NewPythonPackageCataloger(),
|
|
javascript.NewLockCataloger(),
|
|
javascript.NewPackageCataloger(),
|
|
deb.NewDpkgdbCataloger(),
|
|
rpm.NewRpmDBCataloger(),
|
|
rpm.NewFileCataloger(),
|
|
java.NewJavaCataloger(cfg.Java()),
|
|
java.NewJavaPomCataloger(),
|
|
java.NewNativeImageCataloger(),
|
|
java.NewJavaGradleLockfileCataloger(),
|
|
apkdb.NewApkdbCataloger(),
|
|
golang.NewGoModuleBinaryCataloger(cfg.Go()),
|
|
golang.NewGoModFileCataloger(cfg.Go()),
|
|
rust.NewCargoLockCataloger(),
|
|
rust.NewAuditBinaryCataloger(),
|
|
dart.NewPubspecLockCataloger(),
|
|
dotnet.NewDotnetDepsCataloger(),
|
|
php.NewComposerInstalledCataloger(),
|
|
php.NewComposerLockCataloger(),
|
|
swift.NewCocoapodsCataloger(),
|
|
cpp.NewConanCataloger(),
|
|
portage.NewPortageCataloger(),
|
|
haskell.NewHackageCataloger(),
|
|
sbom.NewSBOMCataloger(),
|
|
binary.NewCataloger(),
|
|
elixir.NewMixLockCataloger(),
|
|
erlang.NewRebarLockCataloger(),
|
|
kernel.NewLinuxKernelCataloger(cfg.Kernel()),
|
|
nix.NewStoreCataloger(),
|
|
}, cfg.Catalogers)
|
|
}
|
|
|
|
func RequestedAllCatalogers(cfg Config) bool {
|
|
for _, enableCatalogerPattern := range cfg.Catalogers {
|
|
if enableCatalogerPattern == AllCatalogersPattern {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func filterCatalogers(catalogers []pkg.Cataloger, enabledCatalogerPatterns []string) []pkg.Cataloger {
|
|
// if cataloger is not set, all applicable catalogers are enabled by default
|
|
if len(enabledCatalogerPatterns) == 0 {
|
|
return catalogers
|
|
}
|
|
for _, enableCatalogerPattern := range enabledCatalogerPatterns {
|
|
if enableCatalogerPattern == AllCatalogersPattern {
|
|
return catalogers
|
|
}
|
|
}
|
|
var keepCatalogers []pkg.Cataloger
|
|
for _, cataloger := range catalogers {
|
|
if contains(enabledCatalogerPatterns, cataloger.Name()) {
|
|
keepCatalogers = append(keepCatalogers, cataloger)
|
|
continue
|
|
}
|
|
log.Infof("skipping cataloger %q", cataloger.Name())
|
|
}
|
|
return keepCatalogers
|
|
}
|
|
|
|
func contains(enabledPartial []string, catalogerName string) bool {
|
|
catalogerName = strings.TrimSuffix(catalogerName, "-cataloger")
|
|
for _, partial := range enabledPartial {
|
|
partial = strings.TrimSuffix(partial, "-cataloger")
|
|
if partial == "" {
|
|
continue
|
|
}
|
|
if hasFullWord(partial, catalogerName) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func hasFullWord(targetPhrase, candidate string) bool {
|
|
if targetPhrase == "cataloger" || targetPhrase == "" {
|
|
return false
|
|
}
|
|
start := strings.Index(candidate, targetPhrase)
|
|
if start == -1 {
|
|
return false
|
|
}
|
|
|
|
if start > 0 && candidate[start-1] != '-' {
|
|
return false
|
|
}
|
|
|
|
end := start + len(targetPhrase)
|
|
if end < len(candidate) && candidate[end] != '-' {
|
|
return false
|
|
}
|
|
return true
|
|
}
|