1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- package ncutils
- import (
- "fmt"
- "log"
- "os"
- "os/exec"
- "strconv"
- "strings"
- "syscall"
- "golang.zx2c4.com/wireguard/wgctrl/wgtypes"
- )
- // RunCmd - runs a local command
- func 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 command
- func 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 conf
- func 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 = %s
- PrivateKey = %s
- MTU = %s
- %s
- %s
- `,
- address+"/32",
- privatekey,
- strconv.Itoa(int(mtu)),
- listenPortString,
- peersString)
- return config, nil
- }
|