36 lines
1 KiB
Go
36 lines
1 KiB
Go
package handlers
|
|
|
|
import (
|
|
"context"
|
|
"log/slog"
|
|
"os"
|
|
|
|
"gitlab.unjx.de/flohoss/godash/internal/env"
|
|
|
|
"github.com/zitadel/oidc/v3/pkg/oidc"
|
|
"github.com/zitadel/zitadel-go/v3/pkg/authentication"
|
|
openid "github.com/zitadel/zitadel-go/v3/pkg/authentication/oidc"
|
|
"github.com/zitadel/zitadel-go/v3/pkg/zitadel"
|
|
)
|
|
|
|
func NewAuthHandler(env *env.Config) *AuthHandler {
|
|
ctx := context.Background()
|
|
authN, err := authentication.New(ctx, zitadel.New(env.OIDCIssuerUrl), env.OIDCClientSecret,
|
|
openid.DefaultAuthentication(env.OIDCClientId, env.OIDCRedirectUri, env.OIDCClientSecret),
|
|
)
|
|
if err != nil {
|
|
slog.Error("zitadel sdk could not initialize", "error", err)
|
|
os.Exit(1)
|
|
}
|
|
mw := authentication.Middleware(authN)
|
|
|
|
return &AuthHandler{
|
|
authenticator: authN,
|
|
middleware: mw,
|
|
}
|
|
}
|
|
|
|
type AuthHandler struct {
|
|
authenticator *authentication.Authenticator[*openid.UserInfoContext[*oidc.IDTokenClaims, *oidc.UserInfo]]
|
|
middleware *authentication.Interceptor[*openid.UserInfoContext[*oidc.IDTokenClaims, *oidc.UserInfo]]
|
|
}
|