2022-02-22 16:51:02 +00:00
|
|
|
// Copyright 2022 Prometheus Team
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package telegram
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-11-25 19:23:54 +00:00
|
|
|
"fmt"
|
2022-02-22 16:51:02 +00:00
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/go-kit/log"
|
2022-03-25 16:59:51 +00:00
|
|
|
"github.com/go-kit/log/level"
|
|
|
|
commoncfg "github.com/prometheus/common/config"
|
2022-02-22 16:51:02 +00:00
|
|
|
"gopkg.in/telebot.v3"
|
|
|
|
|
|
|
|
"github.com/prometheus/alertmanager/config"
|
|
|
|
"github.com/prometheus/alertmanager/notify"
|
2022-03-25 16:59:51 +00:00
|
|
|
"github.com/prometheus/alertmanager/template"
|
2022-02-22 16:51:02 +00:00
|
|
|
"github.com/prometheus/alertmanager/types"
|
|
|
|
)
|
|
|
|
|
2022-11-25 19:47:20 +00:00
|
|
|
// Telegram supports 4096 chars max - from https://limits.tginfo.me/en.
|
|
|
|
const maxMessageLenRunes = 4096
|
|
|
|
|
2022-02-22 16:51:02 +00:00
|
|
|
// Notifier implements a Notifier for telegram notifications.
|
|
|
|
type Notifier struct {
|
|
|
|
conf *config.TelegramConfig
|
|
|
|
tmpl *template.Template
|
|
|
|
logger log.Logger
|
|
|
|
client *telebot.Bot
|
|
|
|
retrier *notify.Retrier
|
|
|
|
}
|
|
|
|
|
|
|
|
// New returns a new Telegram notification handler.
|
|
|
|
func New(conf *config.TelegramConfig, t *template.Template, l log.Logger, httpOpts ...commoncfg.HTTPClientOption) (*Notifier, error) {
|
|
|
|
httpclient, err := commoncfg.NewClientFromConfig(*conf.HTTPConfig, "telegram", httpOpts...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
client, err := createTelegramClient(conf.BotToken, conf.APIUrl.String(), conf.ParseMode, httpclient)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &Notifier{
|
|
|
|
conf: conf,
|
|
|
|
tmpl: t,
|
|
|
|
logger: l,
|
|
|
|
client: client,
|
|
|
|
retrier: ¬ify.Retrier{},
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (n *Notifier) Notify(ctx context.Context, alert ...*types.Alert) (bool, error) {
|
|
|
|
var (
|
|
|
|
err error
|
|
|
|
data = notify.GetTemplateData(ctx, n.tmpl, alert, n.logger)
|
|
|
|
tmpl = notify.TmplText(n.tmpl, data, &err)
|
|
|
|
)
|
|
|
|
|
2022-11-25 19:23:54 +00:00
|
|
|
key, ok := notify.GroupKey(ctx)
|
|
|
|
if !ok {
|
|
|
|
return false, fmt.Errorf("group key missing")
|
|
|
|
}
|
|
|
|
|
2022-11-25 19:47:20 +00:00
|
|
|
messageText, truncated := notify.TruncateInRunes(tmpl(n.conf.Message), maxMessageLenRunes)
|
2022-02-22 16:51:02 +00:00
|
|
|
if truncated {
|
2022-11-25 19:47:20 +00:00
|
|
|
level.Warn(n.logger).Log("msg", "Truncated message", "alert", key, "runes", maxMessageLenRunes)
|
2022-02-22 16:51:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message, err := n.client.Send(telebot.ChatID(n.conf.ChatID), messageText, &telebot.SendOptions{
|
|
|
|
DisableNotification: n.conf.DisableNotifications,
|
|
|
|
DisableWebPagePreview: true,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return true, err
|
|
|
|
}
|
|
|
|
level.Debug(n.logger).Log("msg", "Telegram message successfully published", "message_id", message.ID, "chat_id", message.Chat.ID)
|
|
|
|
|
|
|
|
return false, nil
|
|
|
|
}
|
|
|
|
|
2022-03-25 16:59:51 +00:00
|
|
|
func createTelegramClient(token config.Secret, apiURL, parseMode string, httpClient *http.Client) (*telebot.Bot, error) {
|
2022-02-22 16:51:02 +00:00
|
|
|
secret := string(token)
|
|
|
|
bot, err := telebot.NewBot(telebot.Settings{
|
|
|
|
Token: secret,
|
2022-03-25 16:59:51 +00:00
|
|
|
URL: apiURL,
|
2022-02-22 16:51:02 +00:00
|
|
|
ParseMode: parseMode,
|
|
|
|
Client: httpClient,
|
|
|
|
Offline: true,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return bot, nil
|
|
|
|
}
|