2022-01-06 09:00:24 +01:00
|
|
|
package twilio
|
|
|
|
|
|
|
|
import (
|
2022-06-13 08:34:11 +02:00
|
|
|
"github.com/kevinburke/twilio-go"
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/logging"
|
2022-06-13 08:34:11 +02:00
|
|
|
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/zitadel/internal/notification/channels"
|
|
|
|
"github.com/zitadel/zitadel/internal/notification/messages"
|
2023-12-08 16:30:55 +02:00
|
|
|
"github.com/zitadel/zitadel/internal/zerrors"
|
2022-01-06 09:00:24 +01:00
|
|
|
)
|
|
|
|
|
2023-03-29 00:09:06 +02:00
|
|
|
func InitChannel(config Config) channels.NotificationChannel {
|
2022-01-06 09:00:24 +01:00
|
|
|
client := twilio.NewClient(config.SID, config.Token, nil)
|
|
|
|
|
2022-06-13 08:34:11 +02:00
|
|
|
logging.Debug("successfully initialized twilio sms channel")
|
2022-01-06 09:00:24 +01:00
|
|
|
|
|
|
|
return channels.HandleMessageFunc(func(message channels.Message) error {
|
|
|
|
twilioMsg, ok := message.(*messages.SMS)
|
|
|
|
if !ok {
|
2023-12-08 16:30:55 +02:00
|
|
|
return zerrors.ThrowInternal(nil, "TWILI-s0pLc", "message is not SMS")
|
2022-01-06 09:00:24 +01:00
|
|
|
}
|
2023-03-29 00:09:06 +02:00
|
|
|
content, err := twilioMsg.GetContent()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
m, err := client.Messages.SendMessage(twilioMsg.SenderPhoneNumber, twilioMsg.RecipientPhoneNumber, content, nil)
|
2022-01-06 09:00:24 +01:00
|
|
|
if err != nil {
|
2023-12-08 16:30:55 +02:00
|
|
|
return zerrors.ThrowInternal(err, "TWILI-osk3S", "could not send message")
|
2022-01-06 09:00:24 +01:00
|
|
|
}
|
2022-06-13 08:34:11 +02:00
|
|
|
logging.WithFields("message_sid", m.Sid, "status", m.Status).Debug("sms sent")
|
2022-01-06 09:00:24 +01:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
}
|