2021-01-25 00:14:21 +01:00
|
|
|
package telegram
|
|
|
|
|
|
|
|
import (
|
2021-02-18 03:33:30 +01:00
|
|
|
"context"
|
|
|
|
|
2021-01-25 00:14:21 +01:00
|
|
|
tgbotapi "github.com/go-telegram-bot-api/telegram-bot-api"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
2022-06-06 17:41:31 +08:00
|
|
|
const (
|
|
|
|
ModeMarkdown = "Markdown"
|
|
|
|
ModeHTML = "HTML"
|
|
|
|
)
|
|
|
|
|
|
|
|
var parseMode = ModeHTML // HTML is the default mode.
|
2021-01-25 00:14:21 +01:00
|
|
|
|
2021-01-25 05:05:28 +01:00
|
|
|
// Telegram struct holds necessary data to communicate with the Telegram API.
|
2021-01-25 00:14:21 +01:00
|
|
|
type Telegram struct {
|
2021-01-29 19:24:22 +01:00
|
|
|
client *tgbotapi.BotAPI
|
|
|
|
chatIDs []int64
|
2021-01-25 00:14:21 +01:00
|
|
|
}
|
|
|
|
|
2021-01-25 05:05:28 +01:00
|
|
|
// New returns a new instance of a Telegram notification service.
|
2021-01-26 11:31:33 +01:00
|
|
|
// For more information about telegram api token:
|
|
|
|
// -> https://pkg.go.dev/github.com/go-telegram-bot-api/telegram-bot-api#NewBotAPI
|
2021-01-25 00:14:21 +01:00
|
|
|
func New(apiToken string) (*Telegram, error) {
|
|
|
|
client, err := tgbotapi.NewBotAPI(apiToken)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
t := &Telegram{
|
|
|
|
client: client,
|
|
|
|
chatIDs: []int64{},
|
|
|
|
}
|
|
|
|
|
|
|
|
return t, nil
|
|
|
|
}
|
|
|
|
|
2022-06-06 17:41:31 +08:00
|
|
|
// SetParseMode sets the parse mode for the message body.
|
|
|
|
// For more information about telegram constants:
|
|
|
|
// -> https://pkg.go.dev/github.com/go-telegram-bot-api/telegram-bot-api#pkg-constants
|
|
|
|
func (t *Telegram) SetParseMode(mode string) {
|
|
|
|
parseMode = mode
|
|
|
|
}
|
|
|
|
|
2021-01-25 05:05:28 +01:00
|
|
|
// AddReceivers takes Telegram chat IDs and adds them to the internal chat ID list. The Send method will send
|
|
|
|
// a given message to all those chats.
|
2021-02-10 15:11:32 +01:00
|
|
|
func (t *Telegram) AddReceivers(chatIDs ...int64) {
|
|
|
|
t.chatIDs = append(t.chatIDs, chatIDs...)
|
2021-01-25 00:14:21 +01:00
|
|
|
}
|
|
|
|
|
2021-01-25 05:05:28 +01:00
|
|
|
// Send takes a message subject and a message body and sends them to all previously set chats. Message body supports
|
|
|
|
// html as markup language.
|
2021-02-18 03:33:30 +01:00
|
|
|
func (t Telegram) Send(ctx context.Context, subject, message string) error {
|
2021-01-25 00:14:21 +01:00
|
|
|
fullMessage := subject + "\n" + message // Treating subject as message title
|
|
|
|
|
|
|
|
msg := tgbotapi.NewMessage(0, fullMessage)
|
2022-06-06 17:41:31 +08:00
|
|
|
msg.ParseMode = parseMode
|
2021-01-25 00:14:21 +01:00
|
|
|
|
|
|
|
for _, chatID := range t.chatIDs {
|
2021-02-18 03:33:30 +01:00
|
|
|
select {
|
|
|
|
case <-ctx.Done():
|
2021-02-22 23:56:28 +01:00
|
|
|
return ctx.Err()
|
2021-02-18 03:33:30 +01:00
|
|
|
default:
|
|
|
|
msg.ChatID = chatID
|
|
|
|
_, err := t.client.Send(msg)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrapf(err, "failed to send message to Telegram chat '%d'", chatID)
|
|
|
|
}
|
2021-01-25 00:14:21 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|