- Do not export updater interface - Export updater struct - Define local interfaces where needed - More restrictive updater loop interface in http control server - Inject `Updater` into updater loop as an interface
126 lines
5.1 KiB
Go
126 lines
5.1 KiB
Go
package updater
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"reflect"
|
|
"time"
|
|
|
|
"github.com/qdm12/gluetun/internal/constants/providers"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
cyberghost "github.com/qdm12/gluetun/internal/provider/cyberghost/updater"
|
|
expressvpn "github.com/qdm12/gluetun/internal/provider/expressvpn/updater"
|
|
fastestvpn "github.com/qdm12/gluetun/internal/provider/fastestvpn/updater"
|
|
hidemyass "github.com/qdm12/gluetun/internal/provider/hidemyass/updater"
|
|
ipvanish "github.com/qdm12/gluetun/internal/provider/ipvanish/updater"
|
|
ivpn "github.com/qdm12/gluetun/internal/provider/ivpn/updater"
|
|
mullvad "github.com/qdm12/gluetun/internal/provider/mullvad/updater"
|
|
nordvpn "github.com/qdm12/gluetun/internal/provider/nordvpn/updater"
|
|
perfectprivacy "github.com/qdm12/gluetun/internal/provider/perfectprivacy/updater"
|
|
privado "github.com/qdm12/gluetun/internal/provider/privado/updater"
|
|
privateinternetaccess "github.com/qdm12/gluetun/internal/provider/privateinternetaccess/updater"
|
|
privatevpn "github.com/qdm12/gluetun/internal/provider/privatevpn/updater"
|
|
protonvpn "github.com/qdm12/gluetun/internal/provider/protonvpn/updater"
|
|
purevpn "github.com/qdm12/gluetun/internal/provider/purevpn/updater"
|
|
surfshark "github.com/qdm12/gluetun/internal/provider/surfshark/updater"
|
|
torguard "github.com/qdm12/gluetun/internal/provider/torguard/updater"
|
|
vpnunlimited "github.com/qdm12/gluetun/internal/provider/vpnunlimited/updater"
|
|
vyprvpn "github.com/qdm12/gluetun/internal/provider/vyprvpn/updater"
|
|
wevpn "github.com/qdm12/gluetun/internal/provider/wevpn/updater"
|
|
windscribe "github.com/qdm12/gluetun/internal/provider/windscribe/updater"
|
|
)
|
|
|
|
func (u *Updater) updateProvider(ctx context.Context, provider string) (
|
|
warnings []string, err error) {
|
|
existingServers := u.getProviderServers(provider)
|
|
minServers := getMinServers(existingServers)
|
|
servers, warnings, err := u.getServers(ctx, provider, minServers)
|
|
if err != nil {
|
|
return warnings, err
|
|
}
|
|
|
|
if reflect.DeepEqual(existingServers, servers) {
|
|
return warnings, nil
|
|
}
|
|
|
|
u.patchProvider(provider, servers)
|
|
return warnings, nil
|
|
}
|
|
|
|
func (u *Updater) getServers(ctx context.Context, provider string,
|
|
minServers int) (servers []models.Server, warnings []string, err error) {
|
|
switch provider {
|
|
case providers.Custom:
|
|
panic("cannot update custom provider")
|
|
case providers.Cyberghost:
|
|
servers, err = cyberghost.GetServers(ctx, u.presolver, minServers)
|
|
return servers, nil, err
|
|
case providers.Expressvpn:
|
|
return expressvpn.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.Fastestvpn:
|
|
return fastestvpn.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.HideMyAss:
|
|
return hidemyass.GetServers(ctx, u.client, u.presolver, minServers)
|
|
case providers.Ipvanish:
|
|
return ipvanish.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.Ivpn:
|
|
return ivpn.GetServers(ctx, u.client, u.presolver, minServers)
|
|
case providers.Mullvad:
|
|
servers, err = mullvad.GetServers(ctx, u.client, minServers)
|
|
return servers, nil, err
|
|
case providers.Nordvpn:
|
|
return nordvpn.GetServers(ctx, u.client, minServers)
|
|
case providers.Perfectprivacy:
|
|
return perfectprivacy.GetServers(ctx, u.unzipper, minServers)
|
|
case providers.Privado:
|
|
return privado.GetServers(ctx, u.unzipper, u.client, u.presolver, minServers)
|
|
case providers.PrivateInternetAccess:
|
|
servers, err = privateinternetaccess.GetServers(ctx, u.client, minServers)
|
|
return servers, nil, err
|
|
case providers.Privatevpn:
|
|
return privatevpn.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.Protonvpn:
|
|
return protonvpn.GetServers(ctx, u.client, minServers)
|
|
case providers.Purevpn:
|
|
return purevpn.GetServers(ctx, u.client, u.unzipper, u.presolver, minServers)
|
|
case providers.Surfshark:
|
|
return surfshark.GetServers(ctx, u.unzipper, u.client, u.presolver, minServers)
|
|
case providers.Torguard:
|
|
return torguard.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.VPNUnlimited:
|
|
return vpnunlimited.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.Vyprvpn:
|
|
return vyprvpn.GetServers(ctx, u.unzipper, u.presolver, minServers)
|
|
case providers.Wevpn:
|
|
return wevpn.GetServers(ctx, u.presolver, minServers)
|
|
case providers.Windscribe:
|
|
servers, err = windscribe.GetServers(ctx, u.client, minServers)
|
|
return servers, nil, err
|
|
default:
|
|
panic("provider " + provider + " is unknown")
|
|
}
|
|
}
|
|
|
|
func (u *Updater) getProviderServers(provider string) (servers []models.Server) {
|
|
providerServers, ok := u.servers.ProviderToServers[provider]
|
|
if !ok {
|
|
panic(fmt.Sprintf("provider %s is unknown", provider))
|
|
}
|
|
return providerServers.Servers
|
|
}
|
|
|
|
func getMinServers(servers []models.Server) (minServers int) {
|
|
const minRatio = 0.8
|
|
return int(minRatio * float64(len(servers)))
|
|
}
|
|
|
|
func (u *Updater) patchProvider(provider string, servers []models.Server) {
|
|
providerServers, ok := u.servers.ProviderToServers[provider]
|
|
if !ok {
|
|
panic(fmt.Sprintf("provider %s is unknown", provider))
|
|
}
|
|
providerServers.Timestamp = time.Now().Unix()
|
|
providerServers.Servers = servers
|
|
u.servers.ProviderToServers[provider] = providerServers
|
|
}
|