2020-09-19 22:29:08 +02:00
|
|
|
package twilio
|
2020-09-19 22:22:12 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/base64"
|
|
|
|
"fmt"
|
2020-11-23 22:20:06 +01:00
|
|
|
"net/http"
|
|
|
|
"net/url"
|
|
|
|
|
2021-10-04 03:53:59 +02:00
|
|
|
"github.com/TwinProduction/gatus/v3/alerting/alert"
|
|
|
|
"github.com/TwinProduction/gatus/v3/alerting/provider/custom"
|
|
|
|
"github.com/TwinProduction/gatus/v3/core"
|
2020-09-19 22:22:12 +02:00
|
|
|
)
|
|
|
|
|
2020-09-26 21:15:50 +02:00
|
|
|
// AlertProvider is the configuration necessary for sending an alert using Twilio
|
2020-09-19 22:29:08 +02:00
|
|
|
type AlertProvider struct {
|
2020-09-19 22:22:12 +02:00
|
|
|
SID string `yaml:"sid"`
|
|
|
|
Token string `yaml:"token"`
|
|
|
|
From string `yaml:"from"`
|
|
|
|
To string `yaml:"to"`
|
2021-05-16 03:31:32 +02:00
|
|
|
|
|
|
|
// DefaultAlert is the default alert configuration to use for services with an alert of the appropriate type
|
2021-05-19 04:29:15 +02:00
|
|
|
DefaultAlert *alert.Alert `yaml:"default-alert"`
|
2020-09-19 22:22:12 +02:00
|
|
|
}
|
|
|
|
|
2020-09-26 21:15:50 +02:00
|
|
|
// IsValid returns whether the provider's configuration is valid
|
2020-09-19 22:29:08 +02:00
|
|
|
func (provider *AlertProvider) IsValid() bool {
|
2020-09-19 22:22:12 +02:00
|
|
|
return len(provider.Token) > 0 && len(provider.SID) > 0 && len(provider.From) > 0 && len(provider.To) > 0
|
|
|
|
}
|
|
|
|
|
2020-09-26 21:15:50 +02:00
|
|
|
// ToCustomAlertProvider converts the provider into a custom.AlertProvider
|
2021-05-19 04:29:15 +02:00
|
|
|
func (provider *AlertProvider) ToCustomAlertProvider(service *core.Service, alert *alert.Alert, _ *core.Result, resolved bool) *custom.AlertProvider {
|
2020-09-26 20:23:43 +02:00
|
|
|
var message string
|
|
|
|
if resolved {
|
2021-05-16 03:31:32 +02:00
|
|
|
message = fmt.Sprintf("RESOLVED: %s - %s", service.Name, alert.GetDescription())
|
2020-09-26 20:23:43 +02:00
|
|
|
} else {
|
2021-05-16 03:31:32 +02:00
|
|
|
message = fmt.Sprintf("TRIGGERED: %s - %s", service.Name, alert.GetDescription())
|
2020-09-26 20:23:43 +02:00
|
|
|
}
|
2020-09-19 22:29:08 +02:00
|
|
|
return &custom.AlertProvider{
|
2020-10-23 22:29:20 +02:00
|
|
|
URL: fmt.Sprintf("https://api.twilio.com/2010-04-01/Accounts/%s/Messages.json", provider.SID),
|
2020-11-23 22:20:06 +01:00
|
|
|
Method: http.MethodPost,
|
2020-09-19 22:22:12 +02:00
|
|
|
Body: url.Values{
|
|
|
|
"To": {provider.To},
|
|
|
|
"From": {provider.From},
|
|
|
|
"Body": {message},
|
|
|
|
}.Encode(),
|
|
|
|
Headers: map[string]string{
|
|
|
|
"Content-Type": "application/x-www-form-urlencoded",
|
|
|
|
"Authorization": fmt.Sprintf("Basic %s", base64.StdEncoding.EncodeToString([]byte(fmt.Sprintf("%s:%s", provider.SID, provider.Token)))),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
2021-05-16 03:31:32 +02:00
|
|
|
|
|
|
|
// GetDefaultAlert returns the provider's default alert configuration
|
2021-05-19 04:29:15 +02:00
|
|
|
func (provider AlertProvider) GetDefaultAlert() *alert.Alert {
|
2021-05-16 03:31:32 +02:00
|
|
|
return provider.DefaultAlert
|
|
|
|
}
|