- `OPENVPN_IPV6` removed - Affects OpenVPN - Use the same mechanism for OpenVPN and Wireguard - Check only once at program start since this is unlikely to change at runtime - Log if IPv6 is supported - Remove `IPv6` boolean from settings structs - Move IPv6 detection as a method on NetLinker
38 lines
1.2 KiB
Go
38 lines
1.2 KiB
Go
package utils
|
|
|
|
import (
|
|
"net"
|
|
|
|
"github.com/qdm12/gluetun/internal/configuration/settings"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
"github.com/qdm12/gluetun/internal/wireguard"
|
|
)
|
|
|
|
func BuildWireguardSettings(connection models.Connection,
|
|
userSettings settings.Wireguard, ipv6Supported bool) (settings wireguard.Settings) {
|
|
settings.PrivateKey = *userSettings.PrivateKey
|
|
settings.PublicKey = connection.PubKey
|
|
settings.PreSharedKey = *userSettings.PreSharedKey
|
|
settings.InterfaceName = userSettings.Interface
|
|
settings.IPv6 = &ipv6Supported
|
|
|
|
const rulePriority = 101 // 100 is to receive external connections
|
|
settings.RulePriority = rulePriority
|
|
|
|
settings.Endpoint = new(net.UDPAddr)
|
|
settings.Endpoint.IP = make(net.IP, len(connection.IP))
|
|
copy(settings.Endpoint.IP, connection.IP)
|
|
settings.Endpoint.Port = int(connection.Port)
|
|
|
|
for _, address := range userSettings.Addresses {
|
|
addressCopy := new(net.IPNet)
|
|
addressCopy.IP = make(net.IP, len(address.IP))
|
|
copy(addressCopy.IP, address.IP)
|
|
addressCopy.Mask = make(net.IPMask, len(address.Mask))
|
|
copy(addressCopy.Mask, address.Mask)
|
|
settings.Addresses = append(settings.Addresses, addressCopy)
|
|
}
|
|
|
|
return settings
|
|
}
|