19c0f999f4
Resolve #1551 and #1020. We are never returning the result of solved operations so Buildkit could not cache the layer. This commit implements a simple system to forward operations' result to the main build to cache it. Signed-off-by: Vasek - Tom C <tom.chauveau@epitech.eu>
55 lines
1.2 KiB
Go
55 lines
1.2 KiB
Go
package task
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"io/fs"
|
|
"strings"
|
|
|
|
"go.dagger.io/dagger/compiler"
|
|
"go.dagger.io/dagger/plancontext"
|
|
"go.dagger.io/dagger/solver"
|
|
)
|
|
|
|
func init() {
|
|
Register("NewSecret", func() Task { return &newSecretTask{} })
|
|
}
|
|
|
|
type newSecretTask struct {
|
|
}
|
|
|
|
func (t *newSecretTask) Run(_ context.Context, pctx *plancontext.Context, _ *solver.Solver, v *compiler.Value) (*compiler.Value, error) {
|
|
path, err := v.Lookup("path").String()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
input, err := pctx.FS.FromValue(v.Lookup("input"))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
inputFS := solver.NewBuildkitFS(input.Result())
|
|
|
|
// FIXME: we should create an intermediate image containing only `path`.
|
|
// That way, on cache misses, we'll only download the layer with the file contents rather than the entire FS.
|
|
contents, err := fs.ReadFile(inputFS, path)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("ReadFile %s: %w", path, err)
|
|
}
|
|
plaintext := string(contents)
|
|
|
|
trimSpace, err := v.Lookup("trimSpace").Bool()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if trimSpace {
|
|
plaintext = strings.TrimSpace(plaintext)
|
|
}
|
|
|
|
secret := pctx.Secrets.New(plaintext)
|
|
|
|
return compiler.NewValue().FillFields(map[string]interface{}{
|
|
"output": secret.MarshalCUE(),
|
|
})
|
|
}
|