2022-06-09 23:47:12 +00:00
|
|
|
package updater
|
2021-05-08 00:59:42 +00:00
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"net"
|
|
|
|
|
|
2022-04-23 10:59:29 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/constants/vpn"
|
2021-05-08 00:59:42 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
|
|
|
)
|
|
|
|
|
|
2022-08-26 10:55:46 -04:00
|
|
|
type hostToServers map[string][]models.Server
|
2021-05-08 00:59:42 +00:00
|
|
|
|
2022-08-26 10:55:46 -04:00
|
|
|
func (hts hostToServers) addOpenVPN(host, region, country, city,
|
|
|
|
|
retroLoc string, tcp, udp bool) {
|
|
|
|
|
// Check for existing server for this host and OpenVPN.
|
|
|
|
|
servers := hts[host]
|
|
|
|
|
for i, existingServer := range servers {
|
|
|
|
|
if existingServer.Hostname != host ||
|
|
|
|
|
existingServer.VPN != vpn.OpenVPN {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Update OpenVPN supported protocols and return
|
|
|
|
|
if !existingServer.TCP {
|
|
|
|
|
servers[i].TCP = tcp
|
|
|
|
|
}
|
|
|
|
|
if !existingServer.UDP {
|
|
|
|
|
servers[i].UDP = udp
|
|
|
|
|
}
|
|
|
|
|
return
|
2021-05-08 00:59:42 +00:00
|
|
|
}
|
2022-08-26 10:55:46 -04:00
|
|
|
|
|
|
|
|
server := models.Server{
|
|
|
|
|
VPN: vpn.OpenVPN,
|
|
|
|
|
Region: region,
|
|
|
|
|
Country: country,
|
|
|
|
|
City: city,
|
|
|
|
|
RetroLoc: retroLoc,
|
|
|
|
|
Hostname: host,
|
|
|
|
|
TCP: tcp,
|
|
|
|
|
UDP: udp,
|
2021-05-10 01:24:46 +00:00
|
|
|
}
|
2022-08-26 10:55:46 -04:00
|
|
|
hts[host] = append(servers, server)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (hts hostToServers) addWireguard(host, region, country, city, retroLoc,
|
|
|
|
|
wgPubKey string) {
|
|
|
|
|
// Check for existing server for this host and Wireguard.
|
|
|
|
|
servers := hts[host]
|
|
|
|
|
for _, existingServer := range servers {
|
|
|
|
|
if existingServer.Hostname == host &&
|
|
|
|
|
existingServer.VPN == vpn.Wireguard {
|
|
|
|
|
// No update necessary for Wireguard
|
|
|
|
|
return
|
|
|
|
|
}
|
2021-05-10 01:24:46 +00:00
|
|
|
}
|
2022-08-26 10:55:46 -04:00
|
|
|
|
|
|
|
|
server := models.Server{
|
|
|
|
|
VPN: vpn.Wireguard,
|
|
|
|
|
Region: region,
|
|
|
|
|
Country: country,
|
|
|
|
|
City: city,
|
|
|
|
|
RetroLoc: retroLoc,
|
|
|
|
|
Hostname: host,
|
|
|
|
|
WgPubKey: wgPubKey,
|
|
|
|
|
}
|
|
|
|
|
hts[host] = append(servers, server)
|
2021-05-08 00:59:42 +00:00
|
|
|
}
|
|
|
|
|
|
2022-08-26 10:55:46 -04:00
|
|
|
func (hts hostToServers) toHostsSlice() (hosts []string) {
|
|
|
|
|
const vpnServerTypes = 2 // OpenVPN + Wireguard
|
|
|
|
|
hosts = make([]string, 0, vpnServerTypes*len(hts))
|
2021-05-08 00:59:42 +00:00
|
|
|
for host := range hts {
|
|
|
|
|
hosts = append(hosts, host)
|
|
|
|
|
}
|
|
|
|
|
return hosts
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-26 10:55:46 -04:00
|
|
|
func (hts hostToServers) adaptWithIPs(hostToIPs map[string][]net.IP) {
|
2021-05-08 00:59:42 +00:00
|
|
|
for host, IPs := range hostToIPs {
|
2022-08-26 10:55:46 -04:00
|
|
|
servers := hts[host]
|
|
|
|
|
for i := range servers {
|
|
|
|
|
servers[i].IPs = IPs
|
|
|
|
|
}
|
|
|
|
|
hts[host] = servers
|
2021-05-08 00:59:42 +00:00
|
|
|
}
|
2022-08-26 10:55:46 -04:00
|
|
|
for host, servers := range hts {
|
|
|
|
|
if len(servers[0].IPs) == 0 {
|
2021-05-08 00:59:42 +00:00
|
|
|
delete(hts, host)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-26 10:55:46 -04:00
|
|
|
func (hts hostToServers) toServersSlice() (servers []models.Server) {
|
|
|
|
|
const vpnServerTypes = 2 // OpenVPN + Wireguard
|
|
|
|
|
servers = make([]models.Server, 0, vpnServerTypes*len(hts))
|
|
|
|
|
for _, serversForHost := range hts {
|
|
|
|
|
servers = append(servers, serversForHost...)
|
2021-05-08 00:59:42 +00:00
|
|
|
}
|
|
|
|
|
return servers
|
|
|
|
|
}
|