diff options
| author | nsfisis <nsfisis@gmail.com> | 2025-11-29 16:59:33 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2025-12-04 23:27:25 +0900 |
| commit | aac4e9ccdebe52c156506d1899d5a38e99366f69 (patch) | |
| tree | acef83d9b4b58a85b60a3fe8817ae17c0773214f /backend/auth | |
| parent | e8d43fd90725fbf715c7e1517aa7ce51c9465784 (diff) | |
| download | feedaka-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.go | 24 |
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) + } + } +} |
