2017-10-30 08:30:44 +02:00
|
|
|
package notifications
|
|
|
|
|
|
|
|
import (
|
2019-07-21 19:58:19 +02:00
|
|
|
ty "github.com/containrrr/watchtower/pkg/types"
|
2018-03-02 14:08:40 +02:00
|
|
|
"github.com/johntdyer/slackrus"
|
2017-11-27 13:03:00 +02:00
|
|
|
log "github.com/sirupsen/logrus"
|
2019-06-22 22:04:36 +02:00
|
|
|
"github.com/spf13/cobra"
|
2020-12-21 16:17:45 +02:00
|
|
|
"github.com/spf13/viper"
|
2017-10-30 08:30:44 +02:00
|
|
|
)
|
|
|
|
|
2017-10-30 08:45:01 +02:00
|
|
|
// Notifier can send log output as notification to admins, with optional batching.
|
2017-10-30 08:30:44 +02:00
|
|
|
type Notifier struct {
|
2019-07-21 19:58:19 +02:00
|
|
|
types []ty.Notifier
|
2017-10-30 08:30:44 +02:00
|
|
|
}
|
|
|
|
|
2017-10-30 08:45:01 +02:00
|
|
|
// NewNotifier creates and returns a new Notifier, using global configuration.
|
2019-06-22 22:04:36 +02:00
|
|
|
func NewNotifier(c *cobra.Command) *Notifier {
|
2017-10-30 08:30:44 +02:00
|
|
|
n := &Notifier{}
|
|
|
|
|
2020-12-21 16:17:45 +02:00
|
|
|
level := viper.GetString("notifications-level")
|
2019-06-22 22:04:36 +02:00
|
|
|
logLevel, err := log.ParseLevel(level)
|
2018-03-02 14:08:40 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Notifications invalid log level: %s", err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
acceptedLogLevels := slackrus.LevelThreshold(logLevel)
|
|
|
|
|
2017-10-30 08:30:44 +02:00
|
|
|
// Parse types and create notifiers.
|
2020-12-21 16:17:45 +02:00
|
|
|
types := viper.GetStringSlice("notifications")
|
2019-12-27 13:05:56 +02:00
|
|
|
if err != nil {
|
2020-04-24 13:45:24 +02:00
|
|
|
log.WithField("could not read notifications argument", log.Fields{"Error": err}).Fatal()
|
2019-12-27 13:05:56 +02:00
|
|
|
}
|
2017-10-30 08:30:44 +02:00
|
|
|
for _, t := range types {
|
2019-07-21 19:58:19 +02:00
|
|
|
var tn ty.Notifier
|
2017-10-30 08:30:44 +02:00
|
|
|
switch t {
|
|
|
|
case emailType:
|
2018-03-02 14:08:40 +02:00
|
|
|
tn = newEmailNotifier(c, acceptedLogLevels)
|
2017-11-27 13:04:08 +02:00
|
|
|
case slackType:
|
2018-03-02 14:08:40 +02:00
|
|
|
tn = newSlackNotifier(c, acceptedLogLevels)
|
2018-03-13 08:39:54 +02:00
|
|
|
case msTeamsType:
|
|
|
|
tn = newMsTeamsNotifier(c, acceptedLogLevels)
|
2019-07-22 21:17:54 +02:00
|
|
|
case gotifyType:
|
|
|
|
tn = newGotifyNotifier(c, acceptedLogLevels)
|
2020-03-23 12:40:55 +02:00
|
|
|
case shoutrrrType:
|
|
|
|
tn = newShoutrrrNotifier(c, acceptedLogLevels)
|
2017-10-30 08:30:44 +02:00
|
|
|
default:
|
|
|
|
log.Fatalf("Unknown notification type %q", t)
|
|
|
|
}
|
2020-05-30 19:36:20 +02:00
|
|
|
n.types = append(n.types, tn)
|
2017-10-30 08:30:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return n
|
|
|
|
}
|
|
|
|
|
2017-10-30 08:45:01 +02:00
|
|
|
// StartNotification starts a log batch. Notifications will be accumulated after this point and only sent when SendNotification() is called.
|
2017-10-30 08:30:44 +02:00
|
|
|
func (n *Notifier) StartNotification() {
|
|
|
|
for _, t := range n.types {
|
|
|
|
t.StartNotification()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-30 08:45:01 +02:00
|
|
|
// SendNotification sends any notifications accumulated since StartNotification() was called.
|
2017-10-30 08:30:44 +02:00
|
|
|
func (n *Notifier) SendNotification() {
|
|
|
|
for _, t := range n.types {
|
|
|
|
t.SendNotification()
|
|
|
|
}
|
|
|
|
}
|
2020-08-08 22:55:51 +02:00
|
|
|
|
|
|
|
// Close closes all notifiers.
|
|
|
|
func (n *Notifier) Close() {
|
|
|
|
for _, t := range n.types {
|
|
|
|
t.Close()
|
|
|
|
}
|
|
|
|
}
|