| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 | package ncutilsimport (	"fmt"	"log"	"os"	"os/exec"	"strconv"	"strings"	"syscall"	"golang.zx2c4.com/wireguard/wgctrl/wgtypes")// RunCmd - runs a local commandfunc RunCmd(command string, printerr bool) (string, error) {	args := strings.Fields(command)	cmd := exec.Command(args[0], args[1:]...)	cmd.Wait()	//cmd.SysProcAttr = &syscall.SysProcAttr{CmdLine: "/C \"" + command + "\""}	out, err := cmd.CombinedOutput()	if err != nil && printerr {		log.Println("error running command:", command)		log.Println(strings.TrimSuffix(string(out), "\n"))	}	return string(out), err}// RunCmd - runs a local commandfunc RunCmdFormatted(command string, printerr bool) (string, error) {	var comSpec = os.Getenv("COMSPEC")	if comSpec == "" {		comSpec = os.Getenv("SystemRoot") + "\\System32\\cmd.exe"	}	cmd := exec.Command(comSpec)	cmd.SysProcAttr = &syscall.SysProcAttr{CmdLine: "/C \"" + command + "\""}	cmd.Wait()	out, err := cmd.CombinedOutput()	if err != nil && printerr {		log.Println("error running command:", command)		log.Println(strings.TrimSuffix(string(out), "\n"))	}	return string(out), err}// CreateUserSpaceConf - creates a user space WireGuard conffunc CreateUserSpaceConf(address string, privatekey string, listenPort string, mtu int32, fwmark int32, perskeepalive int32, peers []wgtypes.PeerConfig) (string, error) {	peersString, err := parsePeers(perskeepalive, peers)	var listenPortString string	if mtu <= 0 {		mtu = 1280	}	if listenPort != "" {		listenPortString += "ListenPort = " + listenPort	}	if err != nil {		return "", err	}	config := fmt.Sprintf(`[Interface]Address = %sPrivateKey = %sMTU = %s%s%s`,		address+"/32",		privatekey,		strconv.Itoa(int(mtu)),		listenPortString,		peersString)	return config, nil}
 |