mirror of
https://github.com/anchore/syft.git
synced 2026-02-12 10:36:45 +01:00
* Add ability to extend the binaries cataloguers Signed-off-by: Laurent Goderre <laurent.goderre@docker.com> * restrict binary classifier package attributes Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com> --------- Signed-off-by: Laurent Goderre <laurent.goderre@docker.com> Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com> Co-authored-by: Alex Goodman <wagoodman@users.noreply.github.com>
58 lines
1.1 KiB
Go
58 lines
1.1 KiB
Go
package binary
|
|
|
|
import (
|
|
"reflect"
|
|
|
|
"github.com/anchore/packageurl-go"
|
|
"github.com/anchore/syft/syft/cpe"
|
|
"github.com/anchore/syft/syft/file"
|
|
"github.com/anchore/syft/syft/pkg"
|
|
)
|
|
|
|
var emptyPURL = packageurl.PackageURL{}
|
|
|
|
func newPackage(classifier Classifier, location file.Location, matchMetadata map[string]string) *pkg.Package {
|
|
version, ok := matchMetadata["version"]
|
|
if !ok {
|
|
return nil
|
|
}
|
|
|
|
update := matchMetadata["update"]
|
|
|
|
var cpes []cpe.CPE
|
|
for _, c := range classifier.CPEs {
|
|
c.Version = version
|
|
c.Update = update
|
|
cpes = append(cpes, c)
|
|
}
|
|
|
|
p := pkg.Package{
|
|
Name: classifier.Package,
|
|
Version: version,
|
|
Locations: file.NewLocationSet(
|
|
location.WithAnnotation(pkg.EvidenceAnnotationKey, pkg.PrimaryEvidenceAnnotation),
|
|
),
|
|
Type: pkg.BinaryPkg,
|
|
CPEs: cpes,
|
|
FoundBy: catalogerName,
|
|
Metadata: pkg.BinarySignature{
|
|
Matches: []pkg.ClassifierMatch{
|
|
{
|
|
Classifier: classifier.Class,
|
|
Location: location,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
if !reflect.DeepEqual(classifier.PURL, emptyPURL) {
|
|
purl := classifier.PURL
|
|
purl.Version = version
|
|
p.PURL = purl.ToString()
|
|
}
|
|
|
|
p.SetID()
|
|
|
|
return &p
|
|
}
|