chore(updater): incorporate FetchServers method in Provider interface

- Each provider interface can now fetch updated servers data
- Rename each provider updater subpackage name to `updater`
- Updater constructor does not take a settings struct
- Updater update method takes in a slice of provider strings
This commit is contained in:
Quentin McGaw
2022-06-09 23:47:12 +00:00
parent 11b55abff3
commit ebd94723c1
148 changed files with 374 additions and 281 deletions

View File

@@ -92,7 +92,8 @@ func Test_Provider_GetConnection(t *testing.T) {
Return(testCase.filteredServers, testCase.storageErr)
randSource := rand.NewSource(0)
provider := New(storage, randSource)
warner := (common.Warner)(nil)
provider := New(storage, randSource, warner)
if testCase.panicMessage != "" {
assert.PanicsWithValue(t, testCase.panicMessage, func() {

View File

@@ -6,19 +6,23 @@ import (
"github.com/qdm12/gluetun/internal/constants/providers"
"github.com/qdm12/gluetun/internal/provider/common"
"github.com/qdm12/gluetun/internal/provider/utils"
"github.com/qdm12/gluetun/internal/provider/wevpn/updater"
)
type Provider struct {
storage common.Storage
randSource rand.Source
utils.NoPortForwarder
common.Fetcher
}
func New(storage common.Storage, randSource rand.Source) *Provider {
func New(storage common.Storage, randSource rand.Source,
updaterWarner common.Warner) *Provider {
return &Provider{
storage: storage,
randSource: randSource,
NoPortForwarder: utils.NewNoPortForwarding(providers.Wevpn),
Fetcher: updater.New(updaterWarner),
}
}

View File

@@ -1,4 +1,4 @@
package wevpn
package updater
// getAvailableCities get available cities as listed on the WeVPN website.
func getAvailableCities() (cities []string) {

View File

@@ -1,4 +1,4 @@
package wevpn
package updater
import "strings"

View File

@@ -1,4 +1,4 @@
package wevpn
package updater
import (
"time"

View File

@@ -1,6 +1,6 @@
// package wevpn contains code to obtain the server information
// Package updater contains code to obtain the server information
// for the WeVPN provider.
package wevpn
package updater
import (
"context"

View File

@@ -1,4 +1,4 @@
package wevpn
package updater
import "github.com/qdm12/gluetun/internal/provider/common"