Shares #109

Merged
amigan merged 59 commits from shareUI into trunk 2025-02-14 00:25:03 -05:00
3 changed files with 20 additions and 10 deletions
Showing only changes of commit e7f96ea58e - Show all commits

View file

@ -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
} }

View file

@ -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 {

View file

@ -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)
}) })