cert-manager-webhook-sthome/pkg/dns/shell.go

57 lines
1.4 KiB
Go

package dns
import (
"bytes"
"fmt"
"io"
"os"
"os/exec"
"strings"
"k8s.io/klog/v2"
)
func Execute(shell string, arg ...string) (bool, error) {
var outb, errb bytes.Buffer
cmd := exec.Command(shell, arg...)
cmd.Dir = AcmeDir
cmd.Stdout = &outb
cmd.Stderr = &errb
klog.Infof("cmd: %s\n", cmd.String())
err := cmd.Run()
outstr := strings.TrimSuffix(outb.String(), "\n")
errstr := strings.TrimSuffix(errb.String(), "\n")
klog.Infof("out:\n%s\n", outstr)
if err != nil {
klog.Errorf("Script returned error:\nerr:\n")
klog.Errorf("%s\n============\n", err)
return false, err
}
if errb.String() != "" {
klog.Infof("stderr:\n")
klog.Errorf("%s\n============\n", errstr)
return false, fmt.Errorf("stderr:\n%q", errstr)
}
klog.Infof("Script returned success\n")
return true, nil
}
// https://blog.kowalczyk.info/article/wOYk/advanced-command-execution-in-go-with-osexec.html
func Execute2(shell string, arg ...string) (bool, error) {
var stdoutBuf, stderrBuf bytes.Buffer
cmd := exec.Command(shell, arg...)
cmd.Stdout = io.MultiWriter(os.Stdout, &stdoutBuf)
cmd.Stderr = io.MultiWriter(os.Stderr, &stderrBuf)
err := cmd.Run()
if err != nil {
klog.Errorf("Script returned error:\nerr:\n")
klog.Errorf("%s\n============\n", err)
return false, err
}
outStr, errStr := string(stdoutBuf.String()), string(stderrBuf.String())
fmt.Printf("\nout:\n%s\nerr:\n%s\n", outStr, errStr)
klog.Infof("Script returned success\n")
return true, nil
}