package router import ( "net/http" "time" "github.com/go-chi/chi" "github.com/go-chi/chi/middleware" "github.com/go-chi/cors" "github.com/jmoiron/sqlx" log "github.com/sirupsen/logrus" "github.com/jordanknott/project-citadel/api/graph" "github.com/jordanknott/project-citadel/api/pg" ) func (h *CitadelHandler) PingHandler(w http.ResponseWriter, r *http.Request) { w.Write([]byte("pong")) } func NewRouter(db *sqlx.DB) (chi.Router, error) { formatter := new(log.TextFormatter) formatter.TimestampFormat = "02-01-2006 15:04:05" formatter.FullTimestamp = true routerLogger := log.New() routerLogger.SetLevel(log.WarnLevel) routerLogger.Formatter = formatter r := chi.NewRouter() cors := cors.New(cors.Options{ // AllowedOrigins: []string{"https://foo.com"}, // Use this to allow specific origin hosts AllowedOrigins: []string{"*"}, // AllowOriginFunc: func(r *http.Request, origin string) bool { return true }, AllowedMethods: []string{"GET", "POST", "PUT", "DELETE", "OPTIONS"}, AllowedHeaders: []string{"Accept", "Authorization", "Content-Type", "X-CSRF-Token", "Cookie"}, ExposedHeaders: []string{"Link"}, AllowCredentials: true, MaxAge: 300, // Maximum value not ignored by any of major browsers }) r.Use(cors.Handler) r.Use(middleware.RequestID) r.Use(middleware.RealIP) r.Use(NewStructuredLogger(routerLogger)) r.Use(middleware.Recoverer) r.Use(middleware.Timeout(60 * time.Second)) repository := pg.NewRepository(db) citadelHandler := CitadelHandler{repository} r.Group(func(mux chi.Router) { mux.Mount("/auth", authResource{}.Routes(citadelHandler)) mux.Handle("/__graphql", graph.NewPlaygroundHandler("/graphql")) }) r.Group(func(mux chi.Router) { mux.Use(AuthenticationMiddleware) mux.Get("/ping", citadelHandler.PingHandler) mux.Handle("/graphql", graph.NewHandler(repository)) }) return r, nil }