58 lines
1.0 KiB
Go
58 lines
1.0 KiB
Go
package privateinternetaccess
|
|
|
|
import (
|
|
"net"
|
|
|
|
"github.com/qdm12/gluetun/internal/constants/vpn"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
)
|
|
|
|
type nameToServer map[string]models.Server
|
|
|
|
func (nts nameToServer) add(name, hostname, region string,
|
|
tcp, udp, portForward bool, ip net.IP) (change bool) {
|
|
server, ok := nts[name]
|
|
if !ok {
|
|
change = true
|
|
server.VPN = vpn.OpenVPN
|
|
server.ServerName = name
|
|
server.Hostname = hostname
|
|
server.Region = region
|
|
server.PortForward = portForward
|
|
}
|
|
|
|
if !server.TCP && tcp {
|
|
change = true
|
|
server.TCP = tcp
|
|
}
|
|
if !server.UDP && udp {
|
|
change = true
|
|
server.UDP = udp
|
|
}
|
|
|
|
ipFound := false
|
|
for _, existingIP := range server.IPs {
|
|
if ip.Equal(existingIP) {
|
|
ipFound = true
|
|
break
|
|
}
|
|
}
|
|
|
|
if !ipFound {
|
|
change = true
|
|
server.IPs = append(server.IPs, ip)
|
|
}
|
|
|
|
nts[name] = server
|
|
|
|
return change
|
|
}
|
|
|
|
func (nts nameToServer) toServersSlice() (servers []models.Server) {
|
|
servers = make([]models.Server, 0, len(nts))
|
|
for _, server := range nts {
|
|
servers = append(servers, server)
|
|
}
|
|
return servers
|
|
}
|