2021-02-06 16:26:23 +00:00
|
|
|
// Package updater implements update mechanisms for each VPN provider servers.
|
2020-08-28 08:17:04 -04:00
|
|
|
package updater
|
|
|
|
|
|
|
|
|
|
import (
|
2020-09-05 12:57:16 -04:00
|
|
|
"context"
|
2020-08-29 13:19:34 -04:00
|
|
|
"net/http"
|
2020-08-28 08:17:04 -04:00
|
|
|
"time"
|
|
|
|
|
|
2021-02-06 11:05:50 -05:00
|
|
|
"github.com/qdm12/gluetun/internal/configuration"
|
2021-06-20 09:18:03 -07:00
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
2020-09-05 12:57:16 -04:00
|
|
|
"github.com/qdm12/gluetun/internal/models"
|
2021-05-06 18:48:14 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/updater/resolver"
|
2021-05-08 00:59:42 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/updater/unzip"
|
2020-09-12 14:04:54 -04:00
|
|
|
"github.com/qdm12/golibs/logging"
|
2020-08-28 08:17:04 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type Updater interface {
|
2020-09-12 14:04:54 -04:00
|
|
|
UpdateServers(ctx context.Context) (allServers models.AllServers, err error)
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type updater struct {
|
2020-09-05 12:57:16 -04:00
|
|
|
// configuration
|
2021-02-06 11:05:50 -05:00
|
|
|
options configuration.Updater
|
2020-09-05 12:57:16 -04:00
|
|
|
|
|
|
|
|
// state
|
|
|
|
|
servers models.AllServers
|
|
|
|
|
|
|
|
|
|
// Functions for tests
|
2021-05-06 18:48:14 +00:00
|
|
|
logger logging.Logger
|
|
|
|
|
timeNow func() time.Time
|
|
|
|
|
presolver resolver.Parallel
|
|
|
|
|
client *http.Client
|
2021-05-08 00:59:42 +00:00
|
|
|
unzipper unzip.Unzipper
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
|
2021-02-06 11:05:50 -05:00
|
|
|
func New(settings configuration.Updater, httpClient *http.Client,
|
2020-12-19 20:10:34 -05:00
|
|
|
currentServers models.AllServers, logger logging.Logger) Updater {
|
|
|
|
|
if len(settings.DNSAddress) == 0 {
|
|
|
|
|
settings.DNSAddress = "1.1.1.1"
|
2020-09-05 12:57:16 -04:00
|
|
|
}
|
2021-05-08 00:59:42 +00:00
|
|
|
unzipper := unzip.New(httpClient)
|
2020-08-28 08:17:04 -04:00
|
|
|
return &updater{
|
2021-05-06 18:48:14 +00:00
|
|
|
logger: logger,
|
|
|
|
|
timeNow: time.Now,
|
|
|
|
|
presolver: resolver.NewParallelResolver(settings.DNSAddress),
|
|
|
|
|
client: httpClient,
|
2021-05-08 00:59:42 +00:00
|
|
|
unzipper: unzipper,
|
2021-05-06 18:48:14 +00:00
|
|
|
options: settings,
|
|
|
|
|
servers: currentServers,
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-17 20:36:30 -05:00
|
|
|
//nolint:gocognit,gocyclo
|
|
|
|
|
func (u *updater) UpdateServers(ctx context.Context) (allServers models.AllServers, err error) {
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Cyberghost {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating Cyberghost servers...")
|
|
|
|
|
if err := u.updateCyberghost(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-09-12 14:04:54 -04:00
|
|
|
}
|
2020-09-05 12:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
2021-03-05 23:12:19 -05:00
|
|
|
if u.options.Fastestvpn {
|
|
|
|
|
u.logger.Info("updating Fastestvpn servers...")
|
|
|
|
|
if err := u.updateFastestvpn(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-03-05 23:12:19 -05:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-05 22:45:54 -05:00
|
|
|
if u.options.HideMyAss {
|
|
|
|
|
u.logger.Info("updating HideMyAss servers...")
|
|
|
|
|
if err := u.updateHideMyAss(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-03-05 22:45:54 -05:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-20 09:21:48 -07:00
|
|
|
if u.options.Ipvanish {
|
|
|
|
|
u.logger.Info("updating Ipvanish servers...")
|
|
|
|
|
if err := u.updateIpvanish(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-06-20 09:21:48 -07:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-31 00:11:16 +00:00
|
|
|
if u.options.Ivpn {
|
|
|
|
|
u.logger.Info("updating Ivpn servers...")
|
|
|
|
|
if err := u.updateIvpn(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-05-31 00:11:16 +00:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Mullvad {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating Mullvad servers...")
|
2020-10-20 02:45:28 +00:00
|
|
|
if err := u.updateMullvad(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-09-12 14:04:54 -04:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
2020-09-05 12:57:16 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if u.options.Nordvpn {
|
|
|
|
|
// TODO support servers offering only TCP or only UDP
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating NordVPN servers...")
|
2020-10-20 02:45:28 +00:00
|
|
|
if err := u.updateNordvpn(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-09-12 14:04:54 -04:00
|
|
|
}
|
|
|
|
|
if err := ctx.Err(); err != nil {
|
|
|
|
|
return allServers, err
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
2020-09-05 12:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
2021-02-26 12:58:58 +00:00
|
|
|
if u.options.Privado {
|
|
|
|
|
u.logger.Info("updating Privado servers...")
|
|
|
|
|
if err := u.updatePrivado(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-09-12 14:04:54 -04:00
|
|
|
}
|
|
|
|
|
if ctx.Err() != nil {
|
|
|
|
|
return allServers, ctx.Err()
|
2020-11-08 20:56:49 -05:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 12:58:58 +00:00
|
|
|
if u.options.PIA {
|
|
|
|
|
u.logger.Info("updating Private Internet Access servers...")
|
|
|
|
|
if err := u.updatePIA(ctx); err != nil {
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-11-08 20:56:49 -05:00
|
|
|
}
|
|
|
|
|
if ctx.Err() != nil {
|
|
|
|
|
return allServers, ctx.Err()
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-05 22:58:57 -05:00
|
|
|
if u.options.Privatevpn {
|
|
|
|
|
u.logger.Info("updating Privatevpn servers...")
|
|
|
|
|
if err := u.updatePrivatevpn(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-03-05 22:58:57 -05:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-04-25 15:44:45 -04:00
|
|
|
if u.options.Protonvpn {
|
|
|
|
|
u.logger.Info("updating Protonvpn servers...")
|
|
|
|
|
if err := u.updateProtonvpn(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-04-25 15:44:45 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Purevpn {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating PureVPN servers...")
|
2020-09-05 12:57:16 -04:00
|
|
|
// TODO support servers offering only TCP or only UDP
|
|
|
|
|
if err := u.updatePurevpn(ctx); err != nil {
|
2020-09-12 14:04:54 -04:00
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Surfshark {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating Surfshark servers...")
|
2020-09-05 12:57:16 -04:00
|
|
|
if err := u.updateSurfshark(ctx); err != nil {
|
2020-09-12 14:04:54 -04:00
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-08-29 13:19:34 -04:00
|
|
|
}
|
2020-09-05 12:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
2021-02-17 20:36:30 -05:00
|
|
|
if u.options.Torguard {
|
|
|
|
|
u.logger.Info("updating Torguard servers...")
|
|
|
|
|
if err := u.updateTorguard(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-02-17 20:36:30 -05:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-20 09:18:03 -07:00
|
|
|
if u.options.VPNUnlimited {
|
|
|
|
|
u.logger.Info("updating " + constants.VPNUnlimited + " servers...")
|
|
|
|
|
if err := u.updateVPNUnlimited(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2021-06-20 09:18:03 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Vyprvpn {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating Vyprvpn servers...")
|
2020-09-05 12:57:16 -04:00
|
|
|
if err := u.updateVyprvpn(ctx); err != nil {
|
2020-09-12 14:04:54 -04:00
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-08-29 13:19:34 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-05 12:57:16 -04:00
|
|
|
if u.options.Windscribe {
|
2020-09-12 14:04:54 -04:00
|
|
|
u.logger.Info("updating Windscribe servers...")
|
|
|
|
|
if err := u.updateWindscribe(ctx); err != nil {
|
|
|
|
|
if ctxErr := ctx.Err(); ctxErr != nil {
|
|
|
|
|
return allServers, ctxErr
|
|
|
|
|
}
|
2021-07-23 17:36:08 +00:00
|
|
|
u.logger.Error(err.Error())
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-12 14:04:54 -04:00
|
|
|
return u.servers, nil
|
2020-08-28 08:17:04 -04:00
|
|
|
}
|