Skip to content

Commit

Permalink
fix: use unique sbom identifier for the uri field (#1437)
Browse files Browse the repository at this point in the history
* fix: use unique sbom identifier for the uri field

Signed-off-by: Dejan Bosanac <[email protected]>

* fix: HasSBOM uri tests

Signed-off-by: Dejan Bosanac <[email protected]>

---------

Signed-off-by: Dejan Bosanac <[email protected]>
  • Loading branch information
dejanb authored Oct 28, 2023
1 parent 8336525 commit 478e62e
Show file tree
Hide file tree
Showing 5 changed files with 10 additions and 10 deletions.
10 changes: 5 additions & 5 deletions internal/testing/testdata/testdata.go
Original file line number Diff line number Diff line change
Expand Up @@ -750,7 +750,7 @@ var (
{
Pkg: topLevelPack,
HasSBOM: &model.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "https://anchore.com/syft/image/alpine-latest-e78eca08-d9f4-49c7-97e0-6d4b9bfa99c2",
Algorithm: "sha256",
Digest: "8b5e8212cae084f92ff91f8625a50ea1070738cfc68ecca08bf04d64f64b9feb",
DownloadLocation: "TestSource",
Expand Down Expand Up @@ -972,7 +972,7 @@ var (
{
Pkg: cdxTopLevelPack,
HasSBOM: &model.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "urn:uuid:6a44e622-2983-4566-bf90-f87b6103ebaf",
Algorithm: "sha256",
Digest: "01942b5eefd3c15b50318c66d8d16627be573197c877e8a286a8cb12de7939cb",
DownloadLocation: "TestSource",
Expand Down Expand Up @@ -1066,7 +1066,7 @@ var (
{
Pkg: cdxTopQuarkusPack,
HasSBOM: &model.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "urn:uuid:0697952e-9848-4785-95bf-f81ff9731682",
Algorithm: "sha256",
Digest: "036a9f51468f5ce6eec7c310583164ed0ab9f58d7c03380a3fe19d420609e3de",
DownloadLocation: "TestSource",
Expand Down Expand Up @@ -1104,7 +1104,7 @@ var (
{
Pkg: cdxWebAppPackage,
HasSBOM: &model.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "",
Algorithm: "sha256",
Digest: "35363f03c80f26a88db6f2400771bdcc6624bb7b61b96da8503be0f757605fde",
DownloadLocation: "TestSource",
Expand All @@ -1125,7 +1125,7 @@ var (
{
Pkg: quarkusParentPackage,
HasSBOM: &model.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "urn:uuid:8a689387-e9b4-4ba2-835c-a2c3dde6181d",
Algorithm: "sha256",
Digest: "fcd4d1f9c83c274fbc2dabdca4e7de749b23fab1aa15dc2854880a13479fa74e",
DownloadLocation: "TestSource",
Expand Down
4 changes: 2 additions & 2 deletions pkg/ingestor/parser/common/helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -101,13 +101,13 @@ func CreateTopLevelIsDeps(topLevel *model.PkgInputSpec, packages map[string][]*m
return isDeps
}

func CreateTopLevelHasSBOM(topLevel *model.PkgInputSpec, sbomDoc *processor.Document, timeStamp time.Time) assembler.HasSBOMIngest {
func CreateTopLevelHasSBOM(topLevel *model.PkgInputSpec, sbomDoc *processor.Document, uri string, timeStamp time.Time) assembler.HasSBOMIngest {
sha256sum := sha256.Sum256(sbomDoc.Blob)
hash := hex.EncodeToString(sha256sum[:])
return assembler.HasSBOMIngest{
Pkg: topLevel,
HasSBOM: &model.HasSBOMInputSpec{
Uri: sbomDoc.SourceInformation.Source,
Uri: uri,
Algorithm: "sha256",
Digest: hash,
DownloadLocation: sbomDoc.SourceInformation.Source,
Expand Down
2 changes: 1 addition & 1 deletion pkg/ingestor/parser/cyclonedx/parser_cyclonedx.go
Original file line number Diff line number Diff line change
Expand Up @@ -260,7 +260,7 @@ func (c *cyclonedxParser) GetPredicates(ctx context.Context) *assembler.IngestPr
}

preds.IsDependency = append(preds.IsDependency, common.CreateTopLevelIsDeps(toplevel[0], c.packagePackages, nil, "top-level package GUAC heuristic connecting to each file/package")...)
preds.HasSBOM = append(preds.HasSBOM, common.CreateTopLevelHasSBOM(toplevel[0], c.doc, timestamp))
preds.HasSBOM = append(preds.HasSBOM, common.CreateTopLevelHasSBOM(toplevel[0], c.doc, c.cdxBom.SerialNumber, timestamp))
}

for id := range c.packagePackages {
Expand Down
2 changes: 1 addition & 1 deletion pkg/ingestor/parser/spdx/parse_spdx.go
Original file line number Diff line number Diff line change
Expand Up @@ -249,7 +249,7 @@ func (s *spdxParser) GetPredicates(ctx context.Context) *assembler.IngestPredica
return nil
}
for _, topLevelPkg := range topLevel {
preds.HasSBOM = append(preds.HasSBOM, common.CreateTopLevelHasSBOM(topLevelPkg, s.doc, timestamp))
preds.HasSBOM = append(preds.HasSBOM, common.CreateTopLevelHasSBOM(topLevelPkg, s.doc, s.spdxDoc.DocumentNamespace, timestamp))
}

if s.topLevelIsHeuristic {
Expand Down
2 changes: 1 addition & 1 deletion pkg/ingestor/parser/spdx/parse_spdx_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ func Test_spdxParser(t *testing.T) {
Subpath: &packageOfEmptyString,
},
HasSBOM: &generated.HasSBOMInputSpec{
Uri: "TestSource",
Uri: "https://anchore.com/syft/image/alpine-latest-e78eca08-d9f4-49c7-97e0-6d4b9bfa99c2",
Algorithm: "sha256",
Digest: "ba096464061993bbbdfc30a26b42cd8beb1bfff301726fe6c58cb45d468c7648",
DownloadLocation: "TestSource",
Expand Down

0 comments on commit 478e62e

Please sign in to comment.