mirror of
https://github.com/davegallant/vpngate.git
synced 2026-03-03 10:06:36 +00:00
Refactor codebase
This commit is contained in:
@@ -2,46 +2,58 @@ package exec
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"os"
|
||||
"io"
|
||||
"os/exec"
|
||||
"strings"
|
||||
|
||||
"github.com/rs/zerolog/log"
|
||||
)
|
||||
|
||||
// Run executes a command in workDir and returns stdout and error.
|
||||
// The spawned process will exit upon termination of this application
|
||||
// to ensure a clean exit
|
||||
// Run executes a command in workDir and logs its output.
|
||||
// If the command fails to start or setup fails, an error is logged and returned.
|
||||
// If the command exits with a non-zero status, the error is returned without logging
|
||||
// (this allows the caller to decide how to handle it).
|
||||
func Run(path string, workDir string, args ...string) error {
|
||||
_, err := exec.LookPath(path)
|
||||
if err != nil {
|
||||
log.Error().Msgf("%s is required, please install it", path)
|
||||
os.Exit(1)
|
||||
return err
|
||||
}
|
||||
|
||||
cmd := exec.Command(path, args...)
|
||||
cmd.Dir = workDir
|
||||
log.Debug().Msg("Executing " + strings.Join(cmd.Args, " "))
|
||||
|
||||
log.Debug().Strs("command", cmd.Args).Msg("Executing command")
|
||||
|
||||
stdout, err := cmd.StdoutPipe()
|
||||
if err != nil {
|
||||
log.Fatal().Msgf("Failed to get stdout pipe: %v", err)
|
||||
log.Error().Msgf("Failed to get stdout pipe: %v", err)
|
||||
return err
|
||||
}
|
||||
|
||||
stderr, err := cmd.StderrPipe()
|
||||
if err != nil {
|
||||
log.Error().Msgf("Failed to get stderr pipe: %v", err)
|
||||
return err
|
||||
}
|
||||
|
||||
if err := cmd.Start(); err != nil {
|
||||
log.Fatal().Msgf("Failed to start command: %v", err)
|
||||
log.Error().Msgf("Failed to start command: %v", err)
|
||||
return err
|
||||
}
|
||||
|
||||
scanner := bufio.NewScanner(stdout)
|
||||
|
||||
// Combine stdout and stderr into a single reader
|
||||
combined := io.MultiReader(stdout, stderr)
|
||||
scanner := bufio.NewScanner(combined)
|
||||
for scanner.Scan() {
|
||||
log.Debug().Msg(scanner.Text())
|
||||
}
|
||||
|
||||
if err := scanner.Err(); err != nil {
|
||||
log.Fatal().Msgf("Error reading stdout: %v", err)
|
||||
}
|
||||
|
||||
if err := cmd.Wait(); err != nil {
|
||||
log.Fatal().Msgf("Command finished with error: %v", err)
|
||||
log.Error().Msgf("Error reading output: %v", err)
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// cmd.Wait() returns an error if the command exits with non-zero status
|
||||
// We return this without logging since it's expected behavior for some commands
|
||||
return cmd.Wait()
|
||||
}
|
||||
Reference in New Issue
Block a user