mirror of
https://github.com/tailscale/tailscale.git
synced 2025-01-07 16:17:41 +00:00
4722f7e322
We're using it in more and more places, and it's not really specific to our use of Wireguard (and does more just link/interface monitoring). Also removes the separate interface we had for it in sockstats -- it's a small enough package (we already pull in all of its dependencies via other paths) that it's not worth the extra complexity. Updates #7621 Updates #7850 Signed-off-by: Mihai Parparita <mihai@tailscale.com>
31 lines
1.1 KiB
Go
31 lines
1.1 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package router
|
|
|
|
import (
|
|
"github.com/tailscale/wireguard-go/tun"
|
|
"tailscale.com/net/netmon"
|
|
"tailscale.com/types/logger"
|
|
)
|
|
|
|
// For now this router only supports the userspace WireGuard implementations.
|
|
//
|
|
// Work is currently underway for an in-kernel FreeBSD implementation of wireguard
|
|
// https://svnweb.freebsd.org/base?view=revision&revision=357986
|
|
|
|
func newUserspaceRouter(logf logger.Logf, tundev tun.Device, netMon *netmon.Monitor) (Router, error) {
|
|
return newUserspaceBSDRouter(logf, tundev, netMon)
|
|
}
|
|
|
|
func cleanup(logf logger.Logf, interfaceName string) {
|
|
// If the interface was left behind, ifconfig down will not remove it.
|
|
// In fact, this will leave a system in a tainted state where starting tailscaled
|
|
// will result in "interface tailscale0 already exists"
|
|
// until the defunct interface is ifconfig-destroyed.
|
|
ifup := []string{"ifconfig", interfaceName, "destroy"}
|
|
if out, err := cmd(ifup...).CombinedOutput(); err != nil {
|
|
logf("ifconfig destroy: %v\n%s", err, out)
|
|
}
|
|
}
|