Skip to content

Commit ae29694

Browse files
asraalaurentsimon
andauthored
🐛 Retrieve branch on release triggers (#89) (#146)
* updates * unit test * fixes * updates * typo * unit test Co-authored-by: laurentsimon <[email protected]>
1 parent eea3a5d commit ae29694

File tree

4 files changed

+69
-9
lines changed

4 files changed

+69
-9
lines changed

main_test.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -226,7 +226,7 @@ func Test_runVerify(t *testing.T) {
226226
pversiontag: pString("v0"),
227227
err: pkg.ErrorMismatchVersionedTag,
228228
},
229-
// Provenance contains tag = v14.2. )2.5
229+
// Provenance contains tag = v14.2
230230
{
231231
name: "versioned v14.2 match push-v14.2",
232232
artifact: "binary-linux-amd64-push-v14.2",

pkg/provenance.go

+61-7
Original file line numberDiff line numberDiff line change
@@ -625,6 +625,20 @@ func getAsString(environment map[string]interface{}, field string) (string, erro
625625
return i, nil
626626
}
627627

628+
func getEventPayload(environment map[string]interface{}) (map[string]interface{}, error) {
629+
eventPayload, ok := environment["github_event_payload"]
630+
if !ok {
631+
return nil, fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "parameters type event payload")
632+
}
633+
634+
payload, ok := eventPayload.(map[string]interface{})
635+
if !ok {
636+
return nil, fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "parameters type payload")
637+
}
638+
639+
return payload, nil
640+
}
641+
628642
func getBaseRef(environment map[string]interface{}) (string, error) {
629643
baseRef, err := getAsString(environment, "github_base_ref")
630644
if err != nil {
@@ -638,7 +652,7 @@ func getBaseRef(environment map[string]interface{}) (string, error) {
638652

639653
// Look at the event payload instead.
640654
// We don't do that for all triggers because the payload
641-
// is event-specific; and only the `push` event seems to have a `base_ref``.
655+
// is event-specific; and only the `push` event seems to have a `base_ref`.
642656
eventName, err := getAsString(environment, "github_event_name")
643657
if err != nil {
644658
return "", err
@@ -648,17 +662,57 @@ func getBaseRef(environment map[string]interface{}) (string, error) {
648662
return "", nil
649663
}
650664

651-
eventPayload, ok := environment["github_event_payload"]
665+
payload, err := getEventPayload(environment)
666+
if err != nil {
667+
return "", err
668+
}
669+
670+
return getAsString(payload, "base_ref")
671+
}
672+
673+
func getTargetCommittish(environment map[string]interface{}) (string, error) {
674+
eventName, err := getAsString(environment, "github_event_name")
675+
if err != nil {
676+
return "", err
677+
}
678+
679+
if eventName != "release" {
680+
return "", nil
681+
}
682+
683+
payload, err := getEventPayload(environment)
684+
if err != nil {
685+
return "", err
686+
}
687+
688+
// For a release event, we look for release.target_commitish.
689+
releasePayload, ok := payload["release"]
652690
if !ok {
653-
return "", fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "parameters type event payload")
691+
return "", fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "release absent from payload")
654692
}
655693

656-
payload, ok := eventPayload.(map[string]interface{})
694+
release, ok := releasePayload.(map[string]interface{})
657695
if !ok {
658-
return "", fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "parameters type payload")
696+
return "", fmt.Errorf("%w: %s", ErrorInvalidDssePayload, "parameters type releasePayload")
659697
}
660698

661-
return getAsString(payload, "base_ref")
699+
branch, err := getAsString(release, "target_commitish")
700+
if err != nil {
701+
return "", fmt.Errorf("%w: %s", err, "target_commitish not present")
702+
}
703+
704+
return "refs/heads/" + branch, nil
705+
}
706+
707+
func getBranchForTag(environment map[string]interface{}) (string, error) {
708+
// First try the base_ref.
709+
branch, err := getBaseRef(environment)
710+
if branch != "" || err != nil {
711+
return branch, err
712+
}
713+
714+
// Second try the target comittish.
715+
return getTargetCommittish(environment)
662716
}
663717

664718
// Get tag from the provenance invocation parameters.
@@ -720,7 +774,7 @@ func getBranch(env *dsselib.Envelope) (string, error) {
720774
case "branch":
721775
return getAsString(environment, "github_ref")
722776
case "tag":
723-
return getBaseRef(environment)
777+
return getBranchForTag(environment)
724778
default:
725779
return "", fmt.Errorf("%w: %s %s", ErrorInvalidDssePayload,
726780
"unknown ref type", refType)

pkg/provenance_test.go

+6-1
Original file line numberDiff line numberDiff line change
@@ -353,10 +353,15 @@ func Test_VerifyBranch(t *testing.T) {
353353
expected: ErrorInvalidDssePayload,
354354
},
355355
{
356-
name: "tag branch2",
356+
name: "tag branch2 push trigger",
357357
path: "./testdata/dsse-branch2-tag.intoto.jsonl",
358358
branch: "branch2",
359359
},
360+
{
361+
name: "v10.0.1 release trigger",
362+
path: "./testdata/dsse-v10.0.1-release.intoto.jsonl",
363+
branch: "main",
364+
},
360365
}
361366
for _, tt := range tests {
362367
tt := tt // Re-initializing variable so it is not changed while executing the closure below
Original file line numberDiff line numberDiff line change
@@ -0,0 +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":"scorecard-linux-amd64","digest":{"sha256":"04d9166db6ffcb030e0b205fc5b598cd54742f938265c663ae0c1e8932c6d5df"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/tags/v1.0.0"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/go@v1","invocation":{"configSource":{"uri":"git+https://github.com/laurentsimon/scorecard-copy@refs/tags/v10.0.1","digest":{"sha1":"6cd29dd1cf2c72f0539b50405d75338555366351"},"entryPoint":".github/workflows/slsa-releaser.yml"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_actor_id":"64505099","github_base_ref":"","github_event_name":"release","github_event_payload":{"action":"created","release":{"assets":[],"assets_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/releases/69006023/assets","author":{"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"},"body":"v10.0.1 for release created trigger","created_at":"2022-06-08T22:48:37Z","draft":false,"html_url":"https://github.com/laurentsimon/scorecard-copy/releases/tag/v10.0.1","id":69006023,"name":"v10.0.1","node_id":"RE_kwDOHdy3L84EHPLH","prerelease":false,"published_at":"2022-06-08T22:49:14Z","tag_name":"v10.0.1","tarball_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/tarball/v10.0.1","target_commitish":"main","upload_url":"https://uploads.github.com/repos/laurentsimon/scorecard-copy/releases/69006023/assets{?name,label}","url":"https://api.github.com/repos/laurentsimon/scorecard-copy/releases/69006023","zipball_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/zipball/v10.0.1"},"repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/assignees{/user}","blobs_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/git/blobs{/sha}","branches_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/branches{/branch}","clone_url":"https://github.com/laurentsimon/scorecard-copy.git","collaborators_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/comments{/number}","commits_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/commits{/sha}","compare_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/compare/{base}...{head}","contents_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/contents/{+path}","contributors_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/contributors","created_at":"2022-06-07T21:06:57Z","default_branch":"main","deployments_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/downloads","events_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/events","fork":false,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/forks","full_name":"laurentsimon/scorecard-copy","git_commits_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/git/tags{/sha}","git_url":"git://github.com/laurentsimon/scorecard-copy.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/scorecard-copy/hooks","html_url":"https://github.com/laurentsimon/scorecard-copy","id":501004079,"is_template":false,"issue_comment_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/issues/events{/number}","issues_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/issues{/number}","keys_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/keys{/key_id}","labels_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/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/scorecard-copy/merges","milestones_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/milestones{/number}","mirror_url":null,"name":"scorecard-copy","node_id":"R_kgDOHdy3Lw","notifications_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/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/scorecard-copy/pulls{/number}","pushed_at":"2022-06-08T22:49:14Z","releases_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/releases{/id}","size":35611,"ssh_url":"git@github.com:laurentsimon/scorecard-copy.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/stargazers","statuses_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/statuses/{sha}","subscribers_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/subscribers","subscription_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/subscription","svn_url":"https://github.com/laurentsimon/scorecard-copy","tags_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/tags","teams_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/teams","topics":[],"trees_url":"https://api.github.com/repos/laurentsimon/scorecard-copy/git/trees{/sha}","updated_at":"2022-06-07T21:25:29Z","url":"https://api.github.com/repos/laurentsimon/scorecard-copy","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/v10.0.1","github_ref_type":"tag","github_repository_id":"501004079","github_repository_owner":"laurentsimon","github_repository_owner_id":"64505099","github_run_attempt":"1","github_run_id":"2464827829","github_run_number":"6","github_sha1":"6cd29dd1cf2c72f0539b50405d75338555366351","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/scorecard-copy/scorecard-copy"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-ldflags=-s -X sigs.k8s.io/release-utils/version.gitVersion=v10.0.1 -X sigs.k8s.io/release-utils/version.gitCommit=6cd29dd1cf2c72f0539b50405d75338555366351 -X sigs.k8s.io/release-utils/version.gitTreeState=clean -X sigs.k8s.io/release-utils/version.buildDate=1654728517 -w -extldflags \"-static\"","-o","scorecard-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/scorecard-copy/scorecard-copy"}]},"metadata":{"buildInvocationID":"2464827829-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/laurentsimon/scorecard-copy@refs/tags/v10.0.1","digest":{"sha1":"6cd29dd1cf2c72f0539b50405d75338555366351"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220529.1"}]}}","signatures":[{"keyid":"","sig":"MEQCIDOfrIqWkHmrHJcW3qx7csxTndprBX/Y/QuDiL5KHa0FAiBGoYBFK/4lrXDpzG2ch+WAqU4WPxgx7nRulmyLhWVxIg=="}]}

0 commit comments

Comments
 (0)