package mod import ( "net/http" "codeberg.org/u1f320/pronouns.cc/backend/server" "github.com/go-chi/chi/v5" "github.com/go-chi/render" ) type Server struct { *server.Server } func Mount(srv *server.Server, r chi.Router) { s := &Server{Server: srv} r.With(MustAdmin).Route("/admin", func(r chi.Router) { r.Get("/reports", server.WrapHandler(s.getReports)) r.Get("/reports/by-user/{id}", nil) r.Get("/reports/by-reporter/{id}", nil) r.Patch("/reports/{id}", nil) }) } func MustAdmin(next http.Handler) http.Handler { fn := func(w http.ResponseWriter, r *http.Request) { claims, ok := server.ClaimsFromContext(r.Context()) if !ok { render.Status(r, http.StatusForbidden) render.JSON(w, r, server.APIError{ Code: server.ErrForbidden, Message: "Forbidden", }) return } if !claims.UserIsAdmin { render.Status(r, http.StatusForbidden) render.JSON(w, r, server.APIError{ Code: server.ErrForbidden, Message: "Forbidden", }) return } next.ServeHTTP(w, r) } return http.HandlerFunc(fn) }