2022-01-06 09:00:24 +01:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/k3a/html2text"
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/logging"
|
2024-04-03 13:43:43 +03:00
|
|
|
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/zitadel/internal/notification/channels"
|
2022-01-06 09:00:24 +01:00
|
|
|
)
|
|
|
|
|
2023-03-16 18:24:30 +01:00
|
|
|
func InitStdoutChannel(config Config) channels.NotificationChannel {
|
2022-01-06 09:00:24 +01:00
|
|
|
|
2024-07-26 22:39:55 +02:00
|
|
|
logging.WithFields("logID", "NOTIF-D0164").Debug("successfully initialized stdout email and sms channel")
|
2022-01-06 09:00:24 +01:00
|
|
|
|
|
|
|
return channels.HandleMessageFunc(func(message channels.Message) error {
|
|
|
|
|
2023-03-29 00:09:06 +02:00
|
|
|
content, err := message.GetContent()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-01-06 09:00:24 +01:00
|
|
|
if config.Compact {
|
|
|
|
content = html2text.HTML2Text(content)
|
|
|
|
}
|
|
|
|
|
2024-07-26 22:39:55 +02:00
|
|
|
logging.WithFields("logID", "NOTIF-c73ba").WithFields(map[string]interface{}{
|
2022-01-06 09:00:24 +01:00
|
|
|
"type": fmt.Sprintf("%T", message),
|
|
|
|
"content": content,
|
|
|
|
}).Info("handling notification message")
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
}
|