Files
gluetun/internal/storage/sync.go

65 lines
1.8 KiB
Go
Raw Normal View History

package storage
import (
"fmt"
"reflect"
"github.com/qdm12/gluetun/internal/models"
)
func countServers(allServers models.AllServers) int {
return len(allServers.Cyberghost.Servers) +
2021-09-23 10:19:30 -07:00
len(allServers.Expressvpn.Servers) +
2021-03-05 23:12:19 -05:00
len(allServers.Fastestvpn.Servers) +
len(allServers.HideMyAss.Servers) +
len(allServers.Ipvanish.Servers) +
2021-05-31 00:11:16 +00:00
len(allServers.Ivpn.Servers) +
len(allServers.Mullvad.Servers) +
len(allServers.Nordvpn.Servers) +
2021-10-05 10:44:15 -07:00
len(allServers.Perfectprivacy.Servers) +
2020-11-08 20:56:49 -05:00
len(allServers.Privado.Servers) +
len(allServers.Pia.Servers) +
2021-03-05 22:58:57 -05:00
len(allServers.Privatevpn.Servers) +
len(allServers.Protonvpn.Servers) +
len(allServers.Purevpn.Servers) +
len(allServers.Surfshark.Servers) +
len(allServers.Torguard.Servers) +
len(allServers.VPNUnlimited.Servers) +
len(allServers.Vyprvpn.Servers) +
2021-09-23 07:58:13 -07:00
len(allServers.Wevpn.Servers) +
len(allServers.Windscribe.Servers)
}
func (s *Storage) SyncServers() (err error) {
serversOnFile, err := s.readFromFile(s.filepath, s.hardcodedServers)
if err != nil {
return fmt.Errorf("cannot read servers from file: %w", err)
}
hardcodedCount := countServers(s.hardcodedServers)
countOnFile := countServers(serversOnFile)
if countOnFile == 0 {
s.logger.Info(fmt.Sprintf(
"creating %s with %d hardcoded servers",
s.filepath, hardcodedCount))
s.mergedServers = s.hardcodedServers
} else {
s.logger.Info(fmt.Sprintf(
"merging by most recent %d hardcoded servers and %d servers read from %s",
hardcodedCount, countOnFile, s.filepath))
s.mergedServers = s.mergeServers(s.hardcodedServers, serversOnFile)
}
// Eventually write file
if s.filepath == "" || reflect.DeepEqual(serversOnFile, s.mergedServers) {
return nil
}
if err := flushToFile(s.filepath, s.mergedServers); err != nil {
return fmt.Errorf("cannot write servers to file: %w", err)
}
return nil
}