2021-01-29 19:50:19 +01:00
|
|
|
package msteams
|
2021-01-29 19:25:38 +01:00
|
|
|
|
|
|
|
import (
|
2021-02-18 03:33:30 +01:00
|
|
|
"context"
|
|
|
|
|
2022-09-12 08:42:38 +02:00
|
|
|
teams "github.com/atc0005/go-teams-notify/v2"
|
2021-01-29 19:25:38 +01:00
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
// MSTeams struct holds necessary data to communicate with the MSTeams API.
|
|
|
|
type MSTeams struct {
|
|
|
|
client goteamsnotify.API
|
|
|
|
webHooks []string
|
|
|
|
}
|
|
|
|
|
|
|
|
// New returns a new instance of a MSTeams notification service.
|
|
|
|
// For more information about telegram api token:
|
2022-08-04 15:58:38 +02:00
|
|
|
//
|
|
|
|
// -> https://github.com/atc0005/go-teams-notify#example-basic
|
2021-01-31 03:49:50 +01:00
|
|
|
func New() *MSTeams {
|
2022-09-12 08:42:38 +02:00
|
|
|
client := teams.NewClient()
|
2021-01-29 19:25:38 +01:00
|
|
|
|
|
|
|
m := &MSTeams{
|
|
|
|
client: client,
|
|
|
|
webHooks: []string{},
|
|
|
|
}
|
|
|
|
|
2021-01-31 01:18:22 +01:00
|
|
|
return m
|
2021-01-29 19:25:38 +01:00
|
|
|
}
|
|
|
|
|
2021-01-29 19:44:45 +01:00
|
|
|
// DisableWebhookValidation disables the validation of webhook URLs, including the validation of known prefixes so that
|
2021-01-29 19:25:38 +01:00
|
|
|
// custom/private webhook URL endpoints can be used (e.g., testing purposes).
|
|
|
|
// For more information about telegram api token:
|
2022-08-04 15:58:38 +02:00
|
|
|
//
|
|
|
|
// -> https://github.com/atc0005/go-teams-notify#example-disable-webhook-url-prefix-validation
|
2021-01-29 19:25:38 +01:00
|
|
|
func (m *MSTeams) DisableWebhookValidation() {
|
|
|
|
m.client.SkipWebhookURLValidationOnSend(true)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddReceivers takes MSTeams channel web-hooks and adds them to the internal web-hook list. The Send method will send
|
|
|
|
// a given message to all those chats.
|
|
|
|
func (m *MSTeams) AddReceivers(webHooks ...string) {
|
|
|
|
m.webHooks = append(m.webHooks, webHooks...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Send accepts a subject and a message body and sends them to all previously specified channels. Message body supports
|
|
|
|
// html as markup language.
|
|
|
|
// For more information about telegram api token:
|
2022-08-04 15:58:38 +02:00
|
|
|
//
|
|
|
|
// -> https://github.com/atc0005/go-teams-notify#example-basic
|
2021-02-18 03:33:30 +01:00
|
|
|
func (m MSTeams) Send(ctx context.Context, subject, message string) error {
|
2022-09-12 08:42:38 +02:00
|
|
|
msgCard := teams.NewMessageCard()
|
2021-01-29 19:25:38 +01:00
|
|
|
msgCard.Title = subject
|
|
|
|
msgCard.Text = message
|
|
|
|
|
|
|
|
for _, webHook := range m.webHooks {
|
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:
|
|
|
|
err := m.client.SendWithContext(ctx, webHook, msgCard)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrapf(err, "failed to send message to Microsoft Teams via webhook '%s'", webHook)
|
|
|
|
}
|
2021-01-29 19:25:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|