all repos — website @ f8bf946b090aa4fb0b8beb4ad09c1f06078f0b5b

My website

make error pages dynamic
Alan Pearce alan@alanpearce.eu
Wed, 26 Jun 2024 11:20:15 +0200
commit

f8bf946b090aa4fb0b8beb4ad09c1f06078f0b5b

parent

56ac09928f9aea7a25577e9da716afcd09d2d6b8

M internal/builder/builder.gointernal/builder/builder.go
@@ -235,11 +235,6 @@ sitemap.AddPath("/", time.Time{}) 	h, _ = getHTMLStyleHash(publicDir, "index.html")
 	r.Hashes = append(r.Hashes, h)
 
-	log.Debug("rendering 404 page")
-	if err := renderToFile(templates.NotFound(config, "/404.html"), privateDir, "404.html"); err != nil {
-		return nil, err
-	}
-
 	log.Debug("rendering sitemap")
 	if err := writerToFile(sitemap, publicDir, "sitemap.xml"); err != nil {
 		return nil, err
A internal/http/error.go
@@ -0,0 +1,7 @@+package http
+
+type Error struct {
+	Error   error
+	Message string
+	Code    int
+}
M internal/website/mux.gointernal/website/mux.go
@@ -6,6 +6,7 @@ "net/http" 	"path"
 	"strings"
 	"website/internal/config"
+	ihttp "website/internal/http"
 	"website/internal/log"
 	"website/templates"
 
@@ -14,12 +15,6 @@ "github.com/kevinpollet/nego" 	"github.com/pkg/errors"
 )
 
-type HTTPError struct {
-	Error   error
-	Message string
-	Code    int
-}
-
 func canonicalisePath(path string) (cPath string, differs bool) {
 	cPath = path
 	if strings.HasSuffix(path, "/index.html") {
@@ -31,7 +26,7 @@ 	return cPath, differs
 }
 
-type webHandler func(http.ResponseWriter, *http.Request) *HTTPError
+type webHandler func(http.ResponseWriter, *http.Request) *ihttp.Error
 
 type WrappedWebHandler struct {
 	config  *config.Config
@@ -55,7 +50,7 @@ }() 	if err := fn.handler(w, r); err != nil {
 		if strings.Contains(r.Header.Get("Accept"), "text/html") {
 			w.WriteHeader(err.Code)
-			err := templates.NotFound(*fn.config, r.URL.Path).Render(r.Context(), w)
+			err := templates.Error(*fn.config, r.URL.Path, err).Render(r.Context(), w)
 			if err != nil {
 				http.Error(w, err.Error(), http.StatusInternalServerError)
 			}
@@ -76,7 +71,7 @@ return nil, errors.WithMessagef(err, "registering content files") 	}
 	templates.Setup()
 
-	mux.Handle("/", wrapHandler(cfg, func(w http.ResponseWriter, r *http.Request) *HTTPError {
+	mux.Handle("/", wrapHandler(cfg, func(w http.ResponseWriter, r *http.Request) *ihttp.Error {
 		urlPath, shouldRedirect := canonicalisePath(r.URL.Path)
 		if shouldRedirect {
 			http.Redirect(w, r, urlPath, 302)
@@ -85,7 +80,7 @@ return nil 		}
 		file := GetFile(urlPath)
 		if file == nil {
-			return &HTTPError{
+			return &ihttp.Error{
 				Message: "File not found",
 				Code:    http.StatusNotFound,
 			}
D templates/404.templ
@@ -1,13 +0,0 @@-package templates
-
-import "website/internal/config"
-
-templ NotFound(config config.Config, path string) {
-	@Page(config, PageSettings{
-		Title: "Not Found",
-		Path:  path,
-	}) {
-		<h1>404</h1>
-		<h2>ʕノ•ᴥ•ʔノ ︵ ┻━┻</h2>
-	}
-}
A templates/error.templ
@@ -0,0 +1,17 @@+package templates
+
+import (
+	"website/internal/config"
+	"website/internal/http"
+	"strconv"
+)
+
+templ Error(config config.Config, path string, err *http.Error) {
+	@Page(config, PageSettings{
+		Title: "Error",
+		Path:  path,
+	}) {
+		<h1>{ strconv.Itoa(err.Code) } { err.Message }</h1>
+		<h2>ʕノ•ᴥ•ʔノ ︵ ┻━┻</h2>
+	}
+}