saasitone/middleware/auth.go

56 lines
1.3 KiB
Go
Raw Normal View History

2021-12-12 14:04:11 -08:00
package middleware
import (
"net/http"
"goweb/auth"
"goweb/context"
"goweb/ent"
"github.com/labstack/echo/v4"
)
2021-12-15 06:29:43 -08:00
func LoadAuthenticatedUser(authClient *auth.Client) echo.MiddlewareFunc {
2021-12-12 14:04:11 -08:00
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
2021-12-15 06:29:43 -08:00
if user, err := authClient.GetAuthenticatedUser(c); err == nil {
2021-12-12 16:02:25 -08:00
switch err.(type) {
case *ent.NotFoundError:
2021-12-15 06:29:43 -08:00
c.Logger().Debug("auth user not found")
2021-12-12 16:02:25 -08:00
case nil:
2021-12-15 06:29:43 -08:00
c.Set(context.AuthenticatedUserKey, user)
c.Logger().Info("auth user loaded in to context: %d", user.ID)
2021-12-12 16:02:25 -08:00
default:
c.Logger().Errorf("error querying for authenticated user: %v", err)
2021-12-12 14:04:11 -08:00
}
}
return next(c)
}
}
}
func RequireAuthentication() echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
if u := c.Get(context.AuthenticatedUserKey); u == nil {
return echo.NewHTTPError(http.StatusUnauthorized, "Unauthorized")
}
return next(c)
}
}
}
func RequireNoAuthentication() echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
if u := c.Get(context.AuthenticatedUserKey); u != nil {
return echo.NewHTTPError(http.StatusForbidden, "Forbidden")
}
return next(c)
}
}
}