aboutsummaryrefslogtreecommitdiffhomepage
path: root/server.go
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-02-10 20:23:02 +0900
committernsfisis <nsfisis@gmail.com>2026-02-10 20:23:02 +0900
commit6a7d9329d11b9a206f8baa61e8c573f7fb58122d (patch)
tree41c71a724aced503ebe6e46005cf3aae981400a9 /server.go
parentef17d9d888c6034a6db66a5e2f59f039a0d86b1c (diff)
downloadnilink-6a7d9329d11b9a206f8baa61e8c573f7fb58122d.tar.gz
nilink-6a7d9329d11b9a206f8baa61e8c573f7fb58122d.tar.zst
nilink-6a7d9329d11b9a206f8baa61e8c573f7fb58122d.zip
set up logging
Diffstat (limited to 'server.go')
-rw-r--r--server.go31
1 files changed, 29 insertions, 2 deletions
diff --git a/server.go b/server.go
index 12578a4..6a313b7 100644
--- a/server.go
+++ b/server.go
@@ -4,9 +4,11 @@ import (
"database/sql"
"flag"
"fmt"
+ "log/slog"
"net/http"
"os"
"strings"
+ "time"
)
func newMux(db *sql.DB) http.Handler {
@@ -37,7 +39,32 @@ func newMux(db *sql.DB) http.Handler {
}
http.Redirect(w, r, url, http.StatusMovedPermanently)
})
- return mux
+ return withLogging(mux)
+}
+
+type responseWriter struct {
+ http.ResponseWriter
+ status int
+}
+
+func (w *responseWriter) WriteHeader(code int) {
+ w.status = code
+ w.ResponseWriter.WriteHeader(code)
+}
+
+func withLogging(next http.Handler) http.Handler {
+ return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
+ start := time.Now()
+ rw := &responseWriter{ResponseWriter: w, status: http.StatusOK}
+ next.ServeHTTP(rw, r)
+ slog.Info("request",
+ "method", r.Method,
+ "path", r.URL.Path,
+ "status", rw.status,
+ "duration", time.Since(start),
+ "remote", r.RemoteAddr,
+ )
+ })
}
func cmdServe(args []string) {
@@ -53,7 +80,7 @@ func cmdServe(args []string) {
}
defer db.Close()
- fmt.Fprintf(os.Stderr, "listening on %s\n", *addr)
+ slog.Info("listening", "addr", *addr)
if err := http.ListenAndServe(*addr, newMux(db)); err != nil {
fmt.Fprintf(os.Stderr, "error: %v\n", err)
os.Exit(1)