2020-08-25 19:38:50 -04:00
|
|
|
package storage
|
|
|
|
|
|
|
|
|
|
import (
|
2020-12-29 17:49:38 +00:00
|
|
|
"errors"
|
2020-08-25 19:38:50 -04:00
|
|
|
"fmt"
|
|
|
|
|
"reflect"
|
|
|
|
|
|
|
|
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
|
|
|
)
|
|
|
|
|
|
2020-12-29 17:49:38 +00:00
|
|
|
var (
|
|
|
|
|
ErrCannotReadFile = errors.New("cannot read servers from file")
|
|
|
|
|
ErrCannotWriteFile = errors.New("cannot write servers to file")
|
2020-08-25 19:38:50 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
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) +
|
2021-03-05 22:45:54 -05:00
|
|
|
len(allServers.HideMyAss.Servers) +
|
2021-06-20 09:21:48 -07:00
|
|
|
len(allServers.Ipvanish.Servers) +
|
2021-05-31 00:11:16 +00:00
|
|
|
len(allServers.Ivpn.Servers) +
|
2020-08-25 19:38:50 -04:00
|
|
|
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) +
|
2021-02-26 12:58:58 +00:00
|
|
|
len(allServers.Pia.Servers) +
|
2021-03-05 22:58:57 -05:00
|
|
|
len(allServers.Privatevpn.Servers) +
|
2021-04-25 15:44:45 -04:00
|
|
|
len(allServers.Protonvpn.Servers) +
|
2020-08-25 19:38:50 -04:00
|
|
|
len(allServers.Purevpn.Servers) +
|
|
|
|
|
len(allServers.Surfshark.Servers) +
|
2021-02-17 20:36:30 -05:00
|
|
|
len(allServers.Torguard.Servers) +
|
2021-06-20 09:18:03 -07:00
|
|
|
len(allServers.VPNUnlimited.Servers) +
|
2020-08-25 19:38:50 -04:00
|
|
|
len(allServers.Vyprvpn.Servers) +
|
2021-09-23 07:58:13 -07:00
|
|
|
len(allServers.Wevpn.Servers) +
|
2020-08-25 19:38:50 -04:00
|
|
|
len(allServers.Windscribe.Servers)
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-27 19:10:03 +00:00
|
|
|
func (s *Storage) SyncServers() (err error) {
|
2021-09-30 15:22:57 +00:00
|
|
|
serversOnFile, err := s.readFromFile(s.filepath, s.hardcodedServers)
|
2020-12-29 17:49:38 +00:00
|
|
|
if err != nil {
|
2021-08-27 19:10:03 +00:00
|
|
|
return fmt.Errorf("%w: %s", ErrCannotReadFile, err)
|
2020-08-25 19:38:50 -04:00
|
|
|
}
|
|
|
|
|
|
2021-08-27 19:10:03 +00:00
|
|
|
hardcodedCount := countServers(s.hardcodedServers)
|
2020-12-29 17:49:38 +00:00
|
|
|
countOnFile := countServers(serversOnFile)
|
|
|
|
|
|
|
|
|
|
if countOnFile == 0 {
|
2021-08-27 19:10:03 +00:00
|
|
|
s.logger.Info(fmt.Sprintf(
|
|
|
|
|
"creating %s with %d hardcoded servers",
|
|
|
|
|
s.filepath, hardcodedCount))
|
|
|
|
|
s.mergedServers = s.hardcodedServers
|
2020-12-29 17:49:38 +00:00
|
|
|
} else {
|
2021-08-27 19:10:03 +00:00
|
|
|
s.logger.Info(fmt.Sprintf(
|
|
|
|
|
"merging by most recent %d hardcoded servers and %d servers read from %s",
|
|
|
|
|
hardcodedCount, countOnFile, s.filepath))
|
2020-12-29 17:49:38 +00:00
|
|
|
|
2021-08-27 19:10:03 +00:00
|
|
|
s.mergedServers = s.mergeServers(s.hardcodedServers, serversOnFile)
|
2020-12-29 17:49:38 +00:00
|
|
|
}
|
2020-08-25 19:38:50 -04:00
|
|
|
|
2021-08-27 19:10:03 +00:00
|
|
|
// Eventually write file
|
|
|
|
|
if s.filepath == "" || reflect.DeepEqual(serversOnFile, s.mergedServers) {
|
|
|
|
|
return nil
|
2021-05-06 21:10:28 +00:00
|
|
|
}
|
|
|
|
|
|
2021-08-27 19:10:03 +00:00
|
|
|
if err := flushToFile(s.filepath, s.mergedServers); err != nil {
|
|
|
|
|
return fmt.Errorf("%w: %s", ErrCannotWriteFile, err)
|
2020-12-29 00:55:31 +00:00
|
|
|
}
|
2021-08-27 19:10:03 +00:00
|
|
|
return nil
|
2020-08-25 19:38:50 -04:00
|
|
|
}
|