4.2 KiB
Expose Cloud Run service with Global External Application Load Balancer protected by IAP
This recipe demonstrates how to expose a Cloud Run Service Global External Application Load Balancer protected by IAP.
The architecture deployed by this recipe is the one depicted below:
Note: Make sure that the email that you pass as support email for the IAP brand is the email of a group in which the identity executing terraform is a member with the role MANAGER. Otherwise an error will be raised. Also bear in mind only organization internal brands can be created using Terraform.
This recipe addresses common requirements of backends protected by IAP:
-
CORS
When a browser sends a CORS preflight OPTIONS request, it typically doesn't include any authentication credentials (like IAP session cookies). Since IAP is designed to protect an application by requiring authentication, it often blocks these unauthenticated OPTIONS requests, returning an errorinstead of the necessary CORS headers. The browser then sees this as a CORS failure and blocks the subsequent actual request. Google Cloud's IAP has a setting,
access_settings.cors_settings.allow_http_options, that needs to be set to true. This allows IAP to pass OPTIONS requests to your backend without requiring authentication. The backend application must then be configured to correctly respond to these OPTIONS requests with the appropriate CORS headers (e.g., Access-Control-Allow-Origin, Access-Control-Allow-Methods, Access-Control-Allow-Headers). This tells the browser that cross-origin requests are permitted. -
Programmatic access using a service account
To access a service exposed with Global External Application Load Balancer protected by IAP programmatically impersonating a service account:
-
The service account to use for programmatic access must be granted the IAP-Secured Web App User role (
roles/iap.httpsResourceAccessor) on the backend service of your Global External Application Load Balancer. -
To access the IAP-protected service from code impersonating a service account, an ID token signed issues for this one needs to be obtained. The key is to generate an ID token with the correct audience. The audience for an IAP-protected resource is the OAuth 2.0 Client ID that IAP uses.
To try out that programmatic access works for this particular service do the following you can run the command returned as output.
-
Variables
| name | description | type | required | default |
|---|---|---|---|---|
| project_id | Project ID. | string |
✓ | |
| region | Region. | string |
✓ | |
| support_email | Support email for IAP brand. | string |
✓ | |
| _testing | Populate this variable to avoid triggering the data source. | object({…}) |
null |
|
| accessors | List of identities able to access the service via IAP (e.g. group:mygroup@myorg.com). | list(string) |
[] |
|
| impersonators | List of identities able to impersonate the service account for programmatica access. | list(string) |
[] |
Outputs
| name | description | sensitive |
|---|---|---|
| application_service_account_email | Application service account email. | |
| command | Command. | |
| oauth2_client_id | OAuth client ID. | |
| url | URL to access service exposed by IAP. |
Tests
module "test" {
source = "./fabric/modules/net-lb-app-ext/recipe-cloud-run-iap"
project_id = "project-1"
_testing = {
name = "project-1"
number = 1234567890
}
region = "europe-west1"
support_email = "mygroup1@myorg.com"
accessors = [
"group:mygroup2@myorg.com"
]
impersonators = [
"group:mygroup3@myorg.com"
]
}
# tftest modules=6 resources=24
