Skip to content

Commit

Permalink
Pipe stdout/stderr of utils.RunCommand to machine logs
Browse files Browse the repository at this point in the history
This will allow us to immediately see any errors if any commands fail
  • Loading branch information
benwaffle committed Jun 19, 2024
1 parent f682f39 commit 704e844
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 2 deletions.
2 changes: 1 addition & 1 deletion internal/flypg/state/store.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ func clientConfig() (*api.Config, error) {

token, set := u.User.Password()
if !set {
return nil, fmt.Errorf("token not set")
return nil, fmt.Errorf("consul token not set")
}

u.User = nil
Expand Down
17 changes: 16 additions & 1 deletion internal/utils/shell.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package utils

import (
"bytes"
"fmt"
"io"
"os"
"os/exec"
"os/user"
Expand All @@ -15,11 +17,24 @@ func RunCommand(cmdStr, usr string) ([]byte, error) {
return nil, err
}

fmt.Printf("> Running command as %s: %s\n", usr, cmdStr)

cmd := exec.Command("sh", "-c", cmdStr)
cmd.SysProcAttr = &syscall.SysProcAttr{}
cmd.SysProcAttr.Credential = &syscall.Credential{Uid: uint32(uid), Gid: uint32(gid)}

return cmd.Output()
var stdoutBuf, stderrBuf bytes.Buffer
cmd.Stdout = io.MultiWriter(os.Stdout, &stdoutBuf)
cmd.Stderr = io.MultiWriter(os.Stderr, &stderrBuf)

err = cmd.Run()
if err != nil {
if ee, ok := err.(*exec.ExitError); ok {
ee.Stderr = stderrBuf.Bytes()
}
}

return stdoutBuf.Bytes(), err
}

func SetFileOwnership(pathToFile, owner string) error {
Expand Down

0 comments on commit 704e844

Please sign in to comment.