mirror of
https://github.com/TwiN/gatus.git
synced 2024-12-22 14:41:01 +01:00
01131755bc
* fix(logging): Replace log-level parameter by GATUS_LOG_LEVEL env var * Improve log message if GATUS_LOG_LEVEL isn't set
31 lines
1.3 KiB
Go
31 lines
1.3 KiB
Go
package api
|
|
|
|
import (
|
|
_ "embed"
|
|
"html/template"
|
|
|
|
"github.com/TwiN/gatus/v5/config/ui"
|
|
static "github.com/TwiN/gatus/v5/web"
|
|
"github.com/TwiN/logr"
|
|
"github.com/gofiber/fiber/v2"
|
|
)
|
|
|
|
func SinglePageApplication(ui *ui.Config) fiber.Handler {
|
|
return func(c *fiber.Ctx) error {
|
|
t, err := template.ParseFS(static.FileSystem, static.IndexPath)
|
|
if err != nil {
|
|
// This should never happen, because ui.ValidateAndSetDefaults validates that the template works.
|
|
logr.Errorf("[api.SinglePageApplication] Failed to parse template. This should never happen, because the template is validated on start. Error: %s", err.Error())
|
|
return c.Status(500).SendString("Failed to parse template. This should never happen, because the template is validated on start.")
|
|
}
|
|
c.Set("Content-Type", "text/html")
|
|
err = t.Execute(c, ui)
|
|
if err != nil {
|
|
// This should never happen, because ui.ValidateAndSetDefaults validates that the template works.
|
|
logr.Errorf("[api.SinglePageApplication] Failed to execute template. This should never happen, because the template is validated on start. Error: %s", err.Error())
|
|
return c.Status(500).SendString("Failed to parse template. This should never happen, because the template is validated on start.")
|
|
}
|
|
return c.SendStatus(200)
|
|
}
|
|
}
|