aboutsummaryrefslogtreecommitdiffhomepage
path: root/backend/auth
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-11-29 16:59:33 +0900
committernsfisis <nsfisis@gmail.com>2025-12-04 23:27:25 +0900
commitaac4e9ccdebe52c156506d1899d5a38e99366f69 (patch)
treeacef83d9b4b58a85b60a3fe8817ae17c0773214f /backend/auth
parente8d43fd90725fbf715c7e1517aa7ce51c9465784 (diff)
downloadfeedaka-aac4e9ccdebe52c156506d1899d5a38e99366f69.tar.gz
feedaka-aac4e9ccdebe52c156506d1899d5a38e99366f69.tar.zst
feedaka-aac4e9ccdebe52c156506d1899d5a38e99366f69.zip
refactor(backend): move middleware.go to auth package
Diffstat (limited to 'backend/auth')
-rw-r--r--backend/auth/middleware.go24
1 files changed, 24 insertions, 0 deletions
diff --git a/backend/auth/middleware.go b/backend/auth/middleware.go
new file mode 100644
index 0000000..aca1648
--- /dev/null
+++ b/backend/auth/middleware.go
@@ -0,0 +1,24 @@
+package auth
+
+import (
+ "github.com/labstack/echo/v4"
+ appcontext "undef.ninja/x/feedaka/context"
+)
+
+// SessionAuthMiddleware validates session and adds user info to context
+func SessionAuthMiddleware(sessionConfig *SessionConfig) echo.MiddlewareFunc {
+ return func(next echo.HandlerFunc) echo.HandlerFunc {
+ return func(c echo.Context) error {
+ // Try to get user ID from session
+ userID, err := sessionConfig.GetUserID(c)
+ if err == nil {
+ // Add user ID to context
+ ctx := appcontext.SetUserID(c.Request().Context(), userID)
+ c.SetRequest(c.Request().WithContext(ctx))
+ }
+ // If no valid session, continue without authentication
+
+ return next(c)
+ }
+ }
+}