Merge pull request #1681 from helderco/trim-secret
Add #TrimSecret task
This commit is contained in:
commit
64e8afb3f3
@ -27,3 +27,14 @@ package dagger
|
|||||||
// Contents of the secret
|
// Contents of the secret
|
||||||
output: #Secret
|
output: #Secret
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Trim leading and trailing space characters from a secret
|
||||||
|
#TrimSecret: {
|
||||||
|
$dagger: task: _name: "TrimSecret"
|
||||||
|
|
||||||
|
// Original secret
|
||||||
|
input: #Secret
|
||||||
|
|
||||||
|
// New trimmed secret
|
||||||
|
output: #Secret
|
||||||
|
}
|
||||||
|
31
plan/task/trimsecret.go
Normal file
31
plan/task/trimsecret.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package task
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"go.dagger.io/dagger/compiler"
|
||||||
|
"go.dagger.io/dagger/plancontext"
|
||||||
|
"go.dagger.io/dagger/solver"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
Register("TrimSecret", func() Task { return &trimSecretTask{} })
|
||||||
|
}
|
||||||
|
|
||||||
|
type trimSecretTask struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *trimSecretTask) Run(ctx context.Context, pctx *plancontext.Context, s solver.Solver, v *compiler.Value) (*compiler.Value, error) {
|
||||||
|
input, err := pctx.Secrets.FromValue(v.Lookup("input"))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
plaintext := strings.TrimSpace(input.PlainText())
|
||||||
|
secret := pctx.Secrets.New(plaintext)
|
||||||
|
|
||||||
|
return compiler.NewValue().FillFields(map[string]interface{}{
|
||||||
|
"output": secret.MarshalCUE(),
|
||||||
|
})
|
||||||
|
}
|
@ -134,6 +134,12 @@ setup() {
|
|||||||
"$DAGGER" up ./newsecret.cue
|
"$DAGGER" up ./newsecret.cue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@test "task: #TrimSecret" {
|
||||||
|
cd "$TESTDIR"/tasks/trimsecret
|
||||||
|
|
||||||
|
"$DAGGER" up ./trimsecret.cue
|
||||||
|
}
|
||||||
|
|
||||||
@test "task: #Source" {
|
@test "task: #Source" {
|
||||||
cd "$TESTDIR"/tasks/source
|
cd "$TESTDIR"/tasks/source
|
||||||
"$DAGGER" up ./source.cue
|
"$DAGGER" up ./source.cue
|
||||||
|
42
tests/tasks/trimsecret/trimsecret.cue
Normal file
42
tests/tasks/trimsecret/trimsecret.cue
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"dagger.io/dagger"
|
||||||
|
)
|
||||||
|
|
||||||
|
dagger.#Plan & {
|
||||||
|
actions: {
|
||||||
|
image: dagger.#Pull & {
|
||||||
|
source: "alpine:3.15.0@sha256:e7d88de73db3d3fd9b2d63aa7f447a10fd0220b7cbf39803c803f2af9ba256b3"
|
||||||
|
}
|
||||||
|
|
||||||
|
generate: dagger.#Exec & {
|
||||||
|
input: image.output
|
||||||
|
args: ["sh", "-c", "echo ' test ' > /secret"]
|
||||||
|
}
|
||||||
|
|
||||||
|
load: dagger.#NewSecret & {
|
||||||
|
input: generate.output
|
||||||
|
trimSpace: false
|
||||||
|
path: "/secret"
|
||||||
|
}
|
||||||
|
|
||||||
|
trim: dagger.#TrimSecret & {
|
||||||
|
input: load.output
|
||||||
|
}
|
||||||
|
|
||||||
|
verify: dagger.#Exec & {
|
||||||
|
input: image.output
|
||||||
|
mounts: secret: {
|
||||||
|
dest: "/run/secrets/test"
|
||||||
|
contents: trim.output
|
||||||
|
}
|
||||||
|
args: [
|
||||||
|
"sh", "-c",
|
||||||
|
#"""
|
||||||
|
test "$(cat /run/secrets/test)" = "test"
|
||||||
|
"""#,
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user