Files
MonkeyCode/backend/internal/middleware/auth.go

74 lines
1.6 KiB
Go
Raw Normal View History

2025-06-25 15:25:18 +08:00
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 (
2025-07-21 12:24:00 +08:00
adminKey = "session:admin"
userKey = "session:user"
2025-06-25 15:25:18 +08:00
)
type AuthMiddleware struct {
session *session.Session
logger *slog.Logger
}
func NewAuthMiddleware(session *session.Session, logger *slog.Logger) *AuthMiddleware {
return &AuthMiddleware{
session: session,
logger: logger,
}
}
2025-07-21 12:24:00 +08:00
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)
}
}
}
2025-06-25 15:25:18 +08:00
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")
}
2025-07-21 12:24:00 +08:00
c.Set(adminKey, &user)
2025-06-25 15:25:18 +08:00
return next(c)
}
}
}
2025-07-21 12:24:00 +08:00
func GetAdmin(c echo.Context) *domain.AdminUser {
2025-07-21 15:04:03 +08:00
i := c.Get(adminKey)
if i == nil {
return nil
}
return i.(*domain.AdminUser)
2025-07-21 12:24:00 +08:00
}
func GetUser(c echo.Context) *domain.User {
2025-07-21 15:04:03 +08:00
i := c.Get(userKey)
if i == nil {
return nil
}
return i.(*domain.User)
2025-06-25 15:25:18 +08:00
}