2020-06-05 07:50:04 +02:00
|
|
|
package oidc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-06-17 08:06:40 +02:00
|
|
|
"net/http"
|
2020-06-05 07:50:04 +02:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/caos/logging"
|
|
|
|
"github.com/caos/oidc/pkg/op"
|
|
|
|
|
|
|
|
http_utils "github.com/caos/zitadel/internal/api/http"
|
2020-06-17 08:06:40 +02:00
|
|
|
"github.com/caos/zitadel/internal/api/http/middleware"
|
2020-06-05 07:50:04 +02:00
|
|
|
"github.com/caos/zitadel/internal/auth/repository"
|
|
|
|
"github.com/caos/zitadel/internal/config/types"
|
|
|
|
"github.com/caos/zitadel/internal/id"
|
|
|
|
)
|
|
|
|
|
|
|
|
type OPHandlerConfig struct {
|
|
|
|
OPConfig *op.Config
|
|
|
|
StorageConfig StorageConfig
|
|
|
|
UserAgentCookieConfig *http_utils.UserAgentCookieConfig
|
2020-06-17 08:06:40 +02:00
|
|
|
Cache *middleware.CacheConfig
|
2020-06-05 07:50:04 +02:00
|
|
|
Endpoints *EndpointConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
type StorageConfig struct {
|
|
|
|
DefaultLoginURL string
|
|
|
|
SigningKeyAlgorithm string
|
|
|
|
DefaultAccessTokenLifetime types.Duration
|
|
|
|
DefaultIdTokenLifetime types.Duration
|
|
|
|
}
|
|
|
|
|
|
|
|
type EndpointConfig struct {
|
|
|
|
Auth *Endpoint
|
|
|
|
Token *Endpoint
|
|
|
|
Userinfo *Endpoint
|
|
|
|
EndSession *Endpoint
|
|
|
|
Keys *Endpoint
|
|
|
|
}
|
|
|
|
|
|
|
|
type Endpoint struct {
|
|
|
|
Path string
|
|
|
|
URL string
|
|
|
|
}
|
|
|
|
|
|
|
|
type OPStorage struct {
|
|
|
|
repo repository.Repository
|
|
|
|
defaultLoginURL string
|
|
|
|
defaultAccessTokenLifetime time.Duration
|
|
|
|
defaultIdTokenLifetime time.Duration
|
|
|
|
signingKeyAlgorithm string
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewProvider(ctx context.Context, config OPHandlerConfig, repo repository.Repository) op.OpenIDProvider {
|
|
|
|
cookieHandler, err := http_utils.NewUserAgentHandler(config.UserAgentCookieConfig, id.SonyFlakeGenerator)
|
|
|
|
logging.Log("OIDC-sd4fd").OnError(err).Panic("cannot user agent handler")
|
2020-06-17 08:06:40 +02:00
|
|
|
nextHandler := func(handlerFunc http.HandlerFunc) http.HandlerFunc {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2020-07-08 13:56:37 +02:00
|
|
|
middleware.NoCacheInterceptor(http_utils.CopyHeadersToContext(handlerFunc))
|
2020-06-17 08:06:40 +02:00
|
|
|
}
|
|
|
|
}
|
2020-06-05 07:50:04 +02:00
|
|
|
provider, err := op.NewDefaultOP(
|
|
|
|
ctx,
|
|
|
|
config.OPConfig,
|
|
|
|
newStorage(config.StorageConfig, repo),
|
|
|
|
op.WithHttpInterceptor(
|
|
|
|
UserAgentCookieHandler(
|
|
|
|
cookieHandler,
|
2020-06-17 08:06:40 +02:00
|
|
|
nextHandler,
|
2020-06-05 07:50:04 +02:00
|
|
|
),
|
|
|
|
),
|
|
|
|
op.WithCustomAuthEndpoint(op.NewEndpointWithURL(config.Endpoints.Auth.Path, config.Endpoints.Auth.URL)),
|
|
|
|
op.WithCustomTokenEndpoint(op.NewEndpointWithURL(config.Endpoints.Token.Path, config.Endpoints.Token.URL)),
|
|
|
|
op.WithCustomUserinfoEndpoint(op.NewEndpointWithURL(config.Endpoints.Userinfo.Path, config.Endpoints.Userinfo.URL)),
|
|
|
|
op.WithCustomEndSessionEndpoint(op.NewEndpointWithURL(config.Endpoints.EndSession.Path, config.Endpoints.EndSession.URL)),
|
|
|
|
op.WithCustomKeysEndpoint(op.NewEndpointWithURL(config.Endpoints.Keys.Path, config.Endpoints.Keys.URL)),
|
|
|
|
op.WithRetry(3, time.Duration(30*time.Second)),
|
|
|
|
)
|
|
|
|
logging.Log("OIDC-asf13").OnError(err).Panic("cannot create provider")
|
|
|
|
return provider
|
|
|
|
}
|
|
|
|
|
|
|
|
func newStorage(config StorageConfig, repo repository.Repository) *OPStorage {
|
|
|
|
return &OPStorage{
|
|
|
|
repo: repo,
|
|
|
|
defaultLoginURL: config.DefaultLoginURL,
|
|
|
|
signingKeyAlgorithm: config.SigningKeyAlgorithm,
|
|
|
|
defaultAccessTokenLifetime: config.DefaultAccessTokenLifetime.Duration,
|
|
|
|
defaultIdTokenLifetime: config.DefaultIdTokenLifetime.Duration,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (o *OPStorage) Health(ctx context.Context) error {
|
|
|
|
return o.repo.Health(ctx)
|
|
|
|
}
|