2021-12-14 08:13:53 -08:00
|
|
|
package routes
|
2021-12-03 03:11:01 -08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2022-11-02 16:23:26 -07:00
|
|
|
"github.com/mikestefanello/pagoda/pkg/context"
|
|
|
|
"github.com/mikestefanello/pagoda/pkg/controller"
|
2023-12-16 08:07:20 -08:00
|
|
|
"github.com/mikestefanello/pagoda/templates"
|
2021-12-12 19:09:13 -08:00
|
|
|
|
2021-12-03 03:11:01 -08:00
|
|
|
"github.com/labstack/echo/v4"
|
|
|
|
)
|
|
|
|
|
2022-02-10 05:56:07 -08:00
|
|
|
type errorHandler struct {
|
2021-12-12 19:09:13 -08:00
|
|
|
controller.Controller
|
2021-12-03 03:11:01 -08:00
|
|
|
}
|
|
|
|
|
2022-02-10 05:56:07 -08:00
|
|
|
func (e *errorHandler) Get(err error, ctx echo.Context) {
|
2022-01-08 21:23:26 -08:00
|
|
|
if ctx.Response().Committed || context.IsCanceledError(err) {
|
2021-12-11 16:32:27 -08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-12-03 03:11:01 -08:00
|
|
|
code := http.StatusInternalServerError
|
|
|
|
if he, ok := err.(*echo.HTTPError); ok {
|
|
|
|
code = he.Code
|
|
|
|
}
|
|
|
|
|
|
|
|
if code >= 500 {
|
2022-01-08 21:23:26 -08:00
|
|
|
ctx.Logger().Error(err)
|
2021-12-03 03:11:01 -08:00
|
|
|
} else {
|
2022-01-08 21:23:26 -08:00
|
|
|
ctx.Logger().Info(err)
|
2021-12-03 03:11:01 -08:00
|
|
|
}
|
|
|
|
|
2022-01-08 21:23:26 -08:00
|
|
|
page := controller.NewPage(ctx)
|
|
|
|
page.Title = http.StatusText(code)
|
2023-12-16 08:07:20 -08:00
|
|
|
page.Layout = templates.LayoutMain
|
|
|
|
page.Name = templates.PageError
|
2022-01-08 21:23:26 -08:00
|
|
|
page.StatusCode = code
|
|
|
|
page.HTMX.Request.Enabled = false
|
2021-12-03 03:11:01 -08:00
|
|
|
|
2022-01-08 21:23:26 -08:00
|
|
|
if err = e.RenderPage(ctx, page); err != nil {
|
|
|
|
ctx.Logger().Error(err)
|
2021-12-03 03:11:01 -08:00
|
|
|
}
|
|
|
|
}
|