Files
gluetun/internal/provider/ivpn/updater/servers.go

83 lines
2.1 KiB
Go
Raw Normal View History

package updater
2021-05-31 00:11:16 +00:00
import (
"context"
"fmt"
"sort"
2021-05-31 00:11:16 +00:00
"github.com/qdm12/gluetun/internal/constants/vpn"
2021-05-31 00:11:16 +00:00
"github.com/qdm12/gluetun/internal/models"
"github.com/qdm12/gluetun/internal/provider/common"
)
2021-05-31 00:11:16 +00:00
func (u *Updater) FetchServers(ctx context.Context, minServers int) (
servers []models.Server, err error) {
data, err := fetchAPI(ctx, u.client)
2021-05-31 00:11:16 +00:00
if err != nil {
return nil, fmt.Errorf("failed fetching API: %w", err)
2021-05-31 00:11:16 +00:00
}
hosts := make([]string, 0, len(data.Servers))
2021-05-31 00:11:16 +00:00
for _, serverData := range data.Servers {
openVPNHost := serverData.Hostnames.OpenVPN
if openVPNHost != "" {
hosts = append(hosts, openVPNHost)
2021-05-31 00:11:16 +00:00
}
wireguardHost := serverData.Hostnames.Wireguard
if wireguardHost != "" {
hosts = append(hosts, wireguardHost)
}
2021-05-31 00:11:16 +00:00
}
if len(hosts) < minServers {
return nil, fmt.Errorf("%w: %d and expected at least %d",
common.ErrNotEnoughServers, len(hosts), minServers)
2021-05-31 00:11:16 +00:00
}
resolveSettings := parallelResolverSettings(hosts)
hostToIPs, warnings, err := u.parallelResolver.Resolve(ctx, resolveSettings)
for _, warning := range warnings {
u.warner.Warn(warning)
}
2021-05-31 00:11:16 +00:00
if err != nil {
return nil, err
2021-05-31 00:11:16 +00:00
}
if len(hostToIPs) < minServers {
return nil, fmt.Errorf("%w: %d and expected at least %d",
common.ErrNotEnoughServers, len(servers), minServers)
}
servers = make([]models.Server, 0, len(hosts))
for _, serverData := range data.Servers {
server := models.Server{
Country: serverData.Country,
City: serverData.City,
ISP: serverData.ISP,
}
switch {
case serverData.Hostnames.OpenVPN != "":
server.Hostname = serverData.Hostnames.OpenVPN
server.VPN = vpn.OpenVPN
server.UDP = true
server.TCP = true
server.IPs = hostToIPs[server.Hostname]
case serverData.Hostnames.Wireguard != "":
server.Hostname = serverData.Hostnames.Wireguard
server.VPN = vpn.Wireguard
server.IPs = hostToIPs[server.Hostname]
server.WgPubKey = serverData.WgPubKey
default:
warning := fmt.Sprintf("server data %v has no OpenVPN nor Wireguard hostname", serverData)
warnings = append(warnings, warning)
}
servers = append(servers, server)
2021-05-31 00:11:16 +00:00
}
sort.Sort(models.SortableServers(servers))
2021-05-31 00:11:16 +00:00
return servers, nil
2021-05-31 00:11:16 +00:00
}