feat: add support for TLS with Postgres

This commit is contained in:
azz 2022-08-16 08:50:30 +01:00
parent 193b4213b3
commit 4c7f54020b
No known key found for this signature in database
GPG key ID: FA4B7CA14E83F106
2 changed files with 6 additions and 1 deletions

5
app.go
View file

@ -129,13 +129,16 @@ func NewHeadscale(cfg *Config) (*Headscale, error) {
switch cfg.DBtype { switch cfg.DBtype {
case Postgres: case Postgres:
dbString = fmt.Sprintf( dbString = fmt.Sprintf(
"host=%s port=%d dbname=%s user=%s password=%s sslmode=disable", "host=%s port=%d dbname=%s user=%s password=%s",
cfg.DBhost, cfg.DBhost,
cfg.DBport, cfg.DBport,
cfg.DBname, cfg.DBname,
cfg.DBuser, cfg.DBuser,
cfg.DBpass, cfg.DBpass,
) )
if !cfg.DBssl {
dbString = dbString + " sslmode=disable"
}
case Sqlite: case Sqlite:
dbString = cfg.DBpath dbString = cfg.DBpath
default: default:

View file

@ -47,6 +47,7 @@ type Config struct {
DBname string DBname string
DBuser string DBuser string
DBpass string DBpass string
DBssl bool
TLS TLSConfig TLS TLSConfig
@ -506,6 +507,7 @@ func GetHeadscaleConfig() (*Config, error) {
DBname: viper.GetString("db_name"), DBname: viper.GetString("db_name"),
DBuser: viper.GetString("db_user"), DBuser: viper.GetString("db_user"),
DBpass: viper.GetString("db_pass"), DBpass: viper.GetString("db_pass"),
DBssl: viper.GetBool("db_ssl"),
TLS: GetTLSConfig(), TLS: GetTLSConfig(),