mirror of
https://github.com/netbirdio/netbird.git
synced 2025-01-13 01:18:49 +01:00
1de3bb5420
Add netstack support for the agent to run it without privileges. - use interface for tun device - use common IPC for userspace WireGuard integration - move udpmux creation and sharedsock to tun layer
34 lines
814 B
Go
34 lines
814 B
Go
package netstack
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"strconv"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// IsEnabled todo: move these function to cmd layer
|
|
func IsEnabled() bool {
|
|
return os.Getenv("NB_USE_NETSTACK_MODE") == "true"
|
|
}
|
|
|
|
func ListenAddr() string {
|
|
sPort := os.Getenv("NB_SOCKS5_LISTENER_PORT")
|
|
port, err := strconv.Atoi(sPort)
|
|
if err != nil {
|
|
log.Warnf("invalid socks5 listener port, unable to convert it to int, falling back to default: %d", DefaultSocks5Port)
|
|
return listenAddr(DefaultSocks5Port)
|
|
}
|
|
if port < 1 || port > 65535 {
|
|
log.Warnf("invalid socks5 listener port, it should be in the range 1-65535, falling back to default: %d", DefaultSocks5Port)
|
|
return listenAddr(DefaultSocks5Port)
|
|
}
|
|
|
|
return listenAddr(port)
|
|
}
|
|
|
|
func listenAddr(port int) string {
|
|
return fmt.Sprintf("0.0.0.0:%d", port)
|
|
}
|