move middleware
This commit is contained in:
parent
8f8e83a0d7
commit
608f7c36e7
27
cmd/main.go
27
cmd/main.go
@ -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,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
23
internal/middleware/logging.go
Normal file
23
internal/middleware/logging.go
Normal 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)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user