2022-01-05 04:27:54 +01:00
|
|
|
package task
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
2022-01-06 21:13:51 +01:00
|
|
|
"strings"
|
2022-01-05 04:27:54 +01:00
|
|
|
|
|
|
|
"cuelang.org/go/cue"
|
|
|
|
"github.com/rs/zerolog/log"
|
2022-01-06 21:13:51 +01:00
|
|
|
"github.com/sergi/go-diff/diffmatchpatch"
|
2022-01-05 04:27:54 +01:00
|
|
|
"go.dagger.io/dagger/compiler"
|
|
|
|
"go.dagger.io/dagger/plancontext"
|
|
|
|
"go.dagger.io/dagger/solver"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
Register("TransformSecret", func() Task { return &transformSecretTask{} })
|
|
|
|
}
|
|
|
|
|
|
|
|
type transformSecretTask struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *transformSecretTask) Run(ctx context.Context, pctx *plancontext.Context, _ solver.Solver, v *compiler.Value) (*compiler.Value, error) {
|
|
|
|
lg := log.Ctx(ctx)
|
|
|
|
lg.Debug().Msg("transforming secret")
|
|
|
|
|
|
|
|
input := v.Lookup("input")
|
|
|
|
|
|
|
|
inputSecret, err := pctx.Secrets.FromValue(input)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
function := v.Lookup("#function")
|
2022-01-06 21:13:51 +01:00
|
|
|
inputSecretPlaintext := inputSecret.PlainText()
|
|
|
|
err = function.FillPath(cue.ParsePath("input"), inputSecretPlaintext)
|
2022-01-05 04:27:54 +01:00
|
|
|
if err != nil {
|
2022-01-06 21:13:51 +01:00
|
|
|
dmp := diffmatchpatch.New()
|
|
|
|
errStr := err.Error()
|
|
|
|
diffs := dmp.DiffMain(inputSecretPlaintext, err.Error(), false)
|
|
|
|
for _, diff := range diffs {
|
|
|
|
if diff.Type == diffmatchpatch.DiffEqual {
|
|
|
|
diffText := strings.ReplaceAll(diff.Text, ":", "")
|
|
|
|
errStr = strings.ReplaceAll(errStr, diffText, "<redacted>")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil, errors.New(errStr)
|
2022-01-05 04:27:54 +01:00
|
|
|
}
|
|
|
|
|
2022-01-06 21:13:51 +01:00
|
|
|
output := compiler.NewValue()
|
|
|
|
// users could yaml.Unmarshal(input) and return a map
|
|
|
|
// or yaml.Unmarshal(input).someKey and return a string
|
|
|
|
// walk will ensure we convert every leaf
|
|
|
|
functionPathSelectors := function.Path().Selectors()
|
|
|
|
function.Lookup("output").Walk(nil, func(v *compiler.Value) {
|
|
|
|
if v.Kind() == cue.StringKind {
|
|
|
|
plaintext, _ := v.String()
|
|
|
|
secret := pctx.Secrets.New(plaintext)
|
|
|
|
newLeafSelectors := v.Path().Selectors()[len(functionPathSelectors):]
|
|
|
|
newLeafSelectors = append(newLeafSelectors, cue.Str("contents"))
|
|
|
|
newLeafPath := cue.MakePath(newLeafSelectors...)
|
|
|
|
output.FillPath(newLeafPath, secret.MarshalCUE())
|
|
|
|
}
|
2022-01-05 04:27:54 +01:00
|
|
|
})
|
2022-01-06 21:13:51 +01:00
|
|
|
|
|
|
|
return output, nil
|
2022-01-05 04:27:54 +01:00
|
|
|
}
|