Choose an authentication approach
Vertex AI authenticates with Google Cloud Application Default Credentials, which can be supplied several ways. The right one depends on whether your users have Google identities and whether you need per-user attribution in Cloud Audit Logs.| Scenario | Use | Per-device prerequisite | Per-user Cloud Audit Logs identity | Notes |
|---|---|---|---|---|
| Proof of concept, single team | Service-account key (inferenceVertexCredentialsFile) | The key file on each device | No (shared service account) | A long-lived secret distributed to every device. Simplest to start; not recommended for broad rollout. |
| Users have Google Workspace or Cloud Identity accounts | In-app Google sign-in (inferenceVertexOAuth*) | None | Yes | Users sign in with their Google account inside the app. See the session-control warning below. |
| Users authenticate with a third-party IdP (Entra ID, Okta, Ping, …) and you don’t want to provision Google identities | In-app Workforce Identity sign-in (inferenceVertexWorkforce*) | None | Yes (workforce-pool principal) | Users sign in with their corporate identity inside the app. The app runs PKCE against your IdP and exchanges the ID token at Google STS. |
| Your organization already has tooling that obtains a Vertex-usable bearer | Credential helper (inferenceCredentialHelper) | The helper executable on each device | Depends on what the helper obtains | The helper’s stdout is sent as the bearer on each Vertex request. |
| You already operate an LLM proxy | Gateway provider instead of Vertex | None | At your gateway | The proxy holds the Google Cloud credentials; the app authenticates only to the proxy. |
Set up Google Cloud
These steps are performed once per Google Cloud project, regardless of which authentication approach you chose. You need a project with Owner or Editor access.Enable the Vertex AI API
In the Google Cloud console, enable the Vertex AI API for your project.
Enable Claude models in Model Garden
In the Vertex AI Model Garden, locate the Claude models you intend to deploy and click Enable on each. Model availability varies by region; enable them in the region you will set as
inferenceVertexRegion.Grant users access to Vertex AI
Each authenticated principal needs permission to call the model. On the project’s IAM page, grant the Vertex AI User role (
roles/aiplatform.user) to:- the service account, if using a service-account key file
- the Google group containing your users, if using in-app Google sign-in
aiplatform.endpoints.predict.Create an OAuth client (in-app Google sign-in only)
If you chose in-app Google sign-in, create a Desktop-app OAuth client in your project. See In-app Google sign-in below for the full procedure, including consent-screen setup.
Federate to your IdP (optional)
If your users authenticate with Microsoft Entra ID, Okta, or another identity provider and do not already have Google accounts, you have two options:
- Workforce Identity Federation (recommended). Create a workforce pool with an OIDC provider, and use the in-app Workforce Identity sign-in approach. Users sign in directly with their corporate identity; no Google identity is provisioned.
- Cloud Identity with SAML SSO. Provision a free Cloud Identity tenant and configure SAML single sign-on to your IdP. Users then sign in through the in-app Google sign-in approach with a Google identity that is backed by your IdP. See Set up SSO with a third-party IdP in the Cloud Identity documentation.
Prepare devices
What each end-user device needs depends on the authentication approach you chose.Credentials file
Create a service account in your project, grant it the Vertex AI User role, and download its JSON key. Distribute the key file to a fixed path on each device through your device-management tooling and setinferenceVertexCredentialsFile to that path.
inferenceVertexCredentialsFile accepts any Application Default Credentials JSON format, so if your environment already produces an authorized_user file (from gcloud auth application-default login) or an external_account Workforce Identity Federation configuration, you can point at that file instead. For external_account files, the credential_source must be of type file or url (executable sources are not supported), and separate tooling on the device must obtain the IdP token and write it to the configured location; Claude Desktop does not perform that step.
In-app Google sign-in
No per-device preparation is required. The sign-in experience uses a Google OAuth client that you create in your own Google Cloud project; Anthropic does not provide or operate an OAuth client for this flow. Distribute the OAuth client ID and secret in the managed configuration (see Configure the app).How it works
WheninferenceVertexOAuthClientId and inferenceVertexOAuthClientSecret are both set, the app shows a Sign in with Google page the first time a user opens the Cowork tab. Clicking the button opens the system browser for a standard Google consent flow, and the app listens on a loopback address for the redirect. On success, the app stores the user’s Google refresh token encrypted with the operating system’s secure storage (Keychain on macOS, DPAPI on Windows) and returns to the Cowork tab.
At the start of each Cowork session, the app writes an authorized_user Application Default Credentials file (the same format produced by gcloud auth application-default login) into the session sandbox and points GOOGLE_APPLICATION_CREDENTIALS at it. The Google Cloud client library inside the sandbox handles access-token minting and refresh automatically.
If the stored refresh token is revoked or expires, or if you deploy a new OAuth client ID, the app clears the stored token and shows the sign-in page again.
Create the OAuth client
Configure the OAuth consent screen
In the Google Cloud Console for your Vertex project, open APIs & Services → OAuth consent screen.If your project belongs to a Google Workspace organization, select the Internal user type. Internal apps are limited to users in your Workspace and do not require Google verification, regardless of which scopes they request.If the project is not in a Workspace organization, you must use the External user type. Because this flow requests the
https://www.googleapis.com/auth/cloud-platform scope, Google classifies the app as using a sensitive scope, and publishing it beyond test users requires Google’s OAuth verification process. For that reason, Internal is strongly recommended for enterprise deployments.Create a Desktop OAuth client
In APIs & Services → Credentials, choose Create credentials → OAuth client ID, and select Desktop app as the application type.Record the generated Client ID (ending in
.apps.googleusercontent.com) and Client secret. For installed applications, Google does not treat the client secret as confidential; the flow is protected by PKCE and by the loopback redirect, so it is safe to distribute the secret in a managed configuration profile.You do not need to add redirect URIs. Desktop-app clients permit loopback (http://127.0.0.1:<port>) redirects automatically.Allow network egress
The sign-in flow and subsequent token refreshes reach
accounts.google.com and oauth2.googleapis.com from the user’s device. These hosts are already included in the standard Vertex AI egress requirements, so if you allowed egress based on the Egress Requirements section of the configuration window, no additional firewall changes are needed.Federate to a third-party identity provider
The in-app sign-in always opens Google’s authorization endpoint, because Vertex AI only accepts Google-issued access tokens. To have users authenticate with your organization’s own identity provider (Microsoft Entra ID, Okta, Ping, or an in-house SAML IdP) instead of a Google password, configure Cloud Identity as a broker:- In the Google Admin console, set up SSO with a third-party IdP and assign the SSO profile to your Claude Desktop users’ organizational unit.
- Provision those users into Cloud Identity (via SCIM from your IdP, or Google Cloud Directory Sync) so IAM grants resolve.
- Optionally set
inferenceVertexOAuthLoginHintso Google skips its own account chooser and routes straight to your IdP with the user’s identity pre-filled.
Notes and limitations
- Precedence. When both
inferenceVertexOAuthClientIdandinferenceVertexCredentialsFileare set andinferenceCredentialKindis not, Google sign-in takes precedence and the credentials file is ignored (the app logs a multi-credential warning). To force the credentials file, setinferenceCredentialKindtovendor-profileor remove the OAuth client keys. - Both keys required. If only one of
inferenceVertexOAuthClientIdorinferenceVertexOAuthClientSecretis set, the app logs a warning and falls back to standard Application Default Credentials discovery. - Client rotation. If you replace the OAuth client in Google Cloud and push the new client ID via MDM, existing users are automatically signed out and prompted to sign in again on next launch.
In-app Workforce Identity sign-in
No per-device preparation is required. In Google Cloud, create a workforce pool with an OIDC provider pointing at your organization’s IdP, and grant the pool’s principals the Vertex AI User role on the project. In your IdP, register a native (PKCE) OAuth client with the loopback redirect URIhttp://127.0.0.1:<port>/callback.
Distribute the workforce-pool provider audience and the IdP OIDC client in the managed configuration; the app shows a Sign in page on first launch, runs an authorization-code-with-PKCE flow against your IdP in the system browser, exchanges the returned ID token for a Google Cloud access token at sts.googleapis.com, and stores the IdP refresh token encrypted with the operating system’s secure storage. No gcloud CLI, helper script, or Google identity is required.
Configure the app
With Google Cloud set up and devices prepared, open the in-app configuration window (Developer → Configure third-party inference) on an evaluation device. In the Connection section, set Inference provider to Vertex AI and fill in the Vertex AI credentials card with the values for whichever authentication approach you chose:| Field | Service-account key | In-app Google sign-in |
|---|---|---|
| GCP project ID | your-gcp-project | your-gcp-project |
| GCP region | e.g. us-east5 | e.g. us-east5 |
| GCP credentials file path | /path/to/sa-key.json | leave empty |
| Vertex OAuth client ID | leave empty | 1234567890-abc123.apps.googleusercontent.com |
| Vertex OAuth client secret | leave empty | GOCSPX-xxxxxxxxxxxxxxxxxxxx |
| Vertex OAuth scopes | leave empty | leave empty for the default |
| Vertex AI base URL | optional | optional |
claude-sonnet-4-5@20250929.
Then click Export to produce a .mobileconfig (macOS) or .reg (Windows) file for your MDM. See Installation and setup for the export and deployment workflow.
Configuration keys
The full set of Vertex keys is below. SetinferenceProvider to vertex, supply a project and region, and provide exactly one credential source.
| Key | Type | Availability | Default | Description |
|---|---|---|---|---|
inferenceVertexProjectId | string | MDM + Bootstrap | — | |
inferenceVertexRegion | string | MDM + Bootstrap | — | GCP region where your Vertex AI Claude models are deployed. |
inferenceVertexBaseUrl | string | MDM + Bootstrap | — | PSC endpoint, if using one. |
inferenceVertexOAuthClientId | string | MDM + Bootstrap | — | Desktop-app OAuth client ID. Enables Sign in with Google instead of a credentials file. |
inferenceVertexOAuthClientSecret | string | MDM + Bootstrap | — | Secret for the Desktop-app OAuth client above. |
inferenceVertexOAuthScopes | string | MDM + Bootstrap | — | Override the Google OAuth scopes (space-separated). Leave blank for the default. |
inferenceVertexOAuthLoginHint | string | MDM + Bootstrap | — | Pre-fill Google’s account chooser and forward to your federated IdP. {username} expands to the OS login name. |
inferenceVertexWorkforceAudience | string | MDM + Bootstrap | — | Workforce-pool provider audience. When set, sign-in uses your own IdP plus a GCP STS exchange instead of a Google identity. |
inferenceVertexWorkforceUserProject | string | MDM + Bootstrap | — | GCP project for STS billing and quota. Defaults to the Vertex project ID above. |
inferenceVertexWorkforceOidc | object | MDM + Bootstrap | — | Your organization’s OIDC IdP. The app runs an authorization-code-with-PKCE flow against this issuer and exchanges the returned ID token at GCP STS. |
inferenceVertexCredentialsFile | string | MDM only | — | Absolute path to service-account JSON. Leave blank to fall back to ADC. |
inferenceVertexCredentialsFile, the OAuth client keys, the Workforce Identity keys, or inferenceCredentialHelper is set, the Google client library falls back to the standard Application Default Credentials search path on the device (~/.config/gcloud/application_default_credentials.json, then the environment’s metadata server).
You must also set inferenceModels to a list of Vertex publisher model IDs, for example claude-sonnet-4-5@20250929. See the Configuration reference.
What users experience
The first-launch and re-authentication behavior depends on the authentication approach.| Approach | First launch | Re-authentication |
|---|---|---|
| Credentials file (service-account key) | The app opens directly; no user action. | Never, until you rotate the key file. |
| In-app Google sign-in | The Cowork tab shows a Sign in with Google page. Clicking it opens Google’s consent flow in the default browser. After approval, the app relaunches into Cowork. | When the refresh token is revoked, when you deploy a new OAuth client ID, or when your Google Cloud session-control policy expires it. |