From 1e79986188e3ac9de8cc27e04be88dbb51832410 Mon Sep 17 00:00:00 2001 From: Alfredo Deza Date: Thu, 5 Nov 2020 16:04:38 -0500 Subject: [PATCH 1/2] json: update the document to include distro information Signed-off-by: Alfredo Deza --- syft/presenter/json/document.go | 22 +++++++++++++++++++--- syft/presenter/json/image.go | 4 +++- syft/presenter/json/presenter.go | 7 +++++-- syft/presenter/presenter.go | 2 +- 4 files changed, 28 insertions(+), 7 deletions(-) diff --git a/syft/presenter/json/document.go b/syft/presenter/json/document.go index e43336df249..0762e934ff9 100644 --- a/syft/presenter/json/document.go +++ b/syft/presenter/json/document.go @@ -1,16 +1,24 @@ package json import ( + "github.com/anchore/syft/syft/distro" "github.com/anchore/syft/syft/pkg" "github.com/anchore/syft/syft/scope" ) type Document struct { - Artifacts []Artifact `json:"artifacts"` - Source Source `json:"source"` + Artifacts []Artifact `json:"artifacts"` + Source Source `json:"source"` + Distro Distribution `json:"distro"` } -func NewDocument(catalog *pkg.Catalog, s scope.Scope) (Document, error) { +// Distritbution provides information about a detected Linux Distribution +type Distribution struct { + Name string `json:"name"` + Version string `json:"version"` +} + +func NewDocument(catalog *pkg.Catalog, s scope.Scope, d distro.Distro) (Document, error) { doc := Document{ Artifacts: make([]Artifact, 0), } @@ -20,6 +28,14 @@ func NewDocument(catalog *pkg.Catalog, s scope.Scope) (Document, error) { return Document{}, nil } doc.Source = src + distroName := d.Name() + if distroName == "UnknownDistroType" { + distroName = "" + } + doc.Distro = Distribution{ + Name: distroName, + Version: d.FullVersion(), + } for _, p := range catalog.Sorted() { art, err := NewArtifact(p, s) diff --git a/syft/presenter/json/image.go b/syft/presenter/json/image.go index 22e6eb3cfac..bffa999bfcd 100644 --- a/syft/presenter/json/image.go +++ b/syft/presenter/json/image.go @@ -1,6 +1,8 @@ package json -import "github.com/anchore/syft/syft/scope" +import ( + "github.com/anchore/syft/syft/scope" +) type Image struct { Layers []Layer `json:"layers"` diff --git a/syft/presenter/json/presenter.go b/syft/presenter/json/presenter.go index 206178ed623..7c5ee540718 100644 --- a/syft/presenter/json/presenter.go +++ b/syft/presenter/json/presenter.go @@ -4,6 +4,7 @@ import ( "encoding/json" "io" + "github.com/anchore/syft/syft/distro" "github.com/anchore/syft/syft/pkg" "github.com/anchore/syft/syft/scope" ) @@ -11,17 +12,19 @@ import ( type Presenter struct { catalog *pkg.Catalog scope scope.Scope + distro distro.Distro } -func NewPresenter(catalog *pkg.Catalog, s scope.Scope) *Presenter { +func NewPresenter(catalog *pkg.Catalog, s scope.Scope, d distro.Distro) *Presenter { return &Presenter{ catalog: catalog, scope: s, + distro: d, } } func (pres *Presenter) Present(output io.Writer) error { - doc, err := NewDocument(pres.catalog, pres.scope) + doc, err := NewDocument(pres.catalog, pres.scope, pres.distro) if err != nil { return err } diff --git a/syft/presenter/presenter.go b/syft/presenter/presenter.go index 49bd1e25b52..65184a74e16 100644 --- a/syft/presenter/presenter.go +++ b/syft/presenter/presenter.go @@ -28,7 +28,7 @@ type Presenter interface { func GetPresenter(option Option, s scope.Scope, catalog *pkg.Catalog, d *distro.Distro) Presenter { switch option { case JSONPresenter: - return json.NewPresenter(catalog, s) + return json.NewPresenter(catalog, s, *d) case TextPresenter: return text.NewPresenter(catalog, s) case TablePresenter: From c2cf4eb7b02e41f8992091322281c0893947a51e Mon Sep 17 00:00:00 2001 From: Alfredo Deza Date: Thu, 5 Nov 2020 16:35:31 -0500 Subject: [PATCH 2/2] update tests for the new distro information Signed-off-by: Alfredo Deza --- syft/presenter/json/presenter_test.go | 8 +++++--- .../snapshot/TestJsonDirsPresenter.golden | 4 ++++ .../snapshot/TestJsonImgsPresenter.golden | 12 ++++++++---- .../stereoscope-fixture-image-simple.golden | Bin 23552 -> 22016 bytes 4 files changed, 17 insertions(+), 7 deletions(-) diff --git a/syft/presenter/json/presenter_test.go b/syft/presenter/json/presenter_test.go index f3e79815b13..b935050a280 100644 --- a/syft/presenter/json/presenter_test.go +++ b/syft/presenter/json/presenter_test.go @@ -8,6 +8,7 @@ import ( "github.com/anchore/go-testutils" "github.com/anchore/stereoscope/pkg/file" "github.com/anchore/stereoscope/pkg/imagetest" + "github.com/anchore/syft/syft/distro" "github.com/anchore/syft/syft/pkg" "github.com/anchore/syft/syft/scope" "github.com/sergi/go-diff/diffmatchpatch" @@ -39,12 +40,12 @@ func TestJsonDirsPresenter(t *testing.T) { {Path: "/some/path/pkg1"}, }, }) - + d := distro.NewUnknownDistro() s, err := scope.NewScopeFromDir("/some/path") if err != nil { t.Fatal(err) } - pres := NewPresenter(catalog, s) + pres := NewPresenter(catalog, s, d) // run presenter err = pres.Present(&buffer) @@ -100,7 +101,8 @@ func TestJsonImgsPresenter(t *testing.T) { }) s, err := scope.NewScopeFromImage(img, scope.AllLayersScope) - pres := NewPresenter(catalog, s) + d := distro.NewUnknownDistro() + pres := NewPresenter(catalog, s, d) // run presenter err = pres.Present(&buffer) diff --git a/syft/presenter/json/test-fixtures/snapshot/TestJsonDirsPresenter.golden b/syft/presenter/json/test-fixtures/snapshot/TestJsonDirsPresenter.golden index e73fecc869c..a56d2316990 100644 --- a/syft/presenter/json/test-fixtures/snapshot/TestJsonDirsPresenter.golden +++ b/syft/presenter/json/test-fixtures/snapshot/TestJsonDirsPresenter.golden @@ -26,5 +26,9 @@ "source": { "type": "directory", "target": "/some/path" + }, + "distro": { + "name": "", + "version": "" } } diff --git a/syft/presenter/json/test-fixtures/snapshot/TestJsonImgsPresenter.golden b/syft/presenter/json/test-fixtures/snapshot/TestJsonImgsPresenter.golden index 62d379db26a..85957c9ba62 100644 --- a/syft/presenter/json/test-fixtures/snapshot/TestJsonImgsPresenter.golden +++ b/syft/presenter/json/test-fixtures/snapshot/TestJsonImgsPresenter.golden @@ -35,26 +35,30 @@ "layers": [ { "mediaType": "application/vnd.docker.image.rootfs.diff.tar.gzip", - "digest": "sha256:e158b57d6f5a96ef5fd22f2fe76c70b5ba6ff5b2619f9d83125b2aad0492ac7b", + "digest": "sha256:78783bfc74fef84f899b4977561ad1172f87753f82cc2157b06bf097e56dfbce", "size": 22 }, { "mediaType": "application/vnd.docker.image.rootfs.diff.tar.gzip", - "digest": "sha256:da21056e7bf4308ecea0c0836848a7fe92f38fdcf35bc09ee6d98e7ab7beeebf", + "digest": "sha256:54ec7f643dafbf9f27032a5e60afe06248c0e99b50aed54bb0fe28ea4825ccaf", "size": 16 }, { "mediaType": "application/vnd.docker.image.rootfs.diff.tar.gzip", - "digest": "sha256:f0e18aa6032c24659a9c741fc36ca56f589782ea132061ccf6f52b952403da94", + "digest": "sha256:ec4775a139c45b1ddf9ea8e1cb43385e92e5c0bf6ec2e3f4192372785b18c106", "size": 27 } ], "size": 65, - "digest": "sha256:2731251dc34951c0e50fcc643b4c5f74922dad1a5d98f302b504cf46cd5d9368", + "digest": "sha256:fedd7bcc0b90f071501b662d8e7c9ac7548b88daba6b3deedfdf33f22ed8d95b", "mediaType": "application/vnd.docker.distribution.manifest.v2+json", "tags": [ "stereoscope-fixture-image-simple:04e16e44161c8888a1a963720fd0443cbf7eef8101434c431de8725cd98cc9f7" ] } + }, + "distro": { + "name": "", + "version": "" } } diff --git a/syft/presenter/json/test-fixtures/snapshot/stereoscope-fixture-image-simple.golden b/syft/presenter/json/test-fixtures/snapshot/stereoscope-fixture-image-simple.golden index 4e7ce36e08086a679c8a074bf4229f4cafee09bc..c98a9207cba82e4500322a8abc3c47c933deb265 100644 GIT binary patch literal 22016 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 LfsDZaF#`VsZMnln