Files
MonkeyCode/backend/internal/middleware/auth.go
2025-07-21 18:47:39 +08:00

74 lines
1.6 KiB
Go

package middleware
import (
"log/slog"
"net/http"
"github.com/labstack/echo/v4"
"github.com/chaitin/MonkeyCode/backend/consts"
"github.com/chaitin/MonkeyCode/backend/domain"
"github.com/chaitin/MonkeyCode/backend/pkg/session"
)
const (
adminKey = "session:admin"
userKey = "session:user"
)
type AuthMiddleware struct {
session *session.Session
logger *slog.Logger
}
func NewAuthMiddleware(session *session.Session, logger *slog.Logger) *AuthMiddleware {
return &AuthMiddleware{
session: session,
logger: logger,
}
}
func (m *AuthMiddleware) UserAuth() echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
user, err := session.Get[domain.User](m.session, c, consts.UserSessionName)
if err != nil {
m.logger.Error("auth failed", "error", err)
return c.String(http.StatusUnauthorized, "Unauthorized")
}
c.Set(userKey, &user)
return next(c)
}
}
}
func (m *AuthMiddleware) Auth() echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
user, err := session.Get[domain.AdminUser](m.session, c, consts.SessionName)
if err != nil {
m.logger.Error("auth failed", "error", err)
return c.String(http.StatusUnauthorized, "Unauthorized")
}
c.Set(adminKey, &user)
return next(c)
}
}
}
func GetAdmin(c echo.Context) *domain.AdminUser {
i := c.Get(adminKey)
if i == nil {
return nil
}
return i.(*domain.AdminUser)
}
func GetUser(c echo.Context) *domain.User {
i := c.Get(userKey)
if i == nil {
return nil
}
return i.(*domain.User)
}