add alias decision logic
This commit is contained in:
parent
c7f6f45086
commit
b3273545b5
3 changed files with 37 additions and 22 deletions
|
@ -13,6 +13,7 @@ import (
|
||||||
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/configuration"
|
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/configuration"
|
||||||
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/logging"
|
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/logging"
|
||||||
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/mailcow"
|
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/mailcow"
|
||||||
|
"code.lila.network/adoralaura/mailcow-admin-aliases/internal/misc"
|
||||||
"github.com/spf13/pflag"
|
"github.com/spf13/pflag"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -39,26 +40,25 @@ func main() {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, domain := range domains {
|
existingAliases, existingAliasesSlice, err := mailcow.LoadAliases(cfg)
|
||||||
for _, prefix := range cfg.MailPrefixes {
|
|
||||||
address := prefix + "@" + domain.DomainName
|
|
||||||
if address != cfg.AdminEmail {
|
|
||||||
wantedAliases = append(wantedAliases, address)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
aliases, err := mailcow.LoadAliases(cfg)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Error("failed to get aliases", "error", err.Error())
|
slog.Error("failed to get aliases", "error", err.Error())
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
slog.Info(fmt.Sprintf("Found %v domains, %v aliases.", len(domains), len(aliases)))
|
slog.Info(fmt.Sprintf("Found %v domains, %v aliases.", len(domains), len(existingAliases)))
|
||||||
|
|
||||||
for _, alias := range aliases {
|
|
||||||
for _, wantedPrefix := range cfg.MailPrefixes {
|
|
||||||
|
|
||||||
|
for _, domain := range domains {
|
||||||
|
for _, prefix := range cfg.MailPrefixes {
|
||||||
|
address := prefix + "@" + domain.DomainName
|
||||||
|
if address != cfg.AdminEmail && !misc.StringIsInStringSlice(existingAliasesSlice, address) {
|
||||||
|
slog.Info(fmt.Sprintf("%v: Adding to wanted alias list", address))
|
||||||
|
wantedAliases = append(wantedAliases, address)
|
||||||
|
} else {
|
||||||
|
slog.Info(fmt.Sprintf("%v: Ignoring alias", address))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: create aliases
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,8 +36,9 @@ func NewAlias(alias string, destination string) MailcowAlias {
|
||||||
return a
|
return a
|
||||||
}
|
}
|
||||||
|
|
||||||
func LoadAliases(cfg configuration.Config) ([]MailcowAlias, error) {
|
func LoadAliases(cfg configuration.Config) ([]MailcowAlias, []string, error) {
|
||||||
var domains []MailcowAlias
|
var aliases []MailcowAlias
|
||||||
|
var aliasSlice []string
|
||||||
|
|
||||||
url := cfg.ApiEndpoint + configuration.AllAliasesApiEndpoint
|
url := cfg.ApiEndpoint + configuration.AllAliasesApiEndpoint
|
||||||
method := "GET"
|
method := "GET"
|
||||||
|
@ -48,14 +49,14 @@ func LoadAliases(cfg configuration.Config) ([]MailcowAlias, error) {
|
||||||
slog.Debug("alias request", "method", method, "url", url)
|
slog.Debug("alias request", "method", method, "url", url)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []MailcowAlias{}, fmt.Errorf("failed to create alias http request: %w", err)
|
return []MailcowAlias{}, []string{}, fmt.Errorf("failed to create alias http request: %w", err)
|
||||||
}
|
}
|
||||||
req.Header.Add("accept", "application/json")
|
req.Header.Add("accept", "application/json")
|
||||||
req.Header.Add("X-API-Key", cfg.ApiKey)
|
req.Header.Add("X-API-Key", cfg.ApiKey)
|
||||||
|
|
||||||
res, err := client.Do(req)
|
res, err := client.Do(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []MailcowAlias{}, fmt.Errorf("failed to request aliases from server: %w", err)
|
return []MailcowAlias{}, []string{}, fmt.Errorf("failed to request aliases from server: %w", err)
|
||||||
}
|
}
|
||||||
defer res.Body.Close()
|
defer res.Body.Close()
|
||||||
|
|
||||||
|
@ -63,13 +64,17 @@ func LoadAliases(cfg configuration.Config) ([]MailcowAlias, error) {
|
||||||
|
|
||||||
body, err := io.ReadAll(res.Body)
|
body, err := io.ReadAll(res.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []MailcowAlias{}, fmt.Errorf("failed to read alias request body: %w", err)
|
return []MailcowAlias{}, []string{}, fmt.Errorf("failed to read alias request body: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(body, &domains)
|
err = json.Unmarshal(body, &aliases)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []MailcowAlias{}, fmt.Errorf("failed to unmarshal alias request body: %w", err)
|
return []MailcowAlias{}, []string{}, fmt.Errorf("failed to unmarshal alias request body: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return domains, nil
|
for _, alias := range aliases {
|
||||||
|
aliasSlice = append(aliasSlice, alias.Address)
|
||||||
|
}
|
||||||
|
|
||||||
|
return aliases, aliasSlice, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,3 +9,13 @@ func StringIsInStringSlice(slice []string, s string) bool {
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func RemoveStringFromStringSlice(slice []string, s string) []string {
|
||||||
|
a := []string{}
|
||||||
|
for _, item := range slice {
|
||||||
|
if item != s {
|
||||||
|
a = append(a, item)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return a
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue