netclientutils_freebsd.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. package ncutils
  2. import (
  3. "context"
  4. "os/exec"
  5. "strings"
  6. "syscall"
  7. "time"
  8. "github.com/gravitl/netmaker/logger"
  9. )
  10. // RunCmdFormatted - run a command formatted for freebsd
  11. func RunCmdFormatted(command string, printerr bool) (string, error) {
  12. args := strings.Fields(command)
  13. cmd := exec.Command(args[0], args[1:]...)
  14. cmd.Start()
  15. cmd.Wait()
  16. out, err := cmd.CombinedOutput()
  17. if err != nil && printerr {
  18. logger.Log(0, "error running command: ", command)
  19. logger.Log(0, strings.TrimSuffix(string(out), "\n"))
  20. }
  21. return string(out), err
  22. }
  23. // GetEmbedded - if files required for freebsd, put here
  24. func GetEmbedded() error {
  25. return nil
  26. }
  27. // Runs Commands for FreeBSD
  28. func RunCmd(command string, printerr bool) (string, error) {
  29. args := strings.Fields(command)
  30. ctx, cancel := context.WithTimeout(context.Background(), time.Second)
  31. defer cancel()
  32. cmd := exec.Command(args[0], args[1:]...)
  33. cmd.SysProcAttr = &syscall.SysProcAttr{Setpgid: true}
  34. go func() {
  35. <-ctx.Done()
  36. _ = syscall.Kill(-cmd.Process.Pid, syscall.SIGKILL)
  37. }()
  38. out, err := cmd.CombinedOutput()
  39. if err != nil && printerr {
  40. logger.Log(0, "error running command:", command)
  41. logger.Log(0, strings.TrimSuffix(string(out), "\n"))
  42. }
  43. return string(out), err
  44. }