This document shows you how to configure Workforce Identity Federation with the PingFederate identity provider (IdP) and manage access to Google Cloud. After you configure the PingFederate IdP, federated users can access Google Cloud services that support Workforce Identity Federation by using the SAML 2.0 protocol.
Before you begin
- Make sure that you set up a Google Cloud organization.
-
Install the Google Cloud CLI. After installation, initialize the Google Cloud CLI by running the following command:
gcloud initIf you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
To set up a PingFederate application that uses the SAML 2.0 protocol, do the following
in PingFederate:
- Set the SAML 2.0 Entity ID of your PingFederate IdP. For details, see Specifying federation information.
Create a SAML 2.0 SP connection, see Choosing an SP connection type and do the following:
- In Connection Type, select Browser SSO Profiles and SAML 2.0 protocol.
- In Import Metadata, select None.
In General Info, set the Partner's Entity ID (Connection ID) to the following:
https://iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_IDIn SAML Profiles, enable SP-initiated SSO. If you plan to also use IdP-initiated single sign-on (SSO), you can also enable it.
In Attribute Contract, define custom attributes (for example, email and groups) to be passed in the assertion. These attributes can be used in Google Cloud to create access management policies later.
In Attribute Contract Fulfillment, make sure that
SAML_SUBJECTis mapped to a field that has a unique value for each user. For example, an email address is typically unique for each user, doesn't change, and is often used to refer to a specific user in Google Cloud access management policies.To set up console (federated) sign-in, in Assertion Consumer Service URL, add the following endpoint URL:
https://auth.cloud.google/signin-callback/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_IDReplace the following:
WORKFORCE_POOL_ID: the ID of the workforce pool that you created earlier.WORKFORCE_PROVIDER_ID: the ID of the workforce provider that you create later.
Set Binding for this endpoint to POST.
To enable console (federated) sign-in, in Allowable SAML Bindings, select Redirect.
For Signature Policy, select Sign Response As Required.
Save and activate the connection.
To configure the SAML application, do the following:
gcloud
To create the SAML workforce identity pool provider, run the following command:
gcloud iam workforce-pools providers create-saml WORKFORCE_PROVIDER_ID \ --workforce-pool="WORKFORCE_POOL_ID" \ --display-name="DISPLAY_NAME" \ --description="DESCRIPTION" \ --idp-metadata-path="XML_METADATA_PATH" \ --attribute-mapping="ATTRIBUTE_MAPPING" \ --attribute-condition="ATTRIBUTE_CONDITION" \ --location=globalReplace the following:
WORKFORCE_PROVIDER_ID: a provider ID.WORKFORCE_POOL_ID: the workforce identity pool ID.DISPLAY_NAME: a display name.DESCRIPTION: a description.XML_METADATA_PATH: the path to the XML-formatted metadata file from PingFederate.ATTRIBUTE_MAPPING: the attribute mapping; for example,google.subject=assertion.subject,google.groups=assertion.attributes.groups,attribute.department=assertion.attributes.department[0].ATTRIBUTE_CONDITION: an optional attribute condition; for example, to limit theipaddrattribute to a certain IP range, set the condition toassertion.ipaddr.startsWith('98.11.12.').
This command assigns the
subject,groups, anddepartmentin the SAML assertion togoogle.subject,google.groups, andattribute.departmentattributes, respectively. The attribute condition also ensures that only users within a certain IP range can sign in using this workforce provider.Console
To configure the SAML provider by using the Google Cloud console, do the following:
- In the Google Cloud console, go to the Workforce Identity Pools page: Go to Workforce Identity Pools
- In the Workforce Identity Pools table, select the pool that you want to create the provider for.
- In the Providers section, click Add Provider.
- In the Select a Provider vendor list, select Generic Identity Provider.
- In Select an authentication protocol, select SAML.
- In the Create a provider section, do the following:
- In Name, enter a name for the provider.
- In IDP metadata file (XML), select the metadata XML file from PingFederate.
- Click Continue.
- In the Share your provider information section, click Continue.
In the Configure provider section, do the following:
- In Attribute mapping, enter a CEL expression for
google.subject(for example,assertion.subject). Optional: To enter other mappings, click Add mapping and enter other mappings—for example:
google.subject=assertion.subject, google.groups=assertion.attributes['https://example.com/aliases'], attribute.costcenter=assertion.attributes.costcenter[0]
- In Attribute mapping, enter a CEL expression for
To turn on detailed audit logging, in Detailed logging, click the Enable attribute value audit logging toggle.
To create the provider, click Submit.
TEST_PROJECT_ID: the project ID.WORKFORCE_POOL_ID: the workforce identity pool ID.DEPARTMENT_VALUE: the mappedattribute.departmentvalue.TEST_PROJECT_ID: the project ID.WORKFORCE_POOL_ID: the workforce identity pool ID.GROUP_ID: a group in the mappedgoogle.groupsclaim.-
Go to the console (federated) sign-in page.
-
Enter the provider name, which is formatted as follows:
locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID
Enter your PingFederate credentials when prompted. WORKFORCE_POOL_ID: The Workforce Identity Federation pool ID.WORKFORCE_PROVIDER_ID: The Workforce Identity Federation provider ID.-
LOGIN_CONFIG_PATH: The path to write the login configuration file to. For example,login-config.json. -
Set the
CLOUDSDK_AUTH_LOGIN_CONFIG_FILEenvironment variable to the path of the login configuration file. -
Run the following command:
gcloud auth login
- The gcloud CLI references the environment variable to find the login configuration file, and then starts the authentication process. Follow the browser-based flow to authenticate and authorize the gcloud CLI to access resources on your behalf for future commands.
-
Set the active gcloud CLI configuration's
auth/login_config_fileproperty to the login configuration file's path with the following command:gcloud config set auth/login_config_file LOGIN_CONFIG_PATH
-
Run the following command:
gcloud auth login
- The gcloud CLI references the configuration property to find the login configuration file, and then starts the authentication process. Follow the browser-based flow to authenticate and authorize the gcloud CLI to access resources on your behalf for future commands.
-
If you used the
--activateflag when you created the login configuration file, run the following command:gcloud auth login
-
If you didn't use the
--activateflag when you created the login configuration file, run the following command:Linux and macOS
gcloud auth login \ --login-config=LOGIN_CONFIG_PATH
Windows (PowerShell)
gcloud auth login ` --login-config=LOGIN_CONFIG_PATH
Replace LOGIN_CONFIG_PATH with the path of your login configuration file.
- Sign in a user to your PingFederate app and get the SAML response.
- Save the SAML response returned by PingFederate in a secure location on your local machine. Store the path in an environment variable—for example:
SAML_ASSERTION_PATH=/path/to/assertion.xml. Generate a configuration file:
gcloud iam workforce-pools create-cred-config \ locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID \ --subject-token-type=urn:ietf:params:oauth:token-type:saml2 \ --credential-source-file=SAML_ASSERTION_PATH \ --workforce-pool-user-project=PROJECT_ID \ --output-file=config.jsonReplace the following:
SAML_ASSERTION_PATH: the path of the SAML assertion file.PROJECT_ID: the project ID.
The configuration file that's generated looks similar to the following:
{ "type": "external_account", "audience": "//iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID", "subject_token_type": "urn:ietf:params:oauth:token-type:saml2", "token_url": "https://sts.googleapis.com/v1/token", "credential_source": { "file": "SAML_ASSERTION_PATH" }, "workforce_pool_user_project": "PROJECT_ID" }To sign in to the gcloud CLI using token exchange, run the following command:
gcloud auth login --cred-file=config.jsongcloudthen transparently exchanges your PingFederate credentials for temporary Google Cloud access tokens, allowing you to make othergcloudcalls to Google Cloud. The output is similar to the following:Authenticated with external account user credentials for: [principal://iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/subject/USER_ID].To list the credentialed accounts and the active account, run the following command:
gcloud auth list- Go to the Cloud Storage page.
- Verify that you can see the list of existing buckets for the project
TEST_PROJECT_ID. - Delete Workforce Identity Federation users and their data.
- Learn which Google Cloud products support Workforce Identity Federation.
- Set up user access to console (federated).
Use attributes
This section describes how to use attributes from the SAML assertion.
Use attribute contracts to specify the custom attributes in the generated SAML assertions. After you configure attributes, you can use them in Google Cloud to create access management policies. To learn more about attribute contracts, refer to Attribute contracts in the PingFederate server documentation.
For example, in this guide we use PingOne as the datastore for PingFederate and map the email, firstName, and groups attribute contracts using the user attributes from the PingOne datastore, as follows:
| Attribute Contract | Value |
|---|---|
email |
email |
firstName |
name.given |
groups |
memberOfGroupIDs |
Create the PingFederate workforce identity pool provider
This section describes how to create a workforce identity pool provider to enable your IdP users to access Google Cloud. You can configure the provider to use the SAML protocol.
Create a SAML 2.0 workforce identity pool provider
Manage access to Google Cloud resources
This section shows how to manage access to Google Cloud resources for PingFederate users.
The sample project that's used in this guide can be different from the project you used to set up Workforce Identity Federation.
You can manage roles for single identities, a group of identities, or an entire pool. For more information, see Workforce principal identifiers for allow policies.
Use mapped department attributes
To grant the Storage Admin role (roles/storage.admin) to all identities within a specific department for the TEST_PROJECT_ID project, run the following command:
gcloud projects add-iam-policy-binding TEST_PROJECT_ID \
--role="roles/storage.admin" \
--member="principalSet://iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/attribute.department/DEPARTMENT_VALUE"
Replace the following:
Use mapped groups
To grant the Storage Admin role (roles/storage.admin) to all identities within the GROUP_ID group for the TEST_PROJECT_ID project, run the following command:
gcloud projects add-iam-policy-binding TEST_PROJECT_ID \
--role="roles/storage.admin" \
--member="principalSet://iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/group/GROUP_ID"
Replace the following:
Sign in and test access
In this section, you sign in as a workforce identity pool user and test your access.
Sign in
console (federated) sign-in
To sign in to the Google Cloud Workforce Identity Federation console, also known as the console (federated), do the following:
gcloud CLI browser-based sign-in
To sign in to gcloud CLI using a browser-based sign-in flow:
Run the following command to create a login configuration file:
Linux and macOS
gcloud iam workforce-pools create-login-config \ locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID \ --output-file=LOGIN_CONFIG_PATH
Windows (PowerShell)
gcloud iam workforce-pools create-login-config ` locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID ` --output-file=LOGIN_CONFIG_PATH
Replace the following:
The login configuration file contains the endpoints used by the gcloud CLI to enable the browser-based authentication flow and set the audience to the IdP that was configured in the workforce identity pool provider. The file doesn't contain confidential information.
The login configuration file content looks similar to the following:
{ "universe_domain": "googleapis.com", "universe_cloud_web_domain": "cloud.google", "type": "external_account_authorized_user_login_config", "audience": "//iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID", "auth_url": "https://auth.cloud.google/authorize", "token_url": "https://sts.googleapis.com/v1/oauthtoken", "token_info_url": "https://sts.googleapis.com/v1/introspect" }
Point to the login configuration file with an environment variable, a property in the active
gcloud CLI configuration, or use it directly with the gcloud auth login
command:
Environment variable
To use the login configuration file with an environment variable, complete the following instructions:
To stop using the login configuration file for gcloud auth login commands, clear
the CLOUDSDK_AUTH_LOGIN_CONFIG_FILE environment variable.
gcloud CLI configuration
To use the login configuration file with a gcloud CLI configuration property, complete the following instructions:
To stop using the login configuration file for gcloud auth login commands, unset
the property with the following command:
gcloud config unset auth/login_config_file
gcloud auth login
To use the login configuration file directly with the gcloud auth login
command, complete the following instructions:
The gcloud auth login command stores access credentials in your home directory. The authenticated principal becomes the active principal in your active gcloud CLI configuration. Unless overridden, the gcloud CLI uses these stored credentials to access Google Cloud.
gcloud CLI headless sign-in
To sign in to PingFederate with the gcloud CLI using the SAML protocol, do the following:
Test access
You have access to Google Cloud services that support Workforce Identity Federation and to which you are granted access. Earlier in this guide, you granted the Storage Admin role to all identities within a specific department or group for project TEST_PROJECT_ID. You can test that you have access by listing Cloud Storage buckets.
console (federated) sign-in
To verify your access in the console (federated), do the following:
gcloud CLI
To list Cloud Storage buckets and objects for the project that you have access to, run the following command:
gcloud alpha storage ls --project="TEST_PROJECT_ID"
The principal must have the serviceusage.services.use permission on the project set in the gcloud CLI session: PROJECT_ID.