-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ci: generate sboms for provided packeges in a release #247
base: main
Are you sure you want to change the base?
Conversation
LGTM but why is the syft installation needed in the e2e testing workflow? EDIT: I guess it's based on when we use the gorelease action, right? |
Use the following command to generate a SBOM markdown file using the `example.sbom.tmpl` goTemplate template file: | ||
|
||
```SH | ||
SYFT_GOLANG_SEARCH_REMOTE_LICENSES=true syft ghcr.io/caas-team/sparrow:v0.5.0 -o template -t syft.sbom.tmpl |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the template file path is wrong :)
SYFT_GOLANG_SEARCH_REMOTE_LICENSES=true syft ghcr.io/caas-team/sparrow:v0.5.0 -o template -t scripts/sbom/example.sbom.tmpl
| Package | Type | Version | Licenses | | ||
| ------- | ---- | ------- | -------- | | ||
{{- range .artifacts}} | ||
| {{.name}} | {{.type}} | {{.version}} | {{range .licenses}}{{.value}}, {{end}} | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
maybe leave out the ,
at the end? This creates a weird looking table:
❯ SYFT_GOLANG_SEARCH_REMOTE_LICENSES=true syft ghcr.io/caas-team/sparrow:v0.5.0 -o template -t scripts/sbom/example.sbom.tmpl
✔ Parsed image sha256:930220dd636d6eb9c4fb64fb6a3da870d47fda214c2421e5480b25b79ad87659
✔ Cataloged contents a3c35079ee159927516b3059d49f1b0e6c34fc1c62a545d6da1985490e971f42
├── ✔ Packages [53 packages]
├── ✔ File digests [1 files]
├── ✔ File metadata [1 locations]
└── ✔ Executables [1 executables]
| Package | Type | Version | Licenses |
| ------- | ---- | ------- | -------- |
| github.com/beorn7/perks | go-module | v1.0.1 | MIT, |
| github.com/caas-team/sparrow | go-module | v0.5.0 | |
| github.com/cenkalti/backoff/v4 | go-module | v4.3.0 | MIT, |
| github.com/cespare/xxhash/v2 | go-module | v2.3.0 | MIT, |
| github.com/fsnotify/fsnotify | go-module | v1.7.0 | BSD-3-Clause, |
...
EDIT: I'll take a look on how to make this look proper, this can be done with go templating, if that's what they're using in syft.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OK, how about this:
| Package | Type | Version | Licenses |
| ------- | ---- | ------- | -------- |
{{- range .artifacts}}
| {{.name}} | {{.type}} | {{.version}} | {{range $index, $licence := .licenses}}{{- if $index}}, {{end}}{{$licence.value}}{{end}} |
{{- end}}
This produces the following output:
❯ SYFT_GOLANG_SEARCH_REMOTE_LICENSES=true syft ghcr.io/caas-team/sparrow:v0.5.0 -o template -t scripts/sbom/example.sbom.tmpl
✔ Parsed image sha256:930220dd636d6eb9c4fb64fb6a3da870d47fda214c2421e5480b25b79ad87659
✔ Cataloged contents a3c35079ee159927516b3059d49f1b0e6c34fc1c62a545d6da1985490e971f42
├── ✔ Packages [53 packages]
├── ✔ File digests [1 files]
├── ✔ File metadata [1 locations]
└── ✔ Executables [1 executables]
| Package | Type | Version | Licenses |
| ------- | ---- | ------- | -------- |
| github.com/beorn7/perks | go-module | v1.0.1 | MIT |
| github.com/caas-team/sparrow | go-module | v0.5.0 | |
| github.com/cenkalti/backoff/v4 | go-module | v4.3.0 | MIT |
| github.com/cespare/xxhash/v2 | go-module | v2.3.0 | MIT |
| github.com/fsnotify/fsnotify | go-module | v1.7.0 | BSD-3-Clause |
| github.com/getkin/kin-openapi | go-module | v0.128.0 | MIT |
| github.com/go-chi/chi/v5 | go-module | v5.1.0 | MIT |
| github.com/go-logr/logr | go-module | v1.4.2 | Apache-2.0 |
| github.com/go-logr/stdr | go-module | v1.2.2 | Apache-2.0 |
| github.com/go-openapi/jsonpointer | go-module | v0.21.0 | Apache-2.0 |
| github.com/go-openapi/swag | go-module | v0.23.0 | Apache-2.0 |
| github.com/go-viper/mapstructure/v2 | go-module | v2.1.0 | MIT |
| github.com/google/uuid | go-module | v1.6.0 | BSD-3-Clause |
| github.com/grpc-ecosystem/grpc-gateway/v2 | go-module | v2.24.0 | BSD-3-Clause |
| github.com/invopop/yaml | go-module | v0.3.1 | BSD-3-Clause, MIT |
| github.com/josharian/intern | go-module | v1.0.0 | MIT |
| github.com/klauspost/compress | go-module | v1.17.9 | Apache-2.0, BSD-3-Clause, MIT |
...
|
||
Use the following command to generate a simple SBOM file form the repository: | ||
|
||
```SH |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think that SH
is a supported github markdown info string. Just use shell
or bash
or just sh
?
Correct! Syft is needed see this previous failing ci job: https://github.com/telekom/sparrow/actions/runs/12596763639/job/35108497305#step:4:1 |
Motivation
Goreleaser provides the functionality to generate the
sbom
when creating a GitHub release with its artifacts.Changes
This MR will add
sbom
s for all provided artifacts when a new release is created. This is needed to prepare the migration of the repo.Edit: Additionally I have added a description how to use Syft manually in our context.
For additional information look at the commits.
Tests done