2020-08-25 19:38:50 -04:00
|
|
|
package storage
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"encoding/json"
|
|
|
|
|
"fmt"
|
|
|
|
|
"reflect"
|
|
|
|
|
|
|
|
|
|
"github.com/qdm12/gluetun/internal/models"
|
2020-12-29 00:55:31 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/os"
|
2020-08-25 19:38:50 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
jsonFilepath = "/gluetun/servers.json"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func countServers(allServers models.AllServers) int {
|
|
|
|
|
return len(allServers.Cyberghost.Servers) +
|
|
|
|
|
len(allServers.Mullvad.Servers) +
|
|
|
|
|
len(allServers.Nordvpn.Servers) +
|
|
|
|
|
len(allServers.Pia.Servers) +
|
2020-11-08 20:56:49 -05:00
|
|
|
len(allServers.Privado.Servers) +
|
2020-08-25 19:38:50 -04:00
|
|
|
len(allServers.Purevpn.Servers) +
|
|
|
|
|
len(allServers.Surfshark.Servers) +
|
|
|
|
|
len(allServers.Vyprvpn.Servers) +
|
|
|
|
|
len(allServers.Windscribe.Servers)
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-20 02:45:28 +00:00
|
|
|
func (s *storage) SyncServers(hardcodedServers models.AllServers, write bool) (
|
|
|
|
|
allServers models.AllServers, err error) {
|
2020-08-25 19:38:50 -04:00
|
|
|
// Eventually read file
|
|
|
|
|
var serversOnFile models.AllServers
|
2020-12-29 00:55:31 +00:00
|
|
|
file, err := s.os.OpenFile(jsonFilepath, os.O_RDONLY, 0)
|
|
|
|
|
if err != nil && !os.IsNotExist(err) {
|
|
|
|
|
return allServers, err
|
|
|
|
|
}
|
2020-08-25 19:38:50 -04:00
|
|
|
if err == nil {
|
2020-12-29 00:55:31 +00:00
|
|
|
var serversOnFile models.AllServers
|
|
|
|
|
decoder := json.NewDecoder(file)
|
|
|
|
|
if err := decoder.Decode(&serversOnFile); err != nil {
|
|
|
|
|
_ = file.Close()
|
2020-08-25 19:38:50 -04:00
|
|
|
return allServers, err
|
|
|
|
|
}
|
2020-12-29 00:55:31 +00:00
|
|
|
return allServers, file.Close()
|
2020-08-25 19:38:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Merge data from file and hardcoded
|
|
|
|
|
s.logger.Info("Merging by most recent %d hardcoded servers and %d servers read from %s",
|
|
|
|
|
countServers(hardcodedServers), countServers(serversOnFile), jsonFilepath)
|
|
|
|
|
allServers = s.mergeServers(hardcodedServers, serversOnFile)
|
|
|
|
|
|
|
|
|
|
// Eventually write file
|
2020-08-28 08:17:04 -04:00
|
|
|
if !write || reflect.DeepEqual(serversOnFile, allServers) {
|
2020-08-25 19:38:50 -04:00
|
|
|
return allServers, nil
|
|
|
|
|
}
|
2020-08-28 08:17:04 -04:00
|
|
|
return allServers, s.FlushToFile(allServers)
|
2020-08-25 19:38:50 -04:00
|
|
|
}
|
|
|
|
|
|
2020-08-28 08:17:04 -04:00
|
|
|
func (s *storage) FlushToFile(servers models.AllServers) error {
|
2020-12-29 00:55:31 +00:00
|
|
|
file, err := s.os.OpenFile(jsonFilepath, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, 0644)
|
2020-08-25 19:38:50 -04:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2020-12-29 00:55:31 +00:00
|
|
|
encoder := json.NewEncoder(file)
|
|
|
|
|
encoder.SetIndent("", " ")
|
|
|
|
|
if err := encoder.Encode(servers); err != nil {
|
|
|
|
|
_ = file.Close()
|
|
|
|
|
return fmt.Errorf("cannot write to file: %w", err)
|
|
|
|
|
}
|
|
|
|
|
return file.Close()
|
2020-08-25 19:38:50 -04:00
|
|
|
}
|