2020-04-12 20:05:28 +00:00
|
|
|
package settings
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"net"
|
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
|
|
"github.com/qdm12/private-internet-access-docker/internal/params"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Firewall contains settings to customize the firewall operation
|
|
|
|
|
type Firewall struct {
|
|
|
|
|
AllowedSubnets []net.IPNet
|
2020-06-12 17:11:21 +00:00
|
|
|
Enabled bool
|
2020-07-13 02:14:56 +00:00
|
|
|
Debug bool
|
2020-04-12 20:05:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (f *Firewall) String() string {
|
|
|
|
|
allowedSubnets := make([]string, len(f.AllowedSubnets))
|
|
|
|
|
for i := range f.AllowedSubnets {
|
|
|
|
|
allowedSubnets[i] = f.AllowedSubnets[i].String()
|
|
|
|
|
}
|
2020-06-12 17:11:21 +00:00
|
|
|
if !f.Enabled {
|
|
|
|
|
return "Firewall settings: disabled"
|
|
|
|
|
}
|
2020-04-12 20:05:28 +00:00
|
|
|
settingsList := []string{
|
|
|
|
|
"Firewall settings:",
|
|
|
|
|
"Allowed subnets: " + strings.Join(allowedSubnets, ", "),
|
|
|
|
|
}
|
2020-07-13 02:14:56 +00:00
|
|
|
if f.Debug {
|
|
|
|
|
settingsList = append(settingsList, "Debug: on")
|
|
|
|
|
}
|
2020-04-12 20:05:28 +00:00
|
|
|
return strings.Join(settingsList, "\n |--")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// GetFirewallSettings obtains firewall settings from environment variables using the params package.
|
|
|
|
|
func GetFirewallSettings(paramsReader params.Reader) (settings Firewall, err error) {
|
|
|
|
|
settings.AllowedSubnets, err = paramsReader.GetExtraSubnets()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return settings, err
|
|
|
|
|
}
|
2020-06-12 17:11:21 +00:00
|
|
|
settings.Enabled, err = paramsReader.GetFirewall()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return settings, err
|
|
|
|
|
}
|
2020-07-13 02:14:56 +00:00
|
|
|
settings.Debug, err = paramsReader.GetFirewallDebug()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return settings, err
|
|
|
|
|
}
|
2020-04-12 20:05:28 +00:00
|
|
|
return settings, nil
|
|
|
|
|
}
|