2024-04-09 03:00:40 +02:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/TwiN/gatus/v5/config"
|
2024-05-10 04:56:16 +02:00
|
|
|
"github.com/TwiN/gatus/v5/config/endpoint"
|
2024-04-09 03:00:40 +02:00
|
|
|
"github.com/TwiN/gatus/v5/storage/store"
|
|
|
|
"github.com/TwiN/gatus/v5/storage/store/common"
|
|
|
|
"github.com/TwiN/gatus/v5/watchdog"
|
2024-11-14 05:54:00 +01:00
|
|
|
"github.com/TwiN/logr"
|
2024-04-09 03:00:40 +02:00
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
func CreateExternalEndpointResult(cfg *config.Config) fiber.Handler {
|
|
|
|
return func(c *fiber.Ctx) error {
|
|
|
|
// Check if the success query parameter is present
|
|
|
|
success, exists := c.Queries()["success"]
|
|
|
|
if !exists || (success != "true" && success != "false") {
|
|
|
|
return c.Status(400).SendString("missing or invalid success query parameter")
|
|
|
|
}
|
|
|
|
// Check if the authorization bearer token header is correct
|
|
|
|
authorizationHeader := string(c.Request().Header.Peek("Authorization"))
|
|
|
|
if !strings.HasPrefix(authorizationHeader, "Bearer ") {
|
|
|
|
return c.Status(401).SendString("invalid Authorization header")
|
|
|
|
}
|
|
|
|
token := strings.TrimSpace(strings.TrimPrefix(authorizationHeader, "Bearer "))
|
|
|
|
if len(token) == 0 {
|
|
|
|
return c.Status(401).SendString("bearer token must not be empty")
|
|
|
|
}
|
|
|
|
key := c.Params("key")
|
|
|
|
externalEndpoint := cfg.GetExternalEndpointByKey(key)
|
|
|
|
if externalEndpoint == nil {
|
2024-11-14 05:54:00 +01:00
|
|
|
logr.Errorf("[api.CreateExternalEndpointResult] External endpoint with key=%s not found", key)
|
2024-04-09 03:00:40 +02:00
|
|
|
return c.Status(404).SendString("not found")
|
|
|
|
}
|
|
|
|
if externalEndpoint.Token != token {
|
2024-11-14 05:54:00 +01:00
|
|
|
logr.Errorf("[api.CreateExternalEndpointResult] Invalid token for external endpoint with key=%s", key)
|
2024-04-09 03:00:40 +02:00
|
|
|
return c.Status(401).SendString("invalid token")
|
|
|
|
}
|
|
|
|
// Persist the result in the storage
|
2024-05-10 04:56:16 +02:00
|
|
|
result := &endpoint.Result{
|
2024-04-09 03:00:40 +02:00
|
|
|
Timestamp: time.Now(),
|
|
|
|
Success: c.QueryBool("success"),
|
|
|
|
Errors: []string{},
|
|
|
|
}
|
2024-09-18 04:26:21 +02:00
|
|
|
if !result.Success && c.Query("error") != "" {
|
|
|
|
result.Errors = append(result.Errors, c.Query("error"))
|
|
|
|
}
|
2024-04-09 03:00:40 +02:00
|
|
|
convertedEndpoint := externalEndpoint.ToEndpoint()
|
|
|
|
if err := store.Get().Insert(convertedEndpoint, result); err != nil {
|
|
|
|
if errors.Is(err, common.ErrEndpointNotFound) {
|
|
|
|
return c.Status(404).SendString(err.Error())
|
|
|
|
}
|
2024-11-14 05:54:00 +01:00
|
|
|
logr.Errorf("[api.CreateExternalEndpointResult] Failed to insert result in storage: %s", err.Error())
|
2024-04-09 03:00:40 +02:00
|
|
|
return c.Status(500).SendString(err.Error())
|
|
|
|
}
|
2024-11-14 05:54:00 +01:00
|
|
|
logr.Infof("[api.CreateExternalEndpointResult] Successfully inserted result for external endpoint with key=%s and success=%s", c.Params("key"), success)
|
2024-04-09 03:00:40 +02:00
|
|
|
// Check if an alert should be triggered or resolved
|
|
|
|
if !cfg.Maintenance.IsUnderMaintenance() {
|
2024-11-14 05:54:00 +01:00
|
|
|
watchdog.HandleAlerting(convertedEndpoint, result, cfg.Alerting)
|
2024-04-09 03:00:40 +02:00
|
|
|
externalEndpoint.NumberOfSuccessesInARow = convertedEndpoint.NumberOfSuccessesInARow
|
|
|
|
externalEndpoint.NumberOfFailuresInARow = convertedEndpoint.NumberOfFailuresInARow
|
|
|
|
}
|
|
|
|
// Return the result
|
|
|
|
return c.Status(200).SendString("")
|
|
|
|
}
|
|
|
|
}
|