Skip to content

OIDC Azure Integration fails #2334

Open
@tomhuang12

Description

@tomhuang12

Describe the bug

After setting up oidc-auth secret and restarting the deployment, the pod goes into CrashLoopBackOff state with error:

Error: could not create auth server: could not create provider: oidc: issuer did not match the issuer returned by provider, expected "https://login.microsoftonline.com/organizations/v2.0" got "[https://login.microsoftonline.com/{tenantid}/v2.0](https://login.microsoftonline.com/%7Btenantid%7D/v2.0)"

The Azure/Microsoft OIDC URL used is https://login.microsoftonline.com/organizations/v2.0. The resulting OIDC config returns "https://login.microsoftonline.com/{tenantid}/v2.0" from the Microsoft side which causes the failure.

Environment

  • Weave-Gitops Version: v0.8.1
  • Flux Version: v0.31
  • Kubernetes version: v1.22.6

To Reproduce
Steps to reproduce the behavior:

Go through setting up OIDC using Azure's OIDC configuration. (I can provide detailed steps on the Azure side if needed.)

Expected behavior

OIDC should work with Azure/Microsoft OIDC.

Actual Behavior

OIDC auth fails to work.

Additional Context (screenshots, logs, etc)


2022-06-16T13:07:25.254Z    INFO    gitops    cmd/cmd.go:99    Version    {"version": "v0.0.0", "git-commit": "", "branch": "", "buildtime": ""}
I0616 13:07:26.306156       1 request.go:665] Waited for 1.026852261s due to client-side throttling, not priority and fairness, request: GET:https://172.16.0.1:443/apis/operators.coreos.com/v1alpha2?timeout=32s
Error: could not create auth server: could not create provider: oidc: issuer did not match the issuer returned by provider, expected "https://login.microsoftonline.com/organizations/v2.0" got "https://login.microsoftonline.com/{tenantid}/v2.0"
Usage:
   [flags[]
Flags:
      --dev-mode                                 Enables development mode
      --dev-user string                          Sets development User (default "wego-admin")
  -h, --help                                     help for this command
      --host string                              UI host (default "0.0.0.0")
      --insecure                                 do not attempt to read TLS certificates
      --log-level string                         log level (default "info")
      --mtls                                     disable enforce mTLS
      --notification-controller-address string   the address of the notification-controller running in the cluster
      --oidc-client-id string                    The client ID for the OpenID Connect client
      --oidc-client-secret string                The client secret to use with OpenID Connect issuer
      --oidc-issuer-url string                   The URL of the OpenID Connect issuer
      --oidc-redirect-url string                 The OAuth2 redirect URL
      --oidc-token-duration duration             The duration of the ID token. It should be set in the format: number + time unit (s,m,h) e.g., 20m (default 1h0m0s)
      --path string                              Path url
      --port string                              UI port (default "9001")
      --tls-cert-file string                     filename for the TLS certificate, in-memory generated if omitted
      --tls-private-key-file string              filename for the TLS key, in-memory generated if omitted
Error: could not create auth server: could not create provider: oidc: issuer did not match the issuer returned by provider, expected "https://login.microsoftonline.com/organizations/v2.0" got "https://login.microsoftonline.com/{tenantid}/v2.0"

Metadata

Metadata

Assignees

No one assigned

    Labels

    documentationImprovements or additions to documentationhelp wantedThis is approved by product and we are looking for a contributor to help out.team/pestouser-guideImprovements to docs at https://docs.gitops.weave.works/

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions