Learn how to configure Google Distributed Cloud to use OpenID Connect (OIDC) with Google as the OpenID Provider for authentication to user clusters. This page covers the process in general to help you understand how to configure Google as the OpenID provider.
For an overview of the Google Distributed Cloud authentication flow, see Authentication. To learn how to configure OIDC with other OpenID providers, see the following resources:
- Authenticating with OpenID Connect (OIDC)
- Authenticating with OIDC and Active Directory Federation Services (AD FS)
Google Distributed Cloud supports OIDC as one of the authentication mechanisms for interacting with a user cluster's Kubernetes API server. With OIDC, you can manage access to Kubernetes clusters by using the standard procedures in your organization for creating, enabling, and disabling user accounts.
There are two ways that users can authorize their accounts:
- Use the Google Cloud CLI to initiate the OIDC flow and obtain user authorization through a browser-based consent page. 
- Use the Google Cloud console to initiate the OIDC authentication flow. 
Before you begin
- This topic assumes you are familiar with the following authentication and OpenID concepts: 
- The Google OpenID provider does not support groups. When you use Kubernetes role-based access control (RBAC) to grant roles to authenticated users, you must grant roles to each individual user, not a group. 
- Headless systems are unsupported. A browser-based authentication flow is used to prompt you for consent and authorize your user account. 
- To authenticate through the Google Cloud console, each cluster that you want to configure for OIDC authentication must be registered with Google Cloud. 
Personas
This topic refers to three personas:
- Organization administrator. This person chooses an OpenID provider and registers client applications with the provider. 
- Cluster administrator. This person creates one or more user clusters and creates authentication configuration files for developers who use the clusters. 
- Developer. This person runs workloads on one or more clusters and uses OIDC to authenticate. 
Creating redirect URLs
This section is for organization administrators.
You must create redirect URLs for both the gcloud CLI and the Google Cloud console that the OpenID provider can use to return ID tokens.
gcloud CLI redirect URL
Google Cloud CLI is installed on each developer's local machine and includes the gcloud CLI. You can specify a port number greater than 1024 to use for the redirect URL:
http://localhost:PORT/callback
Replace PORT with your port number.
When you configure the Google OpenID provider, specify
http://localhost:PORT/callback as one of your redirect URLs.
Google Cloud console redirect URL
The redirect URL for the Google Cloud console is:
https://console.cloud.google.com/kubernetes/oidc
When you configure the Google OpenID provider, specify
https://console.cloud.google.com/kubernetes/oidc as one of your redirect URLs.
Configuring your consent screen
In this section, you configure Google's OAuth consent screen. When a developer in your organization initiates authentication to a user cluster, they are taken to this consent screen. At that time, they prove their identity to Google and give Google permission to create a token that provides identifying information to the OAuth client. In the context of this topic, the OAuth client is either the gcloud CLI or the Google Cloud console.
- Go to the OAuth consent screen page in Google Cloud console. 
- Select Internal, and click Create. 
- For Application type, select Internal. 
- For Application name, enter a name of your choice. Suggestion: - GKE on-prem.
- Under Authorized domains, add - google.com.
- Fill in additional fields as you see fit. 
- Click Save. 
Registering a client application with Google
In this section, you register Google Distributed Cloud with Google, so that Google can act as the OpenID provider for developers in your organization. As part of the registration, you must supply the two redirect URLs that you created previously.
- Go to the Credentials page in Google Cloud console. 
- Click Create credentials, and select OAuth client ID. 
- For Application type, select Web application. 
- For Name, enter a name of your choice. 
- Under Authorized redirect URIs, add your two redirect URLs. Recall that you created a redirect URL for the gcloud CLI and a redirect URL for the Google Cloud console. 
- Click Create. 
- You are given a client ID and a client secret. Save these for later use. 
Configuring oidc on Google Distributed Cloud clusters
This section is for cluster administrators.
To configure OIDC authentication, you need to configure your user cluster's
ClientConfig CRD with authentication details for a cluster. To do this, edit the KRM default object of type clientconfig in the kube-public namespace.
kubectl --kubeconfig USER_CLUSTER_KUBECONFIG -n kube-public edit clientconfig default
Details from the ClientConfig CRD are used to configure OIDC for both the Google Cloud console and the Authentication plugin for GKE Enterprise. The configuration includes the following OIDC information:
authentication:
  - name: NAME_STRING
    oidc:
      certificateAuthorityData: CERTIFICATE_STRING
      clientID: CLIENT_ID
      clientSecret: CLIENT_SECRET
      cloudConsoleRedirectURI: "http://console.cloud.google.com/kubernetes/oidc"
      deployCloudConsoleProxy: PROXY_BOOLEAN
      extraParams: EXTRA_PARAMS
      groupsClaim: GROUPS_CLAIM
      groupPrefix: GROUP_PREFIX
      issuerURI: ISSUER_URI
      kubectlRedirectURI: KUBECTL_REDIRECT_URI
      scopes: SCOPES
      userClaim: USER_CLAIM
      userPrefix: USER_PREFIX
    proxy: PROXY_URL
The following table describes how to fill out the fields of the 
ClientConfig CRD oidc object. For general information about the 
ClientConfig CRD oidc object, 
see Configuring OIDC on Google Distributed Cloud.
| Field | Required | Description | Format | 
|---|---|---|---|
| name | yes | The name of the OIDC configuration to create. | String | 
| certificateAuthorityData | No | A  Example: This value is optional in versions 1.4 and 1.5. And this value is optional in version 1.6.1 and later. However, this value is required in 1.6.0. This is of special importance for upgrades from 1.5 to 1.6.0. For more information, see Known issues in the 1.6.0 release notes. | String | 
| clientID | Yes | ID for the client application that makes
  authentication requests to the OpenID provider. Both the gcloudCLI and Google Cloud console use this ID. You were given this ID when you
  registered your client application
  with Google. | String | 
| clientSecret | No | Secret for the client application. Both the gcloud CLI and Google Cloud console use this secret. You were given this ID when you registered your client application with Google. | String | 
| extraParams | No | Set this to "prompt=consent,access_type=offline".. | Comma-delimited list | 
| groupsClaim | No | Leave blank. | String | 
| groupPrefix | No | Leave blank. | String | 
| issuerURI | Yes | Set this to "https://accounts.google.com". Client applications, like the
  gcloud CLI and Google Cloud console, send authorization
  requests to this URL. The Kubernetes API server uses this URL to discover
  public keys for verifying tokens. | URL String | 
| kubectlRedirectURI | Yes | The redirect URL that you configured previously for the gcloud CLI. | URL String | 
| scopes | Yes | Additional scopes to send to the OpenID provider. Set this to "email". | Comma-delimited list | 
| userClaim | No | Set this to "email". | String | 
| userPrefix | No | Prefix prepended to username claims
  to prevent clashes with existing names. If you do not provide this field, and usernameis a value other thanemail, the
  prefix defaults toissuerurl#. You can use the value-to disable all prefixing. | String | 
| proxy | No | Proxy server to use for the authmethod, if applicable.
 For example:http://user:password@10.10.10.10:8888 | String | 
Creating an RBAC policy for your user cluster
This section is for cluster administrators.
After you create a cluster, use Kubernetes role-based access control (RBAC) to grant access to authenticated cluster users. To grant access to resources in a particular namespace, create a Role and a RoleBinding To grant access to resources across an entire cluster, create a ClusterRole and a ClusterRoleBinding
When you use Google as your OpenID provider, you must grant access to individual users. It does not work to grant access to groups. This is because the token that the Google OpenID provider returns does not have any information about the the groups that an individual user belongs to.
For example, suppose you want jane@example.com to be able to view all Secret objects across the cluster.
Here's a manifest for a ClusterRole named secret-viewer. A person who is
granted this role can get, watch, and list any Secret in the cluster.
apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRole metadata: name: secret-viewer rules: - apiGroups: [""] # The resource type for which access is granted resources: ["secrets"] # The permissions granted by the ClusterRole verbs: ["get", "watch", "list"]
Here is a manifest for a ClusterRoleBinding named people-who-view-secrets. The
binding grants the secret-viewer role to a user named jane@example.com.
apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: people-who-view-secrets subjects: - kind: User name: jane@example.com apiGroup: rbac.authorization.k8s.io roleRef: kind: ClusterRole name: secret-viewer apiGroup: rbac.authorization.k8s.io
To create the ClusterRole, save the manifest to a file named
secret-viewer-cluster-role.yaml, and enter this command:
kubectl --kubeconfig [USER_CLUSTER_KUBECONFIG] apply -f secret-viewer-cluster-role.yaml
where [USER_CLUSTR_KUBECONFIG] is the kubeconfig file for your user cluster.
To create the ClusterRoleBinding, save the manifest to a file named
secret-viewer-cluster-role-binding.yaml, and enter this command:
kubectl --kubeconfig [USER_CLUSTER_KUBECONFIG] apply -f secret-viewer-cluster-role-binding.yaml
Creating and distributing the authentication configuration file
This section is for cluster administrators.
After you create a user cluster, you create an authentication configuration file for that cluster. You can configure multiple clusters in a single authentication configuration file. You must provide each authentication configuration file to the users who want to authenticate with each of those clusters.
Creating the authentication configuration file
To create the authentication configuration file in
the current directory, run the following gkectl command:
gkectl create-login-config --kubeconfig USER_CLUSTER_KUBECONFIG
Replace USER_CLUSTER_KUBECONFIG with the path of your user cluster's
kubeconfig file. When you ran gkectl create cluster to create your user
cluster, your
kubeconfig file 
was created.
Result: Your authentication configuration file, named
kubectl-anthos-config.yaml, is created in the current directory.
Adding multiple clusters to the authentication configuration file
You can store the authentication configuration details for multiple clusters within a single authentication configuration file.
You can use the following command to merge additional user cluster authentication details into an existing authentication configuration file. Given an existing authentication configuration file, you can either merge or combine additional user cluster authentication details:
- Merge the additional user cluster authentication details into that existing authentication configuration file.
- Combine the additional user cluster authentication details into a new file.
For example, you might need to manage both the anthos-config-1cluster.yaml
and anthos-config-3clusters.yaml authentication configuration files to
accommodate the access needs of the multiple user groups in your organization.
To add additional user clusters to your existing authentication configuration file:
- Ensure that each cluster has a unique name. If your clusters have the same names, you cannot combine them into the same authentication configuration file. Note that after a cluster is created, that cluster cannot be renamed. 
- Run the following - gkectlcommand to merge or combine configuration details:- gkectl create-login-config --kubeconfig USER_CLUSTER_KUBECONFIG \ --merge-from IN_AUTH_CONFIG_FILE --output OUT_AUTH_CONFIG_FILE - Replace the following: - USER_CLUSTER_KUBECONFIGspecifies the- kubeconfigfile of the user cluster that you want to add.
- IN_AUTH_CONFIG_FILEspecifies the path of the existing authentication configuration file that you want to merge with the additional cluster information.
- OUT_AUTH_CONFIG_FILEspecifies the path of the file where you want to store the merged authentication configuration:- Specify the same file as  IN_AUTH_CONFIG_FILEto merge the additional cluster information into that existing file.
- Specify a new path and filename to combine the authentication configuration details into a new file.
 
- Specify the same file as  
 
Distributing the authentication configuration file
To enable your users to authenticate against your user clusters, you must provide them with access to one or more of the authentication configuration files that you created. Note that the following steps use the default file name and the location that are expected by the gcloud CLI. For information about using alternate file names and locations, see Custom configuration.
Consider distributing the authentication configuration files by:
- Hosting the file at an accessible URL. If you include the - --login-configflag in the- gcloud anthos auth logincommand, the gcloud CLI obtains the authentication configuration file from that location.- Consider hosting the file on a secure host. See the - --login-config-certflag of the gcloud CLI for more information about using PEM certificates for secure HTTPS access.
- Manually providing the file to each user. After users download the file, you must instruct them about how to store the file in the default location and with the default filename that the gcloud CLI expects. - For example, users can run the following commands to store the authentication configuration file with the default - kubectl-anthos-config.yamlfilename and in the default location:- Linux- mkdir -p $HOME/.config/google/anthos/ cp AUTH_CONFIG_FILE $HOME/.config/google/anthos/kubectl-anthos-config.yaml - where - AUTH_CONFIG_FILEis the name of your authentication configuration file. For example- kubectl-anthos-config.yaml.- macOS- mkdir -p $HOME/Library/Preferences/google/anthos/ cp AUTH_CONFIG_FILE $HOME/Library/Preferences/google/anthos/kubectl-anthos-config.yaml - where - AUTH_CONFIG_FILEis the name of your authentication configuration file. For example- kubectl-anthos-config.yaml.- Windows- md "%APPDATA%\google\anthos" copy AUTH_CONFIG_FILE "%APPDATA%\google\anthos\kubectl-anthos-config.yaml" - where - AUTH_CONFIG_FILEis the name of your authentication configuration file. For example- kubectl-anthos-config.yaml.
- Using your internal tools to push the authentication configuration file onto each user's machine. For example, you could use your tooling to push files using the default - kubectl-anthos-config.yamlfilename into their default locations on each user's machine:- Linux- $HOME/.config/google/anthos/kubectl-anthos-config.yaml - macOS- $HOME/Library/Preferences/google/anthos/kubectl-anthos-config.yaml - Windows- %APPDATA%\google\anthos\kubectl-anthos-config.yaml 
Custom configuration
The gcloud CLI expects the authentication configuration file to be stored in
the default location and with the default filename kubectl-anthos-config.yaml
as mentioned in the prior section. However, you have the option to rename or
store your authentication configuration file in an alternate location. If the
file's name and location differ from the default, you must append the
--login-config flag to each command that you run when you authenticate with
the cluster. The extra command flag passes in the custom path and filename.
To learn more about the command flag, see
Authenticating through the gcloud CLI.
Installing the gcloud CLI
This section is for both cluster administrators and developers.
Each developer or user who needs to authenticate with a cluster, must install
Google Cloud CLI on their own machine. The Anthos
authentication commands have been integrated into the gcloud CLI as the
anthos-auth component.
- If you have an old version of "Anthos Plugin for Kubectl", you must uninstall that plugin before installing the gcloud CLI and - anthos-authcomponent.
- If you have an existing version of the gcloud CLI, install the latest version and the - anthos-authcomponent.
Removing old plugins
You must uninstall the old plugin before you can use the anthos-auth
component of gcloud CLI. You can check whether one of the past kubectl
based plugins exists on your machine by running the following command:
kubectl anthos version
- If the command responds with - Error: unknown command "anthos" for "kubectl", no plugin was found and you can skip to the next section.
- If a - 1.0betaversion of the plugin was found, you must locate the plugin binary and delete it. Run the following command to list the location and then use that location to remove the binary from your machine:- kubectl plugin list 
Installing gcloud CLI and the gcloud CLI
To install the gcloud CLI you must first first install gcloud CLI:
- Install gcloud CLI but skip the - gcloud initcommand.
- Run the following commands to install the - anthos-authcomponent:- gcloud components update gcloud components install anthos-auth 
- Verify that the gcloud CLI was installed successfully by running either of the following commands: - gcloud anthos auth gcloud anthos auth login - Result: Each command should respond with details about the required arguments and available options. 
Obtaining the authentication configuration file
This section is for developers.
Your administrator is responsible for creating your authentication configuration file and then providing it to you. For more details, see Distributing the authentication configuration file.
By default, the gcloud CLI uses a default filename and storage location for
your authentication configuration file. If you were manually provided the file
and need to save it on your machine, use the defaults to simplify your
gcloud authentication commands.
Use the following commands to copy the authentication configuration file to the default location:
Linux
mkdir -p $HOME/.config/google/anthos/ cp AUTH_CONFIG_FILE $HOME/.config/google/anthos/kubectl-anthos-config.yaml
where AUTH_CONFIG_FILE is the name of your authentication
configuration file. For example kubectl-anthos-config.yaml.
macOS
mkdir -p $HOME/Library/Preferences/google/anthos/ cp AUTH_CONFIG_FILE $HOME/Library/Preferences/google/anthos/kubectl-anthos-config.yaml
where AUTH_CONFIG_FILE is the name of your authentication
configuration file. For example kubectl-anthos-config.yaml.
Windows
md "%APPDATA%\google\anthos" copy AUTH_CONFIG_FILE "%APPDATA%\google\anthos\kubectl-anthos-config.yaml"
where AUTH_CONFIG_FILE is the name of your authentication
configuration file. For example kubectl-anthos-config.yaml.
If you choose to use a different filename or location, you have the option to
include the --login-config flag with each of your authentication requests.
See the following section for details about using the gcloud anthos auth login
command.
Authenticating with user clusters
This section is for developers.
Now that gcloud CLI is installed on your machine and the authentication configuration file has been provided to you by your administrator, you can use either the gcloud CLI or the Google Cloud console to authenticate with your clusters.
Authenticating through the gcloud CLI
Run gcloud commands to authenticate with your clusters:
- Run the - gcloud anthos auth logincommand to initiate the authentication flow:- gcloud anthos auth login \ --cluster CLUSTER_NAME \ --user USER_NAME \ --login-config AUTH_CONFIG_FILE_PATH \ --login-config-cert CA_CERT_PEM_FILE \ --kubeconfig USER_CLUSTER_KUBECONFIG - where: - CLUSTER_NAME(optional) specifies the name of your user cluster. If this flag is omitted, you are prompted to choose from the user clusters that are specified in your authentication configuration file.
- USER_NAME(optional) specifies the username for the credentials stored in the- kubeconfigfile. The default value is- CLUSTER_NAME-anthos-default-user
- AUTH_CONFIG_FILE_PATH(optional) specifies the custom path or URL to where your authentication configuration file is stored or hosted. You can omit this parameter, if the file is in the default location. Example:- --login-config /path/to/custom/authentication-config.yaml
- CA_CERT_PEM_FILE(optional) specifies the path to a PEM certificate file from your CA. If your authentication configuration file is hosted securely, you can use an HTTPS connection to access the file. Example:- --login-config-cert my-cert.pem
- USER_CLUSTER_KUBECONFIG(optional) specifies the custom path to your user cluster's- kubeconfigfile. The OIDC ID tokens that are returned by your OpenID provider are stored in the- kubeconfigfile.- Use this flag if your - kubeconfigfile resides in a location other than the default. If this flag is omitted, a new- kubeconfigfile is created in the default location. Example:- --kubeconfig /path/to/custom.kubeconfig
 - Examples: - Authenticate to specific cluster: - gcloud anthos auth login --cluster my-production-cluster
- Use a prompt to select which cluster to authenticate with: - gcloud anthos auth login- Result: - Please use the --cluster flag to specify a cluster from the list below: Source: $HOME/.config/google/anthos/kubectl-anthos-config.yaml 1. Cluster: test-cluster ServerIP: https://192.168.0.1:6443 2. Cluster: test-cluster-2 ServerIP: https://192.168.0.2:6443 3. Cluster: my-production-cluster ServerIP: https://192.168.0.3:6443
- Use a hosted authentication configuration file: - gcloud anthos auth login \ --cluster my-production-cluster \ --login-config HTTPS://my-secure-server/kubectl-anthos-config.yaml \ --login-config-cert my-cert.pem
 
- Enter your credentials in the browser-based consent screen that opens. 
- Verify that authentication was successful by running one of the - kubectlcommands to retrieve details about your cluster. For example:- kubectl get nodes --kubeconfig USER_CLUSTER_KUBECONFIG 
Result: Your kubeconfig file now contains an ID token that your kubectl
commands will use to authenticate with the Kubernetes API server on your user
cluster.
Using SSH to authenticate from a remote machine
Suppose you want to SSH into a remote machine and authenticate to a user cluster from the remote machine. To do this, your authentication configuration file must be on the remote machine, and you must be able to reach your Open ID provider from your local machine.
On your local machine, run the following command:
ssh USER_NAME@REMOTE_MACHINE -L LOCAL_PORT:localhost:REMOTE_PORT
where:
- USER_NAMEand- REMOTE_MACHINEare the standard values used to log in with SSH.
- LOCAL_PORTis an open port of your choice on your local machine that you will use to access the remote machine.
- REMOTE_PORTis the port you configured for your OIDC redirect URL. You can find this in the- kubectlRedirectURIfield of your authentication configuration file.
In your SSH shell, run the following command to initiate authentication:
gcloud anthos auth login --login-config AUTH_CONFIG_FILE
where AUTH_CONFIG_FILE is the path of your
authentication configuration file on the remote machine.
On your local machine, in a browser, go to
http://localhost:LOCAL_PORT/login and complete the
OIDC login flow.
Now the kubeconfig file on your remote machine has the token that you need to access the user cluster.
In your SSH shell, verify that you have access to the user cluster:
kubectl --kubeconfig USER_CLUSTER_KUBECONFIG get nodes
Authenticating through the Google Cloud console
Initiate the authentication flow from the Kubernetes clusters page in the Google Cloud console:
- 
    Open the Google Cloud console: 
- 
    Locate your Google Distributed Cloud cluster in the list and then click Login. 
- 
    Select Authenticate with the Identity Provider configured for the cluster, and then click LOGIN. You are redirected to your identity provider, where you might need to log in or consent to the Google Cloud console accessing your account. Then you are redirected back to the Kubernetes clusters page in the Google Cloud console. 
Troubleshooting your OIDC configuration
Review the following behaviors and errors to help resolve your OIDC issues:
- Invalid configuration
- If Google Cloud console cannot read the OIDC configuration from your cluster, the LOGIN button will be disabled.
- Invalid provider configuration
- If your identity provider configuration is invalid, you will see an error screen from your identity provider after you click LOGIN. Follow the provider-specific instructions to correctly configure the provider or your cluster.
- Invalid permissions
- If you complete the authentication flow, but still don't see the details of the cluster, make sure you granted the correct RBAC permissions to the account that you used with OIDC. Note that this might be a different account from the one you use to access Google Cloud console.
- Error: missing 'RefreshToken' field in 'OAuth2Token' in credentials struct
- You might get this error if the authorization server prompts for consent, but
the required authentication parameter wasn't provided. Provide the
prompt=consentparameter to Google Distributed Cloud configuration file'soidc: extraparamsfield, and regenerate the client authentication file with the--extra-params prompt=consentflag.
What's next
- Learn more about scopes and claims.