summaryrefslogtreecommitdiff
path: root/internal/config
diff options
context:
space:
mode:
Diffstat (limited to 'internal/config')
-rw-r--r--internal/config/config.go47
-rw-r--r--internal/config/default.go26
-rw-r--r--internal/config/smtp.go33
3 files changed, 106 insertions, 0 deletions
diff --git a/internal/config/config.go b/internal/config/config.go
index bb789b7d2..7a3a92af9 100644
--- a/internal/config/config.go
+++ b/internal/config/config.go
@@ -63,6 +63,7 @@ type Config struct {
StatusesConfig *StatusesConfig `yaml:"statuses"`
LetsEncryptConfig *LetsEncryptConfig `yaml:"letsEncrypt"`
OIDCConfig *OIDCConfig `yaml:"oidc"`
+ SMTPConfig *SMTPConfig `yaml:"smtp"`
/*
Not parsed from .yaml configuration file.
@@ -95,6 +96,7 @@ func Empty() *Config {
StatusesConfig: &StatusesConfig{},
LetsEncryptConfig: &LetsEncryptConfig{},
OIDCConfig: &OIDCConfig{},
+ SMTPConfig: &SMTPConfig{},
AccountCLIFlags: make(map[string]string),
ExportCLIFlags: make(map[string]string),
}
@@ -318,6 +320,27 @@ func (c *Config) ParseCLIFlags(f KeyedFlags, version string) error {
c.OIDCConfig.Scopes = f.StringSlice(fn.OIDCScopes)
}
+ // smtp flags
+ if c.SMTPConfig.Host == "" || f.IsSet(fn.SMTPHost) {
+ c.SMTPConfig.Host = f.String(fn.SMTPHost)
+ }
+
+ if c.SMTPConfig.Port == 0 || f.IsSet(fn.SMTPPort) {
+ c.SMTPConfig.Port = f.Int(fn.SMTPPort)
+ }
+
+ if c.SMTPConfig.Username == "" || f.IsSet(fn.SMTPUsername) {
+ c.SMTPConfig.Username = f.String(fn.SMTPUsername)
+ }
+
+ if c.SMTPConfig.Password == "" || f.IsSet(fn.SMTPPassword) {
+ c.SMTPConfig.Password = f.String(fn.SMTPPassword)
+ }
+
+ if c.SMTPConfig.From == "" || f.IsSet(fn.SMTPFrom) {
+ c.SMTPConfig.From = f.String(fn.SMTPFrom)
+ }
+
// command-specific flags
// admin account CLI flags
@@ -399,6 +422,12 @@ type Flags struct {
OIDCClientID string
OIDCClientSecret string
OIDCScopes string
+
+ SMTPHost string
+ SMTPPort string
+ SMTPUsername string
+ SMTPPassword string
+ SMTPFrom string
}
// Defaults contains all the default values for a gotosocial config
@@ -458,6 +487,12 @@ type Defaults struct {
OIDCClientID string
OIDCClientSecret string
OIDCScopes []string
+
+ SMTPHost string
+ SMTPPort int
+ SMTPUsername string
+ SMTPPassword string
+ SMTPFrom string
}
// GetFlagNames returns a struct containing the names of the various flags used for
@@ -518,6 +553,12 @@ func GetFlagNames() Flags {
OIDCClientID: "oidc-client-id",
OIDCClientSecret: "oidc-client-secret",
OIDCScopes: "oidc-scopes",
+
+ SMTPHost: "smtp-host",
+ SMTPPort: "smtp-port",
+ SMTPUsername: "smtp-username",
+ SMTPPassword: "smtp-password",
+ SMTPFrom: "smtp-from",
}
}
@@ -579,5 +620,11 @@ func GetEnvNames() Flags {
OIDCClientID: "GTS_OIDC_CLIENT_ID",
OIDCClientSecret: "GTS_OIDC_CLIENT_SECRET",
OIDCScopes: "GTS_OIDC_SCOPES",
+
+ SMTPHost: "SMTP_HOST",
+ SMTPPort: "SMTP_PORT",
+ SMTPUsername: "SMTP_USERNAME",
+ SMTPPassword: "SMTP_PASSWORD",
+ SMTPFrom: "SMTP_FROM",
}
}
diff --git a/internal/config/default.go b/internal/config/default.go
index ad171a376..a04a5899b 100644
--- a/internal/config/default.go
+++ b/internal/config/default.go
@@ -67,6 +67,13 @@ func TestDefault() *Config {
ClientSecret: defaults.OIDCClientSecret,
Scopes: defaults.OIDCScopes,
},
+ SMTPConfig: &SMTPConfig{
+ Host: defaults.SMTPHost,
+ Port: defaults.SMTPPort,
+ Username: defaults.SMTPUsername,
+ Password: defaults.SMTPPassword,
+ From: defaults.SMTPFrom,
+ },
}
}
@@ -134,6 +141,13 @@ func Default() *Config {
ClientSecret: defaults.OIDCClientSecret,
Scopes: defaults.OIDCScopes,
},
+ SMTPConfig: &SMTPConfig{
+ Host: defaults.SMTPHost,
+ Port: defaults.SMTPPort,
+ Username: defaults.SMTPUsername,
+ Password: defaults.SMTPPassword,
+ From: defaults.SMTPFrom,
+ },
}
}
@@ -195,6 +209,12 @@ func GetDefaults() Defaults {
OIDCClientID: "",
OIDCClientSecret: "",
OIDCScopes: []string{oidc.ScopeOpenID, "profile", "email", "groups"},
+
+ SMTPHost: "",
+ SMTPPort: 0,
+ SMTPUsername: "",
+ SMTPPassword: "",
+ SMTPFrom: "GoToSocial",
}
}
@@ -253,5 +273,11 @@ func GetTestDefaults() Defaults {
OIDCClientID: "",
OIDCClientSecret: "",
OIDCScopes: []string{oidc.ScopeOpenID, "profile", "email", "groups"},
+
+ SMTPHost: "",
+ SMTPPort: 0,
+ SMTPUsername: "",
+ SMTPPassword: "",
+ SMTPFrom: "GoToSocial",
}
}
diff --git a/internal/config/smtp.go b/internal/config/smtp.go
new file mode 100644
index 000000000..daa4967bf
--- /dev/null
+++ b/internal/config/smtp.go
@@ -0,0 +1,33 @@
+/*
+ GoToSocial
+ Copyright (C) 2021 GoToSocial Authors admin@gotosocial.org
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+package config
+
+// SMTPConfig holds configuration for sending emails using the smtp protocol.
+type SMTPConfig struct {
+ // Host of the smtp server.
+ Host string `yaml:"host"`
+ // Port of the smtp server.
+ Port int `yaml:"port"`
+ // Username to use when authenticating with the smtp server.
+ Username string `yaml:"username"`
+ // Password to use when authenticating with the smtp server.
+ Password string `yaml:"password"`
+ // From address to use when sending emails.
+ From string `yaml:"from"`
+}