3
0
corteza/auth/rest/router.go
2018-09-18 16:39:38 +02:00

47 lines
1.1 KiB
Go

package rest
import (
"context"
"log"
"net/http"
"github.com/crusttech/crust/auth/repository"
"github.com/go-chi/chi"
"github.com/titpetric/factory/resputil"
"github.com/crusttech/crust/auth/rest/handlers"
"github.com/crusttech/crust/auth/service"
"github.com/crusttech/crust/internal/config"
)
func MountRoutes(oidcConfig *config.OIDC, jwtAuth jwtEncodeCookieSetter) func(chi.Router) {
var userSvc = service.User()
var ctx = context.Background()
oidc, err := OpenIdConnect(ctx, oidcConfig, userSvc, jwtAuth, repository.NewSettings(ctx))
if err != nil {
log.Print("Could not initialize OIDC:", err.Error())
}
// Initialize handers & controllers.
return func(r chi.Router) {
handlers.NewAuth(Auth{}.New(userSvc, jwtAuth)).MountRoutes(r)
if oidc != nil {
r.Route("/oidc", func(r chi.Router) {
r.Get("/", oidc.HandleRedirect)
r.Get("/callback", oidc.HandleOAuth2Callback)
})
}
r.Get("/jwt", func(w http.ResponseWriter, r *http.Request) {
if c, err := r.Cookie("jwt"); err != nil {
resputil.JSON(w, "")
} else {
resputil.JSON(w, c.Value)
}
})
}
}