diff --git a/.github/config-release.yml b/.github/config-release.yml new file mode 100644 index 0000000..6bdd119 --- /dev/null +++ b/.github/config-release.yml @@ -0,0 +1,13 @@ +# Used for pre-submit tests. +version: 1 +env: + - GO111MODULE=on + - CGO_ENABLED=0 + +flags: + - -trimpath + - -tags=netgo + +goos: linux +goarch: amd64 +binary: slsa-verifier-{{ .Os }}-{{ .Arch }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..6738b2b --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,21 @@ +name: Verifier releaser + +on: + # For manual tests. + workflow_dispatch: + push: + tags: + - "*" # triggers only if push new tag version, like `0.8.4`. + +permissions: read-all + +jobs: + builder: + permissions: + id-token: write # For signing. + contents: write # For asset uploads. + uses: slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@v0.0.1 + with: + go-version: 1.18 + config-file: .github/config-release.yml + compile-builder: true diff --git a/main_test.go b/main_test.go index 2bdd2c5..cbef54b 100644 --- a/main_test.go +++ b/main_test.go @@ -4,9 +4,10 @@ import ( "errors" "testing" + "github.com/slsa-framework/slsa-verifier/pkg" + "github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp/cmpopts" - pkg "github.com/slsa-framework/slsa-verifier/pkg" ) func errCmp(e1, e2 error) bool { @@ -31,71 +32,71 @@ func Test_runVerify(t *testing.T) { { name: "valid main branch default", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", }, { name: "valid main branch set", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", branch: "main", }, { name: "wrong branch master", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", branch: "master", err: pkg.ErrorMismatchBranch, }, { name: "wrong source append A", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-testA", + source: "github.com/laurentsimon/slsa-verifier-test-genA", err: pkg.ErrorMismatchRepository, }, { name: "wrong source prepend A", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "Agithub.com/asraa/slsa-on-github-test", + source: "Agithub.com/laurentsimon/slsa-verifier-test-gen", err: pkg.ErrorMismatchRepository, }, { name: "wrong source middle A", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/Aasraa/slsa-on-github-test", + source: "github.com/Alaurentsimon/slsa-verifier-test-gen", err: pkg.ErrorMismatchRepository, }, { name: "tag no match empty tag workflow_dispatch", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", ptag: pString("v1.2.3"), err: pkg.ErrorMismatchTag, }, { name: "versioned tag no match empty tag workflow_dispatch", artifact: "./testdata/binary-linux-amd64-workflow_dispatch", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1"), err: pkg.ErrorInvalidSemver, }, { name: "tag v1.2.3 no match v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", ptag: pString("v1.2.3"), err: pkg.ErrorMismatchTag, }, { name: "tag v1.2 no match v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", ptag: pString("v1.2"), err: pkg.ErrorMismatchTag, }, { name: "tag v1 no match v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", ptag: pString("v1"), err: pkg.ErrorMismatchTag, }, @@ -103,60 +104,60 @@ func Test_runVerify(t *testing.T) { { name: "versioned v1.2.4 match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.2.4"), }, { name: "versioned v1.2 match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.2"), }, { name: "versioned v1 match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1"), }, { name: "versioned v2 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v0 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v0"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1.3 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1.1 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1.2.3 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.2.3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1.2.5 no match push-v1.2.4", artifact: "./testdata/binary-linux-amd64-push-v1.2.4", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.2.5"), err: pkg.ErrorMismatchVersionedTag, }, @@ -164,54 +165,54 @@ func Test_runVerify(t *testing.T) { { name: "versioned v2 match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2"), }, { name: "versioned v2.0 match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.0"), }, { name: "versioned v2.1 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v3 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1.2 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1.2"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v3 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v0 no match push-v2", artifact: "./testdata/binary-linux-amd64-push-v2", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v0"), err: pkg.ErrorMismatchVersionedTag, }, @@ -219,71 +220,72 @@ func Test_runVerify(t *testing.T) { { name: "versioned v2.5 match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.5"), }, { name: "versioned v2.5.1 match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.5.1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v2.5.3 match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.5.3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v2 match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2"), }, { name: "versioned v2.4 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.4"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v2.4.1 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.4.1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v2.4.5 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v2.4.5"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v1 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v1"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v3 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v3"), err: pkg.ErrorMismatchVersionedTag, }, { name: "versioned v3.1 no match push-v2.5", artifact: "./testdata/binary-linux-amd64-push-v2.5", - source: "github.com/asraa/slsa-on-github-test", + source: "github.com/laurentsimon/slsa-verifier-test-gen", pversiontag: pString("v3.1"), err: pkg.ErrorMismatchVersionedTag, }, + // TODO(laurent): add tests for special cases of buidlers' ref. } for _, tt := range tests { tt := tt // Re-initializing variable so it is not changed while executing the closure below diff --git a/pkg/provenance.go b/pkg/provenance.go index 75a2001..71ef16f 100644 --- a/pkg/provenance.go +++ b/pkg/provenance.go @@ -44,24 +44,32 @@ const ( certOidcIssuer = "https://token.actions.githubusercontent.com" ) -// TODO: remove builder.yml +var ( + trustedBuilderRepository = "slsa-framework/slsa-github-generator" + e2eTestRepository = "slsa-framework/example-package" +) + +// TODO: remove old builders. var trustedReusableWorkflows = map[string]bool{ - "slsa-framework/slsa-github-generator/.github/workflows/slsa2_provenance.yml": true, + trustedBuilderRepository + "/.github/workflows/slsa2_provenance.yml": true, "slsa-framework/slsa-github-generator-go/.github/workflows/slsa3_builder.yml": true, "slsa-framework/slsa-github-generator-go/.github/workflows/builder.yml": true, - "slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml": true, + trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml": true, } var ( - ErrorInvalidDssePayload = errors.New("invalid DSSE envelope payload") - errorRekorSearch = errors.New("error searching rekor entries") - errorMismatchHash = errors.New("binary artifact hash does not match provenance subject") - ErrorMismatchBranch = errors.New("branch used to generate the binary does not match provenance") - ErrorMismatchRepository = errors.New("repository used to generate the binary does not match provenance") - ErrorMismatchTag = errors.New("tag used to generate the binary does not match provenance") - ErrorMismatchVersionedTag = errors.New("tag used to generate the binary does not match provenance") - ErrorInvalidSemver = errors.New("invalid semantic version") - errorInvalidVersion = errors.New("invalid version") + ErrorInvalidDssePayload = errors.New("invalid DSSE envelope payload") + ErrorMismatchBranch = errors.New("branch used to generate the binary does not match provenance") + ErrorMismatchRepository = errors.New("repository used to generate the binary does not match provenance") + ErrorMismatchTag = errors.New("tag used to generate the binary does not match provenance") + ErrorMismatchVersionedTag = errors.New("tag used to generate the binary does not match provenance") + ErrorInvalidSemver = errors.New("invalid semantic version") + errorRekorSearch = errors.New("error searching rekor entries") + errorMismatchHash = errors.New("binary artifact hash does not match provenance subject") + errorInvalidVersion = errors.New("invalid version") + errorInvalidRef = errors.New("invalid ref") + errorMalformedWorkflowURI = errors.New("malformed URI for workflow") + errorUntrustedReusableWorkflow = errors.New("untrusted reusable workflow") ) func EnvelopeFromBytes(payload []byte) (env *dsselib.Envelope, err error) { @@ -380,15 +388,23 @@ func VerifyWorkflowIdentity(id *WorkflowIdentity, source string) error { // cert URI path is /org/repo/path/to/workflow@ref workflowPath := strings.SplitN(id.JobWobWorkflowRef, "@", 2) if len(workflowPath) < 2 { - return errors.New("malformed URI for workflow") + return fmt.Errorf("%w: %s", errorMalformedWorkflowURI, id.JobWobWorkflowRef) } - if _, ok := trustedReusableWorkflows[strings.Trim(workflowPath[0], "/")]; !ok { - return errors.New("untrusted reuseable workflow") + // Trusted workflow verification by name. + reusableWorkflowName := strings.Trim(workflowPath[0], "/") + if _, ok := trustedReusableWorkflows[reusableWorkflowName]; !ok { + return fmt.Errorf("%w: %s", errorUntrustedReusableWorkflow, reusableWorkflowName) } + // Verify the ref. + if err := verifyTrustedBuilderRef(id, strings.Trim(workflowPath[1], "/")); err != nil { + return err + } + + // Issue verification. if !strings.EqualFold(id.Issuer, certOidcIssuer) { - return errors.New("untrusted token issuer") + return fmt.Errorf("untrusted token issuer: %s", id.Issuer) } // The caller repository in the x509 extension is not fully qualified. It only contains @@ -402,6 +418,31 @@ func VerifyWorkflowIdentity(id *WorkflowIdentity, source string) error { return nil } +// Only allow `@refs/heads/main` for the builder and the e2e tests that need to work at HEAD. +// This lets us use the pre-build builder binary generated during release (release happen at main). +// For other projects, we only allow semantic versions that map to a release. +func verifyTrustedBuilderRef(id *WorkflowIdentity, ref string) error { + if (id.CallerRepository == trustedBuilderRepository || + id.CallerRepository == e2eTestRepository) && + strings.EqualFold("refs/heads/main", ref) { + return nil + } + + if !strings.HasPrefix(ref, "refs/tags/") { + return fmt.Errorf("%w: %s: not of the form 'refs/tags/name'", errorInvalidRef, ref) + } + + // Valid semver of the form vX.Y.Z with no metadata. + pin := strings.TrimPrefix(ref, "refs/tags/") + if !(semver.IsValid(pin) && + len(strings.Split(pin, ".")) == 3 && + semver.Prerelease(pin) == "" && + semver.Build(pin) == "") { + return fmt.Errorf("%w: %s: not of the form vX.Y.Z", errorInvalidRef, pin) + } + return nil +} + func VerifyProvenance(env *dsselib.Envelope, expectedHash string) error { hash, err := getSha256Digest(env) if err != nil { diff --git a/pkg/provenance_test.go b/pkg/provenance_test.go index 4731a58..a05d68a 100644 --- a/pkg/provenance_test.go +++ b/pkg/provenance_test.go @@ -9,6 +9,7 @@ import ( "github.com/go-openapi/runtime" "github.com/google/go-cmp/cmp" + "github.com/google/go-cmp/cmp/cmpopts" dsselib "github.com/secure-systems-lab/go-securesystemslib/dsse" "github.com/sigstore/rekor/pkg/generated/client" "github.com/sigstore/rekor/pkg/generated/client/index" @@ -162,7 +163,7 @@ func Test_VerifyWorkflowIdentity(t *testing.T) { name string workflow *WorkflowIdentity source string - res bool + err error }{ { name: "invalid job workflow ref", @@ -174,7 +175,7 @@ func Test_VerifyWorkflowIdentity(t *testing.T) { Issuer: "https://token.actions.githubusercontent.com", }, source: "asraa/slsa-on-github-test", - res: false, + err: errorMalformedWorkflowURI, }, { name: "untrusted job workflow ref", @@ -186,55 +187,134 @@ func Test_VerifyWorkflowIdentity(t *testing.T) { Issuer: "https://token.actions.githubusercontent.com", }, source: "asraa/slsa-on-github-test", - res: false, + err: errorUntrustedReusableWorkflow, }, { - name: "untrusted job workflow ref", + name: "untrusted job workflow ref for general repos", workflow: &WorkflowIdentity{ CallerRepository: "asraa/slsa-on-github-test", CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", - JobWobWorkflowRef: "/slsa-framework/slsa-github-generator-go/.github/workflows/builder.yml@refs/heads/main", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/heads/main", Trigger: "workflow_dispatch", Issuer: "https://bad.issuer.com", }, source: "asraa/slsa-on-github-test", - res: false, + err: errorInvalidRef, + }, + { + name: "valid main ref for trusted builder", + workflow: &WorkflowIdentity{ + CallerRepository: trustedBuilderRepository, + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/heads/main", + Trigger: "workflow_dispatch", + Issuer: "https://token.actions.githubusercontent.com", + }, + source: trustedBuilderRepository, + }, + { + name: "valid main ref for e2e test", + workflow: &WorkflowIdentity{ + CallerRepository: e2eTestRepository, + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/heads/main", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: e2eTestRepository, + }, + { + name: "unexpected source for e2e test", + workflow: &WorkflowIdentity{ + CallerRepository: e2eTestRepository, + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/heads/main", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: "malicious/source", + err: ErrorMismatchRepository, + }, + { + name: "valid main ref for builder", + workflow: &WorkflowIdentity{ + CallerRepository: trustedBuilderRepository, + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/heads/main", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: "malicious/source", + err: ErrorMismatchRepository, }, { name: "unexpected source", workflow: &WorkflowIdentity{ CallerRepository: "malicious/slsa-on-github-test", CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", - JobWobWorkflowRef: "/slsa-framework/slsa-github-generator-go/.github/workflows/builder.yml@refs/heads/main", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3", Trigger: "workflow_dispatch", - Issuer: "https://token.actions.githubusercontent.com", + Issuer: certOidcIssuer, }, source: "asraa/slsa-on-github-test", - res: false, + err: ErrorMismatchRepository, }, { name: "valid workflow identity", workflow: &WorkflowIdentity{ CallerRepository: "asraa/slsa-on-github-test", CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", - JobWobWorkflowRef: "/slsa-framework/slsa-github-generator-go/.github/workflows/builder.yml@refs/heads/main", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3", Trigger: "workflow_dispatch", - Issuer: "https://token.actions.githubusercontent.com", + Issuer: certOidcIssuer, }, source: "asraa/slsa-on-github-test", - res: true, + }, + { + name: "invalid workflow identity with prerelease", + workflow: &WorkflowIdentity{ + CallerRepository: "asraa/slsa-on-github-test", + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3-alpha", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: "asraa/slsa-on-github-test", + err: errorInvalidRef, + }, + { + name: "invalid workflow identity with build", + workflow: &WorkflowIdentity{ + CallerRepository: "asraa/slsa-on-github-test", + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3+123", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: "asraa/slsa-on-github-test", + err: errorInvalidRef, + }, + { + name: "invalid workflow identity with metadata", + workflow: &WorkflowIdentity{ + CallerRepository: "asraa/slsa-on-github-test", + CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3-alpha+123", + Trigger: "workflow_dispatch", + Issuer: certOidcIssuer, + }, + source: "asraa/slsa-on-github-test", + err: errorInvalidRef, }, { name: "valid workflow identity with fully qualified source", workflow: &WorkflowIdentity{ CallerRepository: "asraa/slsa-on-github-test", CallerHash: "0dfcd24824432c4ce587f79c918eef8fc2c44d7b", - JobWobWorkflowRef: "/slsa-framework/slsa-github-generator-go/.github/workflows/builder.yml@refs/heads/main", + JobWobWorkflowRef: trustedBuilderRepository + "/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.2.3", Trigger: "workflow_dispatch", - Issuer: "https://token.actions.githubusercontent.com", + Issuer: certOidcIssuer, }, source: "github.com/asraa/slsa-on-github-test", - res: true, }, } for _, tt := range tests { @@ -242,8 +322,8 @@ func Test_VerifyWorkflowIdentity(t *testing.T) { t.Run(tt.name, func(t *testing.T) { t.Parallel() err := VerifyWorkflowIdentity(tt.workflow, tt.source) - if (err == nil) != tt.res { - t.Errorf("unexpected result, expected verfication %t", tt.res) + if !errCmp(err, tt.err) { + t.Errorf(cmp.Diff(err, tt.err, cmpopts.EquateErrors())) } }) } @@ -351,6 +431,156 @@ func Test_VerifyTag(t *testing.T) { } } +func Test_verifyTrustedBuilderRef(t *testing.T) { + t.Parallel() + tests := []struct { + name string + callerRepo string + builderRef string + expected error + }{ + // Trusted repo. + { + name: "main allowed for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/heads/main", + }, + { + name: "full semver for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1.2.3", + }, + { + name: "no patch semver for other builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1.2", + expected: errorInvalidRef, + }, + { + name: "no min semver for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1", + expected: errorInvalidRef, + }, + { + name: "full semver with prerelease for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1.2.3-alpha", + expected: errorInvalidRef, + }, + { + name: "full semver with build for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1.2.3+123", + expected: errorInvalidRef, + }, + { + name: "full semver with build/prerelease for builder", + callerRepo: trustedBuilderRepository, + builderRef: "refs/tags/v1.2.3-alpha+123", + expected: errorInvalidRef, + }, + // E2e tests repo. + { + name: "main allowed for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/heads/main", + }, + { + name: "full semver for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1.2.3", + }, + { + name: "no patch semver for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1.2", + expected: errorInvalidRef, + }, + { + name: "no min semver for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1", + expected: errorInvalidRef, + }, + { + name: "full semver with prerelease for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1.2.3-alpha", + expected: errorInvalidRef, + }, + { + name: "full semver with build for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1.2.3+123", + expected: errorInvalidRef, + }, + { + name: "full semver with build/prerelease for test repo", + callerRepo: e2eTestRepository, + builderRef: "refs/tags/v1.2.3-alpha+123", + expected: errorInvalidRef, + }, + // Other repos. + { + name: "main not allowed for other repos", + callerRepo: "some/repo", + builderRef: "refs/heads/main", + expected: errorInvalidRef, + }, + { + name: "full semver for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1.2.3", + }, + { + name: "no patch semver for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1.2", + expected: errorInvalidRef, + }, + { + name: "no min semver for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1", + expected: errorInvalidRef, + }, + { + name: "full semver with prerelease for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1.2.3-alpha", + expected: errorInvalidRef, + }, + { + name: "full semver with build for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1.2.3+123", + expected: errorInvalidRef, + }, + { + name: "full semver with build/prerelease for other repos", + callerRepo: "some/repo", + builderRef: "refs/tags/v1.2.3-alpha+123", + expected: errorInvalidRef, + }, + } + for _, tt := range tests { + tt := tt // Re-initializing variable so it is not changed while executing the closure below + t.Run(tt.name, func(t *testing.T) { + t.Parallel() + + wf := WorkflowIdentity{ + CallerRepository: tt.callerRepo, + } + + err := verifyTrustedBuilderRef(&wf, tt.builderRef) + if !errCmp(err, tt.expected) { + t.Errorf(cmp.Diff(err, tt.expected, cmpopts.EquateErrors())) + } + }) + } +} + func Test_VerifyVersionedTag(t *testing.T) { t.Parallel() tests := []struct { diff --git a/testdata/binary-linux-amd64-push-v1.2.4 b/testdata/binary-linux-amd64-push-v1.2.4 index 1839b9c..3690c2e 100644 Binary files a/testdata/binary-linux-amd64-push-v1.2.4 and b/testdata/binary-linux-amd64-push-v1.2.4 differ diff --git a/testdata/binary-linux-amd64-push-v1.2.4.intoto.jsonl b/testdata/binary-linux-amd64-push-v1.2.4.intoto.jsonl index cebf90e..c52481e 100644 --- a/testdata/binary-linux-amd64-push-v1.2.4.intoto.jsonl +++ b/testdata/binary-linux-amd64-push-v1.2.4.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"6db937f07c14d309d403e561e2b402972e2a6edb32f4526e1b6b9ba855fd8574"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator-go/.github/workflows/slsa3_builder.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v1.2.4","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"entryPoint":"Test SLSA"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/asraa/slsa-on-github-test/compare/v1.2.4","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"committer":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"distinct":true,"id":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","message":"empty","timestamp":"2022-05-03T15:28:00-05:00","tree_id":"2d3a7894c930afd6bf0e367c968ecba42f74481f","url":"https://github.com/asraa/slsa-on-github-test/commit/9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"pusher":{"email":"asraa@google.com","name":"asraa"},"ref":"refs/tags/v1.2.4","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":1644939229,"default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","email":"asraa@google.com","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","name":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":1651609812,"releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1334,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://github.com/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"}},"github_head_ref":"","github_ref":"refs/tags/v1.2.4","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2266198872","github_run_number":"12","github_sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.9/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"]}]},"metadata":{"completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v1.2.4","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220425.1"}]}}","signatures":[{"keyid":"","sig":"MEUCIAfeaooEcy3GWhVwv/VCrFEISqsdPgN+YrtGB8+VKVp0AiEA/sS5qYkhZLQdfEQmwPELQirSdUeTwzGgfiF4vAzEfi8="}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"149bf863f6fbd75bc9a2853ad9973905b3634784bfb034a6df8bef1c238f8c35"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/tags/v0.0.1"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v1.2.4","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/laurentsimon/slsa-verifier-test-gen/compare/v1.2.4","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon","username":"laurentsimon"},"committer":{"email":"noreply@github.com","name":"GitHub","username":"web-flow"},"distinct":true,"id":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","message":"Update builder-test.yaml","timestamp":"2022-05-25T14:46:25-07:00","tree_id":"9445d61b7cb6f8193d31a19b91bf900499cb2c2f","url":"https://github.com/laurentsimon/slsa-verifier-test-gen/commit/15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"pusher":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon"},"ref":"refs/tags/v1.2.4","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/assignees{/user}","blobs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/blobs{/sha}","branches_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/branches{/branch}","clone_url":"https://github.com/laurentsimon/slsa-verifier-test-gen.git","collaborators_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/comments{/number}","commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/commits{/sha}","compare_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/compare/{base}...{head}","contents_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contents/{+path}","contributors_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contributors","created_at":1653514549,"default_branch":"main","deployments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/downloads","events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/events","fork":false,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/forks","full_name":"laurentsimon/slsa-verifier-test-gen","git_commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/tags{/sha}","git_url":"git://github.com/laurentsimon/slsa-verifier-test-gen.git","has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/hooks","html_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","id":496397049,"is_template":false,"issue_comment_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/events{/number}","issues_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues{/number}","keys_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/keys{/key_id}","labels_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/merges","milestones_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/milestones{/number}","mirror_url":null,"name":"slsa-verifier-test-gen","node_id":"R_kgDOHZZq-Q","notifications_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","email":"64505099+laurentsimon@users.noreply.github.com","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","name":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"private":false,"pulls_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/pulls{/number}","pushed_at":1653515227,"releases_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/releases{/id}","size":0,"ssh_url":"git@github.com:laurentsimon/slsa-verifier-test-gen.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/stargazers","statuses_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/statuses/{sha}","subscribers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscribers","subscription_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscription","svn_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/tags","teams_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/teams","topics":[],"trees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/trees{/sha}","updated_at":"2022-05-25T21:36:29Z","url":"https://github.com/laurentsimon/slsa-verifier-test-gen","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"}},"github_head_ref":"","github_ref":"refs/tags/v1.2.4","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2387315820","github_run_number":"2","github_sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"}]},"metadata":{"buildInvocationID":"2387315820-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v1.2.4","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEYCIQDLjU/ELi60pmE9MSZ9uprJwlJowSrFa6//ewSHxUDlbAIhAO6lvR3a9/oldEuW7+NV/vTuTmcSbuwhUM2h50xfIbaC"}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-push-v2 b/testdata/binary-linux-amd64-push-v2 index 1839b9c..3690c2e 100644 Binary files a/testdata/binary-linux-amd64-push-v2 and b/testdata/binary-linux-amd64-push-v2 differ diff --git a/testdata/binary-linux-amd64-push-v2.5 b/testdata/binary-linux-amd64-push-v2.5 index 1839b9c..3690c2e 100644 Binary files a/testdata/binary-linux-amd64-push-v2.5 and b/testdata/binary-linux-amd64-push-v2.5 differ diff --git a/testdata/binary-linux-amd64-push-v2.5.intoto.jsonl b/testdata/binary-linux-amd64-push-v2.5.intoto.jsonl index f1f54fe..1db939c 100644 --- a/testdata/binary-linux-amd64-push-v2.5.intoto.jsonl +++ b/testdata/binary-linux-amd64-push-v2.5.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"6db937f07c14d309d403e561e2b402972e2a6edb32f4526e1b6b9ba855fd8574"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator-go/.github/workflows/slsa3_builder.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v2.5","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"entryPoint":"Test SLSA"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/asraa/slsa-on-github-test/compare/v2.5","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"committer":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"distinct":true,"id":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","message":"empty","timestamp":"2022-05-03T15:28:00-05:00","tree_id":"2d3a7894c930afd6bf0e367c968ecba42f74481f","url":"https://github.com/asraa/slsa-on-github-test/commit/9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"pusher":{"email":"asraa@google.com","name":"asraa"},"ref":"refs/tags/v2.5","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":1644939229,"default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","email":"asraa@google.com","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","name":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":1651609720,"releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1334,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://github.com/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"}},"github_head_ref":"","github_ref":"refs/tags/v2.5","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2266192391","github_run_number":"10","github_sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.9/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"]}]},"metadata":{"completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v2.5","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220425.1"}]}}","signatures":[{"keyid":"","sig":"MEQCICfZdDyUtpLMcfEGC7Q2th9VFtL8CgGkMkTKyl50hANNAiBA4ot+7uJTIkol6ZcMfEpUO/r+ZYvze7ONrrCv24h9mQ=="}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"149bf863f6fbd75bc9a2853ad9973905b3634784bfb034a6df8bef1c238f8c35"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/tags/v0.0.1"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v2.5","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/laurentsimon/slsa-verifier-test-gen/compare/v2.5","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon","username":"laurentsimon"},"committer":{"email":"noreply@github.com","name":"GitHub","username":"web-flow"},"distinct":true,"id":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","message":"Update builder-test.yaml","timestamp":"2022-05-25T14:46:25-07:00","tree_id":"9445d61b7cb6f8193d31a19b91bf900499cb2c2f","url":"https://github.com/laurentsimon/slsa-verifier-test-gen/commit/15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"pusher":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon"},"ref":"refs/tags/v2.5","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/assignees{/user}","blobs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/blobs{/sha}","branches_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/branches{/branch}","clone_url":"https://github.com/laurentsimon/slsa-verifier-test-gen.git","collaborators_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/comments{/number}","commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/commits{/sha}","compare_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/compare/{base}...{head}","contents_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contents/{+path}","contributors_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contributors","created_at":1653514549,"default_branch":"main","deployments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/downloads","events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/events","fork":false,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/forks","full_name":"laurentsimon/slsa-verifier-test-gen","git_commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/tags{/sha}","git_url":"git://github.com/laurentsimon/slsa-verifier-test-gen.git","has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/hooks","html_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","id":496397049,"is_template":false,"issue_comment_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/events{/number}","issues_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues{/number}","keys_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/keys{/key_id}","labels_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/merges","milestones_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/milestones{/number}","mirror_url":null,"name":"slsa-verifier-test-gen","node_id":"R_kgDOHZZq-Q","notifications_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","email":"64505099+laurentsimon@users.noreply.github.com","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","name":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"private":false,"pulls_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/pulls{/number}","pushed_at":1653519445,"releases_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/releases{/id}","size":204,"ssh_url":"git@github.com:laurentsimon/slsa-verifier-test-gen.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/stargazers","statuses_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/statuses/{sha}","subscribers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscribers","subscription_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscription","svn_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/tags","teams_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/teams","topics":[],"trees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/trees{/sha}","updated_at":"2022-05-25T21:36:29Z","url":"https://github.com/laurentsimon/slsa-verifier-test-gen","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"}},"github_head_ref":"","github_ref":"refs/tags/v2.5","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2387598648","github_run_number":"4","github_sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","CGO_ENABLED=0","GO111MODULE=on"],"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"}]},"metadata":{"buildInvocationID":"2387598648-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v2.5","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEQCIGnJLB2ga9mKucnlSy1DoU/hsJcJ8Ect/sXfqQYL0WaGAiBSXRZMyIsgQpgEdXpQNVa8EF7bfz4HJAsw50kHWc3MBQ=="}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-push-v2.intoto.jsonl b/testdata/binary-linux-amd64-push-v2.intoto.jsonl index e798eef..1e3def0 100644 --- a/testdata/binary-linux-amd64-push-v2.intoto.jsonl +++ b/testdata/binary-linux-amd64-push-v2.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"6db937f07c14d309d403e561e2b402972e2a6edb32f4526e1b6b9ba855fd8574"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator-go/.github/workflows/slsa3_builder.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v2","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"entryPoint":"Test SLSA"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/asraa/slsa-on-github-test/compare/v2","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"committer":{"email":"asraa@google.com","name":"Asra Ali","username":"asraa"},"distinct":true,"id":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","message":"empty","timestamp":"2022-05-03T15:28:00-05:00","tree_id":"2d3a7894c930afd6bf0e367c968ecba42f74481f","url":"https://github.com/asraa/slsa-on-github-test/commit/9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"},"pusher":{"email":"asraa@google.com","name":"asraa"},"ref":"refs/tags/v2","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":1644939229,"default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","email":"asraa@google.com","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","name":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":1651609805,"releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1334,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://github.com/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"}},"github_head_ref":"","github_ref":"refs/tags/v2","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2266198374","github_run_number":"11","github_sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.9/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","CGO_ENABLED=0","GO111MODULE=on"]}]},"metadata":{"completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/tags/v2","digest":{"sha1":"9f1dbb239ff176c63e5bbc004de46f98fd98f8ad"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220425.1"}]}}","signatures":[{"keyid":"","sig":"MEUCIQCVYMaw7h/a10vMG9W6AGenrnnvKjXoT3xh2p4+qOw6QgIgE+ecTYYveZipFp5lGk+J5CLx0GAwMCgzhv1QPOo4wew="}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"149bf863f6fbd75bc9a2853ad9973905b3634784bfb034a6df8bef1c238f8c35"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/tags/v0.0.1"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v2","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_base_ref":"","github_event_name":"push","github_event_payload":{"after":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","base_ref":"refs/heads/main","before":"0000000000000000000000000000000000000000","commits":[],"compare":"https://github.com/laurentsimon/slsa-verifier-test-gen/compare/v2","created":true,"deleted":false,"forced":false,"head_commit":{"author":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon","username":"laurentsimon"},"committer":{"email":"noreply@github.com","name":"GitHub","username":"web-flow"},"distinct":true,"id":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","message":"Update builder-test.yaml","timestamp":"2022-05-25T14:46:25-07:00","tree_id":"9445d61b7cb6f8193d31a19b91bf900499cb2c2f","url":"https://github.com/laurentsimon/slsa-verifier-test-gen/commit/15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"pusher":{"email":"64505099+laurentsimon@users.noreply.github.com","name":"laurentsimon"},"ref":"refs/tags/v2","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/assignees{/user}","blobs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/blobs{/sha}","branches_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/branches{/branch}","clone_url":"https://github.com/laurentsimon/slsa-verifier-test-gen.git","collaborators_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/comments{/number}","commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/commits{/sha}","compare_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/compare/{base}...{head}","contents_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contents/{+path}","contributors_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contributors","created_at":1653514549,"default_branch":"main","deployments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/downloads","events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/events","fork":false,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/forks","full_name":"laurentsimon/slsa-verifier-test-gen","git_commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/tags{/sha}","git_url":"git://github.com/laurentsimon/slsa-verifier-test-gen.git","has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/hooks","html_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","id":496397049,"is_template":false,"issue_comment_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/events{/number}","issues_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues{/number}","keys_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/keys{/key_id}","labels_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"master_branch":"main","merges_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/merges","milestones_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/milestones{/number}","mirror_url":null,"name":"slsa-verifier-test-gen","node_id":"R_kgDOHZZq-Q","notifications_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","email":"64505099+laurentsimon@users.noreply.github.com","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","name":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"private":false,"pulls_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/pulls{/number}","pushed_at":1653518256,"releases_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/releases{/id}","size":204,"ssh_url":"git@github.com:laurentsimon/slsa-verifier-test-gen.git","stargazers":0,"stargazers_count":0,"stargazers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/stargazers","statuses_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/statuses/{sha}","subscribers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscribers","subscription_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscription","svn_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/tags","teams_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/teams","topics":[],"trees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/trees{/sha}","updated_at":"2022-05-25T21:36:29Z","url":"https://github.com/laurentsimon/slsa-verifier-test-gen","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"}},"github_head_ref":"","github_ref":"refs/tags/v2","github_ref_type":"tag","github_run_attempt":"1","github_run_id":"2387524945","github_run_number":"3","github_sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"}]},"metadata":{"buildInvocationID":"2387524945-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/tags/v2","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEYCIQD19+UrpONXflg3BjPvZaxiMgm+xAwd1boUoTUfhw9rUgIhAMfRfa59mTByEnAuWKBw/D79z+x8XvsNi2uFwaS0Esaz"}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-workflow_dispatch b/testdata/binary-linux-amd64-workflow_dispatch index 1839b9c..3690c2e 100644 Binary files a/testdata/binary-linux-amd64-workflow_dispatch and b/testdata/binary-linux-amd64-workflow_dispatch differ diff --git a/testdata/binary-linux-amd64-workflow_dispatch.intoto.jsonl b/testdata/binary-linux-amd64-workflow_dispatch.intoto.jsonl index cd58dc0..6441f64 100644 --- a/testdata/binary-linux-amd64-workflow_dispatch.intoto.jsonl +++ b/testdata/binary-linux-amd64-workflow_dispatch.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"6db937f07c14d309d403e561e2b402972e2a6edb32f4526e1b6b9ba855fd8574"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator-go/.github/workflows/slsa3_builder.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"a5f48fdb433884a3b43cbfc65218ffe4559f0b17"},"entryPoint":"Test SLSA"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-02-15T15:33:49Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-05-03T20:11:46Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1334,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-push.yml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_run_attempt":"1","github_run_id":"2266114228","github_run_number":"9","github_sha1":"a5f48fdb433884a3b43cbfc65218ffe4559f0b17","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.9/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"]}]},"metadata":{"completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"a5f48fdb433884a3b43cbfc65218ffe4559f0b17"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220425.1"}]}}","signatures":[{"keyid":"","sig":"MEYCIQCmavtqg43hySrWVr4TtOMx8dDXlr4BGOHNan6nmSRn2wIhAOSg1DgDcr3pWB44Xe5u/mCtBcRa/gf+lkj4+sqhu9Ce"}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"149bf863f6fbd75bc9a2853ad9973905b3634784bfb034a6df8bef1c238f8c35"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/tags/v0.0.1"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/heads/main","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/assignees{/user}","blobs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/blobs{/sha}","branches_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/branches{/branch}","clone_url":"https://github.com/laurentsimon/slsa-verifier-test-gen.git","collaborators_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/comments{/number}","commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/commits{/sha}","compare_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/compare/{base}...{head}","contents_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contents/{+path}","contributors_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/contributors","created_at":"2022-05-25T21:35:49Z","default_branch":"main","deployments_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/downloads","events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/events","fork":false,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/forks","full_name":"laurentsimon/slsa-verifier-test-gen","git_commits_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/tags{/sha}","git_url":"git://github.com/laurentsimon/slsa-verifier-test-gen.git","has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/hooks","html_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","id":496397049,"is_template":false,"issue_comment_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues/events{/number}","issues_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/issues{/number}","keys_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/keys{/key_id}","labels_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/merges","milestones_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/milestones{/number}","mirror_url":null,"name":"slsa-verifier-test-gen","node_id":"R_kgDOHZZq-Q","notifications_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"private":false,"pulls_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/pulls{/number}","pushed_at":"2022-05-25T22:57:25Z","releases_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/releases{/id}","size":204,"ssh_url":"git@github.com:laurentsimon/slsa-verifier-test-gen.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/stargazers","statuses_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/statuses/{sha}","subscribers_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscribers","subscription_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/subscription","svn_url":"https://github.com/laurentsimon/slsa-verifier-test-gen","tags_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/tags","teams_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/teams","topics":[],"trees_url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen/git/trees{/sha}","updated_at":"2022-05-25T21:36:29Z","url":"https://api.github.com/repos/laurentsimon/slsa-verifier-test-gen","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"workflow":".github/workflows/builder-test.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_run_attempt":"1","github_run_id":"2387611653","github_run_number":"5","github_sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-verifier-test-gen/slsa-verifier-test-gen"}]},"metadata":{"buildInvocationID":"2387611653-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/laurentsimon/slsa-verifier-test-gen@refs/heads/main","digest":{"sha1":"15bf79ea9c89fffbf5dd02c6b5b686b291bfcbd2"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEQCICc1T/TjVMIVhZr9BbsDuYVnzgHakmGyibLLyJXPZox9AiARgu6v/aCR3DK1gEyfnXdYx2bUtsHpihU8Y6kge2xWYg=="}]} \ No newline at end of file