feat: further instrument main file with logging
This commit is contained in:
31
main.go
31
main.go
@@ -39,39 +39,64 @@ func main() {
|
|||||||
var externalIpProvider externalIpProvider.ExternalIpProvider
|
var externalIpProvider externalIpProvider.ExternalIpProvider
|
||||||
switch configClient.ExternalIPProvider.Type {
|
switch configClient.ExternalIPProvider.Type {
|
||||||
case "plain":
|
case "plain":
|
||||||
|
logger.Info("Using plain external IP provider", slog.String("external_ip_provider", "plain"))
|
||||||
|
|
||||||
var plainConfig plainExternalIpProvider.PlainExternalIpProviderConfig
|
var plainConfig plainExternalIpProvider.PlainExternalIpProviderConfig
|
||||||
err := configClient.ExternalIPProvider.ProviderConfig.Decode(&plainConfig)
|
err := configClient.ExternalIPProvider.ProviderConfig.Decode(&plainConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
logger.Error("Failed to create config",
|
||||||
|
slog.String("external_ip_provider", "plain"),
|
||||||
|
slog.String("error", err.Error()),
|
||||||
|
)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
externalIpProvider, err = plainExternalIpProvider.New(plainConfig)
|
externalIpProvider, err = plainExternalIpProvider.New(plainConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
logger.Error("Failed to create plain external IP provider",
|
||||||
|
slog.String("external_ip_provider", "plain"),
|
||||||
|
slog.String("error", err.Error()),
|
||||||
|
)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
logger.Error("Unknown external IP provider", slog.String("external_ip_provider", configClient.ExternalIPProvider.Type))
|
||||||
panic(fmt.Errorf("unknown external IP provider: %s", configClient.ExternalIPProvider.Type))
|
panic(fmt.Errorf("unknown external IP provider: %s", configClient.ExternalIPProvider.Type))
|
||||||
}
|
}
|
||||||
|
|
||||||
var dnsProvider dnsProvider.DNSProvider
|
var dnsProvider dnsProvider.DNSProvider
|
||||||
switch configClient.DNSProvider.Type {
|
switch configClient.DNSProvider.Type {
|
||||||
case "ionos":
|
case "ionos":
|
||||||
|
logger.Info("Using IONOS DNS provider", slog.String("dns_provider", "ionos"))
|
||||||
|
|
||||||
var ionosConfig ionos.IONOSConfig
|
var ionosConfig ionos.IONOSConfig
|
||||||
err := configClient.DNSProvider.ProviderConfig.Decode(&ionosConfig)
|
err := configClient.DNSProvider.ProviderConfig.Decode(&ionosConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
logger.Error("Failed to create IONOS DNS provider",
|
||||||
|
slog.String("dns_provider", "ionos"),
|
||||||
|
slog.String("error", err.Error()),
|
||||||
|
)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
dnsProvider, err = ionos.NewIonos(&ionosConfig)
|
dnsProvider, err = ionos.NewIonos(&ionosConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
logger.Error("Failed to create IONOS DNS provider",
|
||||||
|
slog.String("dns_provider", "ionos"),
|
||||||
|
slog.String("error", err.Error()),
|
||||||
|
)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
logger.Error("Unknown DNS provider", slog.String("dns_provider", configClient.DNSProvider.Type))
|
||||||
panic(fmt.Errorf("unknown DNS provider: %s", configClient.DNSProvider.Type))
|
panic(fmt.Errorf("unknown DNS provider: %s", configClient.DNSProvider.Type))
|
||||||
}
|
}
|
||||||
|
|
||||||
var notificationProvider notificationProvider.NotificationProvider
|
var notificationProvider notificationProvider.NotificationProvider
|
||||||
switch configClient.NotificationProvider.Type {
|
switch configClient.NotificationProvider.Type {
|
||||||
case "gotify":
|
case "gotify":
|
||||||
|
logger.Info("Using Gotify notification provider", slog.String("notification_provider", "gotify"))
|
||||||
|
|
||||||
var gotifyConfig gotify.NotificationProviderImplGotifyConfig
|
var gotifyConfig gotify.NotificationProviderImplGotifyConfig
|
||||||
err := configClient.NotificationProvider.ProviderConfig.Decode(&gotifyConfig)
|
err := configClient.NotificationProvider.ProviderConfig.Decode(&gotifyConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -80,9 +105,15 @@ func main() {
|
|||||||
|
|
||||||
notificationProvider, err = gotify.New(gotifyConfig)
|
notificationProvider, err = gotify.New(gotifyConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
logger.Error("Failed to create Gotify notification provider",
|
||||||
|
slog.String("notification_provider", "gotify"),
|
||||||
|
slog.String("error", err.Error()),
|
||||||
|
)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
logger.Info("Using console notification provider", slog.String("notification_provider", "console"))
|
||||||
|
|
||||||
notificationProvider = notificationProviderConsole.New()
|
notificationProvider = notificationProviderConsole.New()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user