Skip to content

Commit

Permalink
Adding Gitpod Provider
Browse files Browse the repository at this point in the history
Signed-off-by: Edward Brough <[email protected]>
  • Loading branch information
ChevronTango committed Mar 15, 2024
1 parent 5d60a9a commit 69d0c37
Show file tree
Hide file tree
Showing 3 changed files with 71 additions and 0 deletions.
7 changes: 7 additions & 0 deletions pkg/cosign/env/env.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,7 @@ const (
VariableGitHubToken Variable = "GITHUB_TOKEN" //nolint:gosec
VariableGitHubRequestToken Variable = "ACTIONS_ID_TOKEN_REQUEST_TOKEN"
VariableGitHubRequestURL Variable = "ACTIONS_ID_TOKEN_REQUEST_URL"
VariableGitpodWorkspaceId Variable = "GITPOD_WORKSPACE_ID"
VariableSPIFFEEndpointSocket Variable = "SPIFFE_ENDPOINT_SOCKET"
VariableGoogleServiceAccountName Variable = "GOOGLE_SERVICE_ACCOUNT_NAME"
VariableGitLabHost Variable = "GITLAB_HOST"
Expand Down Expand Up @@ -157,6 +158,12 @@ var (
Sensitive: false,
External: true,
},
VariableGitpodWorkspaceId: {
Description: "is the ID of the workspace in Gitpod",
Expects: "string with the ID of the Gitpod workspace",
Sensitive: false,
External: true,
},
VariableSPIFFEEndpointSocket: {
Description: "allows you to specify non-default SPIFFE socket to use.",
Expects: "string with SPIFFE socket path",
Expand Down
18 changes: 18 additions & 0 deletions pkg/providers/gitpod/doc.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
//
// Copyright 2021 The Sigstore Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

// Package gitpod defines an implementation of the providers.Interface
// that reads identity tokens from the gitpod API within a workspace.
package gitpod
46 changes: 46 additions & 0 deletions pkg/providers/gitpod/gitpod.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
//
// Copyright 2021 The Sigstore Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package gitpod

import (
"context"
"os/exec"

"github.com/sigstore/cosign/v2/pkg/cosign/env"
"github.com/sigstore/cosign/v2/pkg/providers"
)

func init() {
providers.Register("filesystem", &gitpod{})
}

type gitpod struct{}

var _ providers.Interface = (*gitpod)(nil)

// Enabled implements providers.Interface
func (ga *gitpod) Enabled(_ context.Context) bool {
return env.Getenv(env.VariableGitpodWorkspaceId) != ""
}

// Provide implements providers.Interface
func (ga *gitpod) Provide(ctx context.Context, audience string) (string, error) {
token, err := exec.Command("gp idp token --audience " + audience).Output()
if err != nil {
return "", err
}
return string(token), nil
}

0 comments on commit 69d0c37

Please sign in to comment.