2021-02-06 11:05:50 -05:00
|
|
|
package configuration
|
|
|
|
|
|
|
|
|
|
import (
|
2021-07-23 02:34:15 +00:00
|
|
|
"fmt"
|
2021-02-06 11:05:50 -05:00
|
|
|
|
|
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
|
|
|
|
"github.com/qdm12/golibs/params"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func (settings *Provider) privateinternetaccessLines() (lines []string) {
|
|
|
|
|
if len(settings.ServerSelection.Regions) > 0 {
|
|
|
|
|
lines = append(lines, lastIndent+"Regions: "+commaJoin(settings.ServerSelection.Regions))
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-09 16:49:22 +00:00
|
|
|
if len(settings.ServerSelection.Hostnames) > 0 {
|
|
|
|
|
lines = append(lines, lastIndent+"Hostnames: "+commaJoin(settings.ServerSelection.Hostnames))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(settings.ServerSelection.Names) > 0 {
|
|
|
|
|
lines = append(lines, lastIndent+"Names: "+commaJoin(settings.ServerSelection.Names))
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-17 16:54:22 +00:00
|
|
|
lines = append(lines, settings.ServerSelection.OpenVPN.lines()...)
|
2021-02-06 11:05:50 -05:00
|
|
|
|
|
|
|
|
if settings.PortForwarding.Enabled {
|
|
|
|
|
lines = append(lines, lastIndent+"Port forwarding:")
|
|
|
|
|
for _, line := range settings.PortForwarding.lines() {
|
|
|
|
|
lines = append(lines, indent+line)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return lines
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (settings *Provider) readPrivateInternetAccess(r reader) (err error) {
|
|
|
|
|
settings.Name = constants.PrivateInternetAccess
|
|
|
|
|
|
|
|
|
|
settings.ServerSelection.TargetIP, err = readTargetIP(r.env)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
settings.ServerSelection.Regions, err = r.env.CSVInside("REGION", constants.PIAGeoChoices())
|
|
|
|
|
if err != nil {
|
2021-07-23 02:34:15 +00:00
|
|
|
return fmt.Errorf("environment variable REGION: %w", err)
|
2021-02-06 11:05:50 -05:00
|
|
|
}
|
|
|
|
|
|
2021-05-09 16:49:22 +00:00
|
|
|
settings.ServerSelection.Hostnames, err = r.env.CSVInside("SERVER_HOSTNAME", constants.PIAHostnameChoices())
|
|
|
|
|
if err != nil {
|
2021-07-23 02:34:15 +00:00
|
|
|
return fmt.Errorf("environment variable SERVER_HOSTNAME: %w", err)
|
2021-05-09 16:49:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
settings.ServerSelection.Hostnames, err = r.env.CSVInside("SERVER_NAME", constants.PIANameChoices())
|
|
|
|
|
if err != nil {
|
2021-07-23 02:34:15 +00:00
|
|
|
return fmt.Errorf("environment variable SERVER_NAME: %w", err)
|
2021-05-09 16:49:22 +00:00
|
|
|
}
|
|
|
|
|
|
2021-02-06 11:05:50 -05:00
|
|
|
settings.PortForwarding.Enabled, err = r.env.OnOff("PORT_FORWARDING", params.Default("off"))
|
|
|
|
|
if err != nil {
|
2021-07-23 02:34:15 +00:00
|
|
|
return fmt.Errorf("environment variable PORT_FORWARDING: %w", err)
|
2021-02-06 11:05:50 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if settings.PortForwarding.Enabled {
|
2021-02-06 18:31:14 +00:00
|
|
|
settings.PortForwarding.Filepath, err = r.env.Path("PORT_FORWARDING_STATUS_FILE",
|
2021-02-06 11:05:50 -05:00
|
|
|
params.Default("/tmp/gluetun/forwarded_port"), params.CaseSensitiveValue())
|
|
|
|
|
if err != nil {
|
2021-07-23 02:34:15 +00:00
|
|
|
return fmt.Errorf("environment variable PORT_FORWARDING_STATUS_FILE: %w", err)
|
2021-02-06 11:05:50 -05:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-17 16:54:22 +00:00
|
|
|
return settings.ServerSelection.OpenVPN.readPrivateInternetAccess(r)
|
2021-02-06 11:05:50 -05:00
|
|
|
}
|
2021-08-17 15:44:11 +00:00
|
|
|
|
2021-08-17 16:54:22 +00:00
|
|
|
func (settings *OpenVPNSelection) readPrivateInternetAccess(r reader) (err error) {
|
2021-08-17 15:44:11 +00:00
|
|
|
settings.EncPreset, err = getPIAEncryptionPreset(r)
|
2021-08-17 16:54:22 +00:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
settings.CustomPort, err = readPortOrZero(r.env, "PORT")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("environment variable PORT: %w", err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
2021-08-17 15:44:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func getPIAEncryptionPreset(r reader) (encryptionPreset string, err error) {
|
|
|
|
|
encryptionPreset, err = r.env.Inside("PIA_ENCRYPTION",
|
|
|
|
|
[]string{constants.PIAEncryptionPresetNone, constants.PIAEncryptionPresetNormal, constants.PIAEncryptionPresetStrong},
|
|
|
|
|
params.RetroKeys([]string{"ENCRYPTION"}, r.onRetroActive),
|
|
|
|
|
params.Default(constants.PIACertificateStrong),
|
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return "", fmt.Errorf("environment variable PIA_ENCRYPTION: %w", err)
|
|
|
|
|
}
|
2021-08-17 16:54:22 +00:00
|
|
|
|
2021-08-17 15:44:11 +00:00
|
|
|
return encryptionPreset, nil
|
|
|
|
|
}
|