mirror of
https://github.com/anchore/syft.git
synced 2025-11-17 16:33:21 +01:00
58 lines
1.1 KiB
Go
58 lines
1.1 KiB
Go
package cyclonedxhelpers
|
|
|
|
import (
|
|
"github.com/CycloneDX/cyclonedx-go"
|
|
|
|
"github.com/anchore/syft/internal/log"
|
|
"github.com/anchore/syft/syft/pkg"
|
|
)
|
|
|
|
func encodeSingleCPE(p pkg.Package) string {
|
|
// Since the CPEs in a package are sorted by specificity
|
|
// we can extract the first CPE as the one to output in cyclonedx
|
|
if len(p.CPEs) > 0 {
|
|
return pkg.CPEString(p.CPEs[0])
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func encodeCPEs(p pkg.Package) (out []cyclonedx.Property) {
|
|
for i, c := range p.CPEs {
|
|
// first CPE is "most specific" and already encoded as the component CPE
|
|
if i == 0 {
|
|
continue
|
|
}
|
|
out = append(out, cyclonedx.Property{
|
|
Name: "syft:cpe23",
|
|
Value: pkg.CPEString(c),
|
|
})
|
|
}
|
|
return
|
|
}
|
|
|
|
func decodeCPEs(c *cyclonedx.Component) (out []pkg.CPE) {
|
|
if c.CPE != "" {
|
|
cp, err := pkg.NewCPE(c.CPE)
|
|
if err != nil {
|
|
log.Warnf("invalid CPE: %s", c.CPE)
|
|
} else {
|
|
out = append(out, cp)
|
|
}
|
|
}
|
|
|
|
if c.Properties != nil {
|
|
for _, p := range *c.Properties {
|
|
if p.Name == "syft:cpe23" {
|
|
cp, err := pkg.NewCPE(p.Value)
|
|
if err != nil {
|
|
log.Warnf("invalid CPE: %s", p.Value)
|
|
} else {
|
|
out = append(out, cp)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return
|
|
}
|