1
0
mirror of https://github.com/nikoksr/notify.git synced 2025-01-24 03:16:35 +02:00
notify/service/slack/slack.go

60 lines
1.5 KiB
Go
Raw Normal View History

2021-01-26 22:30:13 +00:00
package slack
2021-01-26 22:25:16 +00:00
import (
"context"
2021-01-26 22:25:16 +00:00
"github.com/pkg/errors"
"github.com/slack-go/slack"
)
// Slack struct holds necessary data to communicate with the Slack API.
type Slack struct {
client *slack.Client
channelIDs []string
}
// New returns a new instance of a Slack notification service.
// For more information about slack api token:
// -> https://pkg.go.dev/github.com/slack-go/slack#New
func New(apiToken string) *Slack {
2021-01-26 22:25:16 +00:00
client := slack.New(apiToken)
s := &Slack{
client: client,
channelIDs: []string{},
}
return s
2021-01-26 22:25:16 +00:00
}
// AddReceivers takes Slack channel IDs and adds them to the internal channel ID list. The Send method will send
// a given message to all those channels.
func (s *Slack) AddReceivers(channelIDs ...string) {
s.channelIDs = append(s.channelIDs, channelIDs...)
}
// Send takes a message subject and a message body and sends them to all previously set channels.
2021-01-26 22:49:15 +00:00
// you will need a slack app with the chat:write.public and chat:write permissions.
2021-01-26 22:50:42 +00:00
// see https://api.slack.com/
func (s Slack) Send(ctx context.Context, subject, message string) error {
2021-01-26 22:25:16 +00:00
fullMessage := subject + "\n" + message // Treating subject as message title
for _, channelID := range s.channelIDs {
select {
case <-ctx.Done():
return ctx.Err()
default:
id, timestamp, err := s.client.PostMessageContext(
ctx,
channelID,
slack.MsgOptionText(fullMessage, false),
)
if err != nil {
return errors.Wrapf(err, "failed to send message to Slack channel '%s' at time '%s'", id, timestamp)
}
2021-01-26 22:25:16 +00:00
}
}
return nil
}