Skip to content

Commit

Permalink
fix(secret): update env values for secret origin ctn
Browse files Browse the repository at this point in the history
  • Loading branch information
ecrupper committed Nov 9, 2024
1 parent 402d3d0 commit 98e16b8
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 3 deletions.
22 changes: 21 additions & 1 deletion executor/linux/build.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (

"golang.org/x/sync/errgroup"

"github.com/go-vela/sdk-go/vela"
api "github.com/go-vela/server/api/types"
"github.com/go-vela/server/compiler/types/pipeline"
"github.com/go-vela/server/constants"
Expand Down Expand Up @@ -356,8 +357,27 @@ func (c *client) AssembleBuild(ctx context.Context) error {
}

c.Logger.Infof("creating %s secret", s.Origin.Name)

// fetch request token if id_request used in origin config
var requestToken string

if len(s.Origin.IDRequest) > 0 {
opts := &vela.RequestTokenOptions{
Image: s.Origin.Image,
Request: s.Origin.IDRequest,
Commands: len(s.Origin.Commands) > 0 || len(s.Origin.Entrypoint) > 0,
}

tkn, _, err := c.Vela.Build.GetIDRequestToken(c.build.GetRepo().GetOrg(), c.build.GetRepo().GetName(), c.build.GetNumber(), opts)
if err != nil {
return err
}

requestToken = tkn.GetToken()
}

// create the service
c.err = c.secret.create(ctx, s.Origin)
c.err = c.secret.create(ctx, s.Origin, requestToken)
if c.err != nil {
return fmt.Errorf("unable to create %s secret: %w", s.Origin.Name, c.err)
}
Expand Down
8 changes: 7 additions & 1 deletion executor/linux/secret.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ var (
)

// create configures the secret plugin for execution.
func (s *secretSvc) create(ctx context.Context, ctn *pipeline.Container) error {
func (s *secretSvc) create(ctx context.Context, ctn *pipeline.Container, reqToken string) error {
// update engine logger with secret metadata
//
// https://pkg.go.dev/github.com/sirupsen/logrus#Entry.WithField
Expand All @@ -45,6 +45,12 @@ func (s *secretSvc) create(ctx context.Context, ctn *pipeline.Container) error {
ctn.Environment["VELA_HOST"] = s.client.build.GetHost()
ctn.Environment["VELA_RUNTIME"] = s.client.build.GetRuntime()
ctn.Environment["VELA_VERSION"] = s.client.Version
ctn.Environment["VELA_OUTPUTS"] = "/vela/outputs/.env"
ctn.Environment["VELA_MASKED_OUTPUTS"] = "/vela/outputs/masked.env"

if len(reqToken) > 0 {
ctn.Environment["VELA_ID_TOKEN_REQUEST_TOKEN"] = reqToken
}

logger.Debug("setting up container")
// setup the runtime container
Expand Down
2 changes: 1 addition & 1 deletion executor/linux/secret_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ func TestLinux_Secret_create(t *testing.T) {
t.Errorf("unable to create %s executor engine: %v", test.name, err)
}

err = _engine.secret.create(context.Background(), test.container)
err = _engine.secret.create(context.Background(), test.container, "")

if test.failure {
if err == nil {
Expand Down

0 comments on commit 98e16b8

Please sign in to comment.