move middleware

This commit is contained in:
Michael Thomson 2025-02-10 10:18:01 -05:00
parent 8f8e83a0d7
commit 608f7c36e7
No known key found for this signature in database
GPG Key ID: 8EFECCD347C72F7D
2 changed files with 34 additions and 16 deletions

View File

@ -2,30 +2,25 @@ package main
import ( import (
"database/sql" "database/sql"
"fmt"
"log" "log"
"log/slog" "log/slog"
"net/http" "net/http"
"os" "os"
"gitea.michaelthomson.dev/mthomson/habits/internal/middleware"
"gitea.michaelthomson.dev/mthomson/habits/internal/migrate" "gitea.michaelthomson.dev/mthomson/habits/internal/migrate"
todohandler "gitea.michaelthomson.dev/mthomson/habits/internal/todo/handler" todohandler "gitea.michaelthomson.dev/mthomson/habits/internal/todo/handler"
todosqliterepository "gitea.michaelthomson.dev/mthomson/habits/internal/todo/repository/sqlite" todorepository "gitea.michaelthomson.dev/mthomson/habits/internal/todo/repository/sqlite"
todoservice "gitea.michaelthomson.dev/mthomson/habits/internal/todo/service" todoservice "gitea.michaelthomson.dev/mthomson/habits/internal/todo/service"
_ "github.com/mattn/go-sqlite3" _ "github.com/mattn/go-sqlite3"
) )
func loggingMiddleware(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
slog.Info(fmt.Sprintf("[%s] %s", r.Method, r.URL))
next.ServeHTTP(w, r)
})
}
func main() { func main() {
// create logger // create logger
logger := slog.New(slog.NewTextHandler(os.Stdout, nil)) httpLogger := slog.New(slog.NewTextHandler(os.Stdout, nil))
slog.SetDefault(logger)
// create middlewares
loggingMiddleware := middleware.LoggingMiddleware(httpLogger)
// create db pool // create db pool
db, err := sql.Open("sqlite3", "./habits.db") db, err := sql.Open("sqlite3", "./habits.db")
@ -39,7 +34,7 @@ func main() {
migrate.Migrate(db) migrate.Migrate(db)
// create repos // create repos
todoRepository := todosqliterepository.NewSqliteTodoRepository(db) todoRepository := todorepository.NewSqliteTodoRepository(db)
// create services // create services
todoService := todoservice.NewTodoService(todoRepository) todoService := todoservice.NewTodoService(todoRepository)
@ -49,13 +44,13 @@ func main() {
// register handlers // register handlers
mux.Handle("GET /todo/{id}", loggingMiddleware(todohandler.HandleTodoGet(todoService))) mux.Handle("GET /todo/{id}", loggingMiddleware(todohandler.HandleTodoGet(todoService)))
mux.Handle("POST /todo", todohandler.HandleTodoCreate(todoService)) mux.Handle("POST /todo", loggingMiddleware(todohandler.HandleTodoCreate(todoService)))
mux.Handle("DELETE /todo/{id}", todohandler.HandleTodoDelete(todoService)) mux.Handle("DELETE /todo/{id}", loggingMiddleware(todohandler.HandleTodoDelete(todoService)))
mux.Handle("PUT /todo/{id}", todohandler.HandleTodoUpdate(todoService)) mux.Handle("PUT /todo/{id}", loggingMiddleware(todohandler.HandleTodoUpdate(todoService)))
// create server // create server
server := &http.Server{ server := &http.Server{
Addr: ":8080", Addr: ":8080",
Handler: mux, Handler: mux,
} }

View File

@ -0,0 +1,23 @@
package middleware
import (
"context"
"log/slog"
"net/http"
)
func LoggingMiddleware(logger *slog.Logger) func(http.Handler) http.Handler {
return func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
logger.LogAttrs(
context.Background(),
slog.LevelInfo,
"Incoming request",
slog.String("method", r.Method),
slog.String("path", r.URL.String()),
)
next.ServeHTTP(w, r)
})
}
}