diff options
author | Yulqen <246857+yulqen@users.noreply.github.com> | 2024-04-18 13:58:11 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-04-18 13:58:11 +0100 |
commit | 69017cc225e2754466b8444ca42cb1122208425d (patch) | |
tree | 6a7ac8d150b95c1fad9229d124a23737abc17964 /cmd/web/helpers.go | |
parent | 530f08071fc1295fabdaedf9724b8cda48780927 (diff) | |
parent | f08ac7b887e0bae0cb67362eec90a575faec07f1 (diff) |
Merge pull request #4 from defencedigital/changes
Changes
Diffstat (limited to 'cmd/web/helpers.go')
-rw-r--r-- | cmd/web/helpers.go | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/cmd/web/helpers.go b/cmd/web/helpers.go new file mode 100644 index 0000000..fc9b8f8 --- /dev/null +++ b/cmd/web/helpers.go @@ -0,0 +1,52 @@ +package main + +import ( + "fmt" + "log" + "net/http" + "runtime/debug" +) + +func (app *application) serverError(w http.ResponseWriter, r *http.Request, err error) { + var ( + method = r.Method + uri = r.URL.RequestURI() + trace = string(debug.Stack()) + ) + + app.logger.Error(err.Error(), "method", method, "uri", uri, "trace", trace) + log.Printf("Crash! %s %s %s", method, uri, trace) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) +} + +// The clientError helper sends a specific status code and corresponding description +// to the user. We'll use this later in the book to send responses like 400 "Bad +// Request" when there's a problem with the request that the user sent. +func (app *application) clientError(w http.ResponseWriter, status int) { + http.Error(w, http.StatusText(status), status) +} + +// notFound helper is a convenience wrapper around clientError which sends a 404 Not Found response +func (app *application) notFound(w http.ResponseWriter) { + app.clientError(w, http.StatusNotFound) +} + +func (app *application) render(w http.ResponseWriter, r *http.Request, status int, page string, data templateData) { + // retrieve the appropriate template set from the cache based on the page name. + // If no entry exists in the cache with the provided name, create a new error + // and call serverError() helper that we made earlier and return. + ts, ok := app.templateCache[page] + if !ok { + err := fmt.Errorf("the template %s does not exist", page) + app.serverError(w, r, err) + return + } + + // Write out the provided HTTP status code('200 OK', '400 Bad Request', etc). + w.WriteHeader(status) + + err := ts.ExecuteTemplate(w, "base", data) + if err != nil { + app.serverError(w, r, err) + } +} |