mirror of
https://github.com/WireGuard/wgctrl-go.git
synced 2024-11-23 16:26:12 +00:00
97bc4ad4a1
* internal/freebsd: add initial version of FreeBSD support * internal/wguser: Replace deprecated io/ioutil package with io * internal/freebsd: prepare CI to run tests on FreeBSD * test: sort AllowedIPs before diffing them * test: skip integration test configure_peers_update_only on FreeBSD * test: increase test timeout for slow FreeBSD tests * add FreeBSD support to README Signed-off-by: Steffen Vogel <post@steffenvogel.de> * *: tidy * go.mod: bump dependencies * .builds: try to fix OpenBSD Signed-off-by: Matt Layher <mdlayher@gmail.com> Co-authored-by: Steffen Vogel <post@steffenvogel.de>
52 lines
996 B
Go
52 lines
996 B
Go
//go:build !windows
|
|
// +build !windows
|
|
|
|
package wguser
|
|
|
|
import (
|
|
"errors"
|
|
"io/fs"
|
|
"net"
|
|
"os"
|
|
"path/filepath"
|
|
)
|
|
|
|
// dial is the default implementation of Client.dial.
|
|
func dial(device string) (net.Conn, error) {
|
|
return net.Dial("unix", device)
|
|
}
|
|
|
|
// find is the default implementation of Client.find.
|
|
func find() ([]string, error) {
|
|
return findUNIXSockets([]string{
|
|
// It seems that /var/run is a common location between Linux and the
|
|
// BSDs, even though it's a symlink on Linux.
|
|
"/var/run/wireguard",
|
|
})
|
|
}
|
|
|
|
// findUNIXSockets looks for UNIX socket files in the specified directories.
|
|
func findUNIXSockets(dirs []string) ([]string, error) {
|
|
var socks []string
|
|
for _, d := range dirs {
|
|
files, err := os.ReadDir(d)
|
|
if err != nil {
|
|
if errors.Is(err, os.ErrNotExist) {
|
|
continue
|
|
}
|
|
|
|
return nil, err
|
|
}
|
|
|
|
for _, f := range files {
|
|
if f.Type()&fs.ModeSocket == 0 {
|
|
continue
|
|
}
|
|
|
|
socks = append(socks, filepath.Join(d, f.Name()))
|
|
}
|
|
}
|
|
|
|
return socks, nil
|
|
}
|