netclientutils_freebsd.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package ncutils
  2. import (
  3. "context"
  4. "fmt"
  5. "golang.zx2c4.com/wireguard/wgctrl/wgtypes"
  6. "log"
  7. "os/exec"
  8. "strconv"
  9. "strings"
  10. "syscall"
  11. "time"
  12. )
  13. func RunCmdFormatted(command string, printerr bool) (string, error) {
  14. return "", nil
  15. }
  16. // Runs Commands for FreeBSD
  17. func RunCmd(command string, printerr bool) (string, error) {
  18. args := strings.Fields(command)
  19. ctx, cancel := context.WithTimeout(context.Background(), time.Second)
  20. defer cancel()
  21. cmd := exec.Command(args[0], args[1:]...)
  22. cmd.SysProcAttr = &syscall.SysProcAttr{Setpgid: true}
  23. go func() {
  24. <-ctx.Done()
  25. _ = syscall.Kill(-cmd.Process.Pid, syscall.SIGKILL)
  26. }()
  27. out, err := cmd.CombinedOutput()
  28. if err != nil && printerr {
  29. log.Println("error running command:", command)
  30. log.Println(strings.TrimSuffix(string(out), "\n"))
  31. }
  32. return string(out), err
  33. }
  34. // CreateUserSpaceConf - creates a user space WireGuard conf
  35. func CreateUserSpaceConf(address string, privatekey string, listenPort string, mtu int32, perskeepalive int32, peers []wgtypes.PeerConfig) (string, error) {
  36. peersString, err := parsePeers(perskeepalive, peers)
  37. var listenPortString string
  38. if mtu <= 0 {
  39. mtu = 1280
  40. }
  41. if listenPort != "" {
  42. listenPortString += "ListenPort = " + listenPort
  43. }
  44. if err != nil {
  45. return "", err
  46. }
  47. config := fmt.Sprintf(`[Interface]
  48. Address = %s
  49. PrivateKey = %s
  50. MTU = %s
  51. %s
  52. %s
  53. `,
  54. address+"/32",
  55. privatekey,
  56. strconv.Itoa(int(mtu)),
  57. listenPortString,
  58. peersString)
  59. return config, nil
  60. }