Shares #109
3 changed files with 20 additions and 10 deletions
|
@ -34,8 +34,8 @@ type jwtAuth interface {
|
||||||
// InstallVerifyMiddleware installs the JWT verifier middleware to the provided chi Router.
|
// InstallVerifyMiddleware installs the JWT verifier middleware to the provided chi Router.
|
||||||
VerifyMiddleware() func(http.Handler) http.Handler
|
VerifyMiddleware() func(http.Handler) http.Handler
|
||||||
|
|
||||||
// InstallAuthMiddleware installs the JWT authenticator middleware to the provided chi Router.
|
// SubjectMiddleware sets the request context subject from JWT or public.
|
||||||
AuthMiddleware() func(http.Handler) http.Handler
|
SubjectMiddleware(requireAuth bool) func(http.Handler) http.Handler
|
||||||
|
|
||||||
// PublicRoutes installs the auth route to the provided chi Router.
|
// PublicRoutes installs the auth route to the provided chi Router.
|
||||||
PublicRoutes(chi.Router)
|
PublicRoutes(chi.Router)
|
||||||
|
@ -84,12 +84,20 @@ func TokenFromCookie(r *http.Request) string {
|
||||||
return cookie.Value
|
return cookie.Value
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Auth) AuthMiddleware() func(http.Handler) http.Handler {
|
func (a *Auth) PublicSubjectMiddleware() func(http.Handler) http.Handler {
|
||||||
|
return a.SubjectMiddleware(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *Auth) AuthorizedSubjectMiddleware() func(http.Handler) http.Handler {
|
||||||
|
return a.SubjectMiddleware(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *Auth) SubjectMiddleware(requireToken bool) func(http.Handler) http.Handler {
|
||||||
return func(next http.Handler) http.Handler {
|
return func(next http.Handler) http.Handler {
|
||||||
hfn := func(w http.ResponseWriter, r *http.Request) {
|
hfn := func(w http.ResponseWriter, r *http.Request) {
|
||||||
token, _, err := jwtauth.FromContext(r.Context())
|
token, _, err := jwtauth.FromContext(r.Context())
|
||||||
|
|
||||||
if err != nil {
|
if err != nil && requireToken {
|
||||||
http.Error(w, err.Error(), http.StatusUnauthorized)
|
http.Error(w, err.Error(), http.StatusUnauthorized)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,11 +31,11 @@ const (
|
||||||
|
|
||||||
func SubjectFrom(ctx context.Context) Subject {
|
func SubjectFrom(ctx context.Context) Subject {
|
||||||
sub, ok := ctx.Value(SubjectCtxKey).(Subject)
|
sub, ok := ctx.Value(SubjectCtxKey).(Subject)
|
||||||
if ok {
|
if !ok {
|
||||||
return sub
|
panic("no subject in context")
|
||||||
}
|
}
|
||||||
|
|
||||||
return new(PublicSubject)
|
return sub
|
||||||
}
|
}
|
||||||
|
|
||||||
type Subject interface {
|
type Subject interface {
|
||||||
|
|
|
@ -29,10 +29,11 @@ func (s *Server) setupRoutes() {
|
||||||
r.Use(s.WithCtxStores())
|
r.Use(s.WithCtxStores())
|
||||||
|
|
||||||
s.installPprof()
|
s.installPprof()
|
||||||
|
r.Use(s.auth.VerifyMiddleware())
|
||||||
|
|
||||||
r.Group(func(r chi.Router) {
|
r.Group(func(r chi.Router) {
|
||||||
|
r.Use(s.auth.SubjectMiddleware(true))
|
||||||
// authenticated routes
|
// authenticated routes
|
||||||
r.Use(s.auth.VerifyMiddleware(), s.auth.AuthMiddleware())
|
|
||||||
s.nex.PrivateRoutes(r)
|
s.nex.PrivateRoutes(r)
|
||||||
s.auth.PrivateRoutes(r)
|
s.auth.PrivateRoutes(r)
|
||||||
s.alerter.PrivateRoutes(r)
|
s.alerter.PrivateRoutes(r)
|
||||||
|
@ -41,6 +42,7 @@ func (s *Server) setupRoutes() {
|
||||||
|
|
||||||
r.Group(func(r chi.Router) {
|
r.Group(func(r chi.Router) {
|
||||||
s.rateLimit(r)
|
s.rateLimit(r)
|
||||||
|
r.Use(s.auth.SubjectMiddleware(false))
|
||||||
r.Use(render.SetContentType(render.ContentTypeJSON))
|
r.Use(render.SetContentType(render.ContentTypeJSON))
|
||||||
// public routes
|
// public routes
|
||||||
s.sources.PublicRoutes(r)
|
s.sources.PublicRoutes(r)
|
||||||
|
@ -49,6 +51,7 @@ func (s *Server) setupRoutes() {
|
||||||
r.Group(func(r chi.Router) {
|
r.Group(func(r chi.Router) {
|
||||||
// auth/share routes get rate-limited heavily, but not using middleware
|
// auth/share routes get rate-limited heavily, but not using middleware
|
||||||
s.rateLimit(r)
|
s.rateLimit(r)
|
||||||
|
r.Use(s.auth.SubjectMiddleware(false))
|
||||||
r.Use(render.SetContentType(render.ContentTypeJSON))
|
r.Use(render.SetContentType(render.ContentTypeJSON))
|
||||||
s.auth.PublicRoutes(r)
|
s.auth.PublicRoutes(r)
|
||||||
r.Mount("/share", s.rest.ShareRouter())
|
r.Mount("/share", s.rest.ShareRouter())
|
||||||
|
@ -56,9 +59,8 @@ func (s *Server) setupRoutes() {
|
||||||
|
|
||||||
r.Group(func(r chi.Router) {
|
r.Group(func(r chi.Router) {
|
||||||
s.rateLimit(r)
|
s.rateLimit(r)
|
||||||
r.Use(s.auth.VerifyMiddleware())
|
|
||||||
|
|
||||||
// optional auth routes
|
// optional auth routes
|
||||||
|
r.Use(s.auth.SubjectMiddleware(false))
|
||||||
|
|
||||||
s.clientRoute(r, clientRoot)
|
s.clientRoute(r, clientRoot)
|
||||||
})
|
})
|
||||||
|
|
Loading…
Add table
Reference in a new issue