* Adapt storage: SyncServers write to file option, export FlushToFile * CLI built-in updater for old and new PIA servers * Update hardcoded IP addresses for PIA old and new servers * Add PIA old to allServers struct and update timestamps * Adapt code to work with new and old PIA servers * Remove PIA subdomains (unneeded) from resolver tool
243 lines
7.9 KiB
Go
243 lines
7.9 KiB
Go
package settings
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
"github.com/qdm12/gluetun/internal/params"
|
|
)
|
|
|
|
// GetPIASettings obtains PIA settings from environment variables using the params package.
|
|
func GetPIASettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.PrivateInternetAccess
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
encryptionPreset, err := paramsReader.GetPIAEncryptionPreset()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.EncryptionPreset = encryptionPreset
|
|
settings.ExtraConfigOptions.EncryptionPreset = encryptionPreset
|
|
settings.ServerSelection.Region, err = paramsReader.GetPIARegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetPIAOldSettings obtains PIA settings for the older PIA servers (pre summer 2020) from environment variables using the params package.
|
|
func GetPIAOldSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.PrivateInternetAccessOld
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
encryptionPreset, err := paramsReader.GetPIAEncryptionPreset()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.EncryptionPreset = encryptionPreset
|
|
settings.ExtraConfigOptions.EncryptionPreset = encryptionPreset
|
|
settings.ServerSelection.Region, err = paramsReader.GetPIAOldRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.PortForwarding.Enabled, err = paramsReader.GetPortForwarding()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
if settings.PortForwarding.Enabled {
|
|
settings.PortForwarding.Filepath, err = paramsReader.GetPortForwardingStatusFilepath()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetMullvadSettings obtains Mullvad settings from environment variables using the params package.
|
|
func GetMullvadSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Mullvad
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Country, err = paramsReader.GetMullvadCountry()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.City, err = paramsReader.GetMullvadCity()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.ISP, err = paramsReader.GetMullvadISP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.CustomPort, err = paramsReader.GetMullvadPort()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
if settings.ServerSelection.Protocol == constants.TCP {
|
|
switch settings.ServerSelection.CustomPort {
|
|
case 0, 80, 443, 1401:
|
|
default:
|
|
return settings, fmt.Errorf("port %d is not valid for TCP protocol", settings.ServerSelection.CustomPort)
|
|
}
|
|
} else {
|
|
switch settings.ServerSelection.CustomPort {
|
|
case 0, 53, 1194, 1195, 1196, 1197, 1300, 1301, 1302, 1303, 1400:
|
|
default:
|
|
return settings, fmt.Errorf("port %d is not valid for UDP protocol", settings.ServerSelection.CustomPort)
|
|
}
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetWindscribeSettings obtains Windscribe settings from environment variables using the params package.
|
|
func GetWindscribeSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Windscribe
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetWindscribeRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.CustomPort, err = paramsReader.GetWindscribePort(settings.ServerSelection.Protocol)
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetSurfsharkSettings obtains Surfshark settings from environment variables using the params package.
|
|
func GetSurfsharkSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Surfshark
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetSurfsharkRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetCyberghostSettings obtains Cyberghost settings from environment variables using the params package.
|
|
func GetCyberghostSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Cyberghost
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ExtraConfigOptions.ClientKey, err = paramsReader.GetCyberghostClientKey()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Group, err = paramsReader.GetCyberghostGroup()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetCyberghostRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetVyprvpnSettings obtains Vyprvpn settings from environment variables using the params package.
|
|
func GetVyprvpnSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Vyprvpn
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetVyprvpnRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetNordvpnSettings obtains NordVPN settings from environment variables using the params package.
|
|
func GetNordvpnSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Nordvpn
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetNordvpnRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Number, err = paramsReader.GetNordvpnNumber()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|
|
|
|
// GetPurevpnSettings obtains Purevpn settings from environment variables using the params package.
|
|
func GetPurevpnSettings(paramsReader params.Reader) (settings models.ProviderSettings, err error) {
|
|
settings.Name = constants.Mullvad
|
|
settings.ServerSelection.Protocol, err = paramsReader.GetNetworkProtocol()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.TargetIP, err = paramsReader.GetTargetIP()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Region, err = paramsReader.GetPurevpnRegion()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.Country, err = paramsReader.GetPurevpnCountry()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
settings.ServerSelection.City, err = paramsReader.GetPurevpnCity()
|
|
if err != nil {
|
|
return settings, err
|
|
}
|
|
return settings, nil
|
|
}
|