Skip to content

Commit

Permalink
Merge pull request #1474 from felixfontein/exec-filename
Browse files Browse the repository at this point in the history
exec-file: if `--filename` is used, use the provided filename without random suffix
  • Loading branch information
devstein authored Jun 11, 2024
2 parents aa00ab6 + 417c20a commit 0da6be8
Show file tree
Hide file tree
Showing 3 changed files with 71 additions and 9 deletions.
9 changes: 2 additions & 7 deletions cmd/sops/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ func main() {
},
cli.StringFlag{
Name: "filename",
Usage: "filename for the temporarily file (default: tmp-file)",
Usage: fmt.Sprintf("filename for the temporarily file (default: %s)", exec.FallbackFilename),
},
}, keyserviceFlags...),
Action: func(c *cli.Context) error {
Expand Down Expand Up @@ -272,11 +272,6 @@ func main() {
return toExitError(err)
}

filename := c.String("filename")
if filename == "" {
filename = "tmp-file"
}

if c.Bool("background") {
log.Warn("exec-file's --background option is deprecated and will be removed in a future version of sops")
}
Expand All @@ -287,7 +282,7 @@ func main() {
Background: c.Bool("background"),
Fifo: !c.Bool("no-fifo"),
User: c.String("user"),
Filename: filename,
Filename: c.String("filename"),
}); err != nil {
return toExitError(err)
}
Expand Down
28 changes: 26 additions & 2 deletions cmd/sops/subcommand/exec/exec.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package exec
import (
"bytes"
"os"
"path/filepath"
"runtime"
"strings"

Expand All @@ -11,6 +12,10 @@ import (
"github.com/sirupsen/logrus"
)

const (
FallbackFilename = "tmp-file"
)

var log *logrus.Logger

func init() {
Expand All @@ -28,10 +33,23 @@ type ExecOpts struct {
}

func GetFile(dir, filename string) *os.File {
handle, err := os.CreateTemp(dir, filename)
// If no filename is provided, create a random one based on FallbackFilename
if filename == "" {
handle, err := os.CreateTemp(dir, FallbackFilename)
if err != nil {
log.Fatal(err)
}
return handle
}
// If a filename is provided, use that one
handle, err := os.Create(filepath.Join(dir, filename))
if err != nil {
log.Fatal(err)
}
// read+write for owner only
if err = handle.Chmod(0600); err != nil {
log.Fatal(err)
}
return handle
}

Expand All @@ -55,9 +73,15 @@ func ExecWithFile(opts ExecOpts) error {
if opts.Fifo {
// fifo handling needs to be async, even opening to write
// will block if there is no reader present
filename = GetPipe(dir, opts.Filename)
filename = opts.Filename
if filename == "" {
filename = FallbackFilename
}
filename = GetPipe(dir, filename)
go WritePipe(filename, opts.Plaintext)
} else {
// GetFile handles opts.Filename == "" specially, that's why we have
// to pass in opts.Filename without handling the fallback here
handle := GetFile(dir, opts.Filename)
handle.Write(opts.Plaintext)
handle.Close()
Expand Down
43 changes: 43 additions & 0 deletions functional-tests/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -949,4 +949,47 @@ bar: |-
}"#
);
}

#[test]
fn exec_file_filename() {
let file_path = prepare_temp_file(
"test_exec_file_filename.yaml",
r#"foo: bar
bar: |-
baz
bam
"#
.as_bytes(),
);
assert!(
Command::new(SOPS_BINARY_PATH)
.arg("-e")
.arg("-i")
.arg(file_path.clone())
.output()
.expect("Error running sops")
.status
.success(),
"sops didn't exit successfully"
);
let output = Command::new(SOPS_BINARY_PATH)
.arg("exec-file")
.arg("--no-fifo")
.arg("--filename")
.arg("foobar")
.arg(file_path.clone())
.arg("echo {}")
.output()
.expect("Error running sops");
assert!(output.status.success(), "sops didn't exit successfully");
println!(
"stdout: {}, stderr: {}",
String::from_utf8_lossy(&output.stdout),
String::from_utf8_lossy(&output.stderr)
);
assert!(
String::from_utf8_lossy(&output.stdout).ends_with("foobar\n"),
"filename did not end with 'foobar'"
);
}
}

0 comments on commit 0da6be8

Please sign in to comment.