All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.gcp.compute.kotlin.RegionUrlMapArgs.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 8.10.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.compute.kotlin

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.compute.RegionUrlMapArgs.builder
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapDefaultRouteActionArgs
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapDefaultRouteActionArgsBuilder
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapDefaultUrlRedirectArgs
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapDefaultUrlRedirectArgsBuilder
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapHostRuleArgs
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapHostRuleArgsBuilder
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapPathMatcherArgs
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapPathMatcherArgsBuilder
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapTestArgs
import com.pulumi.gcp.compute.kotlin.inputs.RegionUrlMapTestArgsBuilder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * UrlMaps are used to route requests to a backend service based on rules
 * that you define for the host and path of an incoming URL.
 * ## Example Usage
 * ### Region Url Map Basic
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     region: "us-central1",
 *     name: "health-check",
 *     checkIntervalSec: 1,
 *     timeoutSec: 1,
 *     httpHealthCheck: {
 *         port: 80,
 *         requestPath: "/",
 *     },
 * });
 * const login = new gcp.compute.RegionBackendService("login", {
 *     region: "us-central1",
 *     name: "login",
 *     protocol: "HTTP",
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     region: "us-central1",
 *     name: "home",
 *     protocol: "HTTP",
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     region: "us-central1",
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultService: home.id,
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         pathRules: [
 *             {
 *                 paths: ["/home"],
 *                 service: home.id,
 *             },
 *             {
 *                 paths: ["/login"],
 *                 service: login.id,
 *             },
 *         ],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     region="us-central1",
 *     name="health-check",
 *     check_interval_sec=1,
 *     timeout_sec=1,
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *         request_path="/",
 *     ))
 * login = gcp.compute.RegionBackendService("login",
 *     region="us-central1",
 *     name="login",
 *     protocol="HTTP",
 *     load_balancing_scheme="INTERNAL_MANAGED",
 *     timeout_sec=10,
 *     health_checks=default.id)
 * home = gcp.compute.RegionBackendService("home",
 *     region="us-central1",
 *     name="home",
 *     protocol="HTTP",
 *     load_balancing_scheme="INTERNAL_MANAGED",
 *     timeout_sec=10,
 *     health_checks=default.id)
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     region="us-central1",
 *     name="regionurlmap",
 *     description="a description",
 *     default_service=home.id,
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         path_rules=[
 *             gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *                 paths=["/home"],
 *                 service=home.id,
 *             ),
 *             gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *                 paths=["/login"],
 *                 service=login.id,
 *             ),
 *         ],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Region = "us-central1",
 *         Name = "health-check",
 *         CheckIntervalSec = 1,
 *         TimeoutSec = 1,
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *             RequestPath = "/",
 *         },
 *     });
 *     var login = new Gcp.Compute.RegionBackendService("login", new()
 *     {
 *         Region = "us-central1",
 *         Name = "login",
 *         Protocol = "HTTP",
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Region = "us-central1",
 *         Name = "home",
 *         Protocol = "HTTP",
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Region = "us-central1",
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultService = home.Id,
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 PathRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/home",
 *                         },
 *                         Service = home.Id,
 *                     },
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/login",
 *                         },
 *                         Service = login.Id,
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Region:           pulumi.String("us-central1"),
 * 			Name:             pulumi.String("health-check"),
 * 			CheckIntervalSec: pulumi.Int(1),
 * 			TimeoutSec:       pulumi.Int(1),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port:        pulumi.Int(80),
 * 				RequestPath: pulumi.String("/"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		login, err := compute.NewRegionBackendService(ctx, "login", &compute.RegionBackendServiceArgs{
 * 			Region:              pulumi.String("us-central1"),
 * 			Name:                pulumi.String("login"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Region:              pulumi.String("us-central1"),
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Region:         pulumi.String("us-central1"),
 * 			Name:           pulumi.String("regionurlmap"),
 * 			Description:    pulumi.String("a description"),
 * 			DefaultService: home.ID(),
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					PathRules: compute.RegionUrlMapPathMatcherPathRuleArray{
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/home"),
 * 							},
 * 							Service: home.ID(),
 * 						},
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/login"),
 * 							},
 * 							Service: login.ID(),
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .region("us-central1")
 *             .name("health-check")
 *             .checkIntervalSec(1)
 *             .timeoutSec(1)
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .requestPath("/")
 *                 .build())
 *             .build());
 *         var login = new RegionBackendService("login", RegionBackendServiceArgs.builder()
 *             .region("us-central1")
 *             .name("login")
 *             .protocol("HTTP")
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .region("us-central1")
 *             .name("home")
 *             .protocol("HTTP")
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .region("us-central1")
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultService(home.id())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .pathRules(
 *                     RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                         .paths("/home")
 *                         .service(home.id())
 *                         .build(),
 *                     RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                         .paths("/login")
 *                         .service(login.id())
 *                         .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       region: us-central1
 *       name: regionurlmap
 *       description: a description
 *       defaultService: ${home.id}
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           pathRules:
 *             - paths:
 *                 - /home
 *               service: ${home.id}
 *             - paths:
 *                 - /login
 *               service: ${login.id}
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   login:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       region: us-central1
 *       name: login
 *       protocol: HTTP
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       region: us-central1
 *       name: home
 *       protocol: HTTP
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       region: us-central1
 *       name: health-check
 *       checkIntervalSec: 1
 *       timeoutSec: 1
 *       httpHealthCheck:
 *         port: 80
 *         requestPath: /
 * ```
 * 
 * ### Region Url Map Default Route Action
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     region: "us-central1",
 *     name: "health-check",
 *     checkIntervalSec: 1,
 *     timeoutSec: 1,
 *     httpHealthCheck: {
 *         port: 80,
 *         requestPath: "/",
 *     },
 * });
 * const login = new gcp.compute.RegionBackendService("login", {
 *     region: "us-central1",
 *     name: "login",
 *     protocol: "HTTP",
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     region: "us-central1",
 *     name: "home",
 *     protocol: "HTTP",
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     region: "us-central1",
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultRouteAction: {
 *         retryPolicy: {
 *             retryConditions: [
 *                 "5xx",
 *                 "gateway-error",
 *             ],
 *             numRetries: 3,
 *             perTryTimeout: {
 *                 seconds: "0",
 *                 nanos: 500,
 *             },
 *         },
 *         requestMirrorPolicy: {
 *             backendService: home.id,
 *         },
 *         weightedBackendServices: [
 *             {
 *                 backendService: login.id,
 *                 weight: 200,
 *                 headerAction: {
 *                     requestHeadersToAdds: [{
 *                         headerName: "foo-request-1",
 *                         headerValue: "bar",
 *                         replace: true,
 *                     }],
 *                     requestHeadersToRemoves: ["fizz"],
 *                     responseHeadersToAdds: [{
 *                         headerName: "foo-response-1",
 *                         headerValue: "bar",
 *                         replace: true,
 *                     }],
 *                     responseHeadersToRemoves: ["buzz"],
 *                 },
 *             },
 *             {
 *                 backendService: home.id,
 *                 weight: 100,
 *                 headerAction: {
 *                     requestHeadersToAdds: [
 *                         {
 *                             headerName: "foo-request-1",
 *                             headerValue: "bar",
 *                             replace: true,
 *                         },
 *                         {
 *                             headerName: "foo-request-2",
 *                             headerValue: "bar",
 *                             replace: true,
 *                         },
 *                     ],
 *                     requestHeadersToRemoves: ["fizz"],
 *                     responseHeadersToAdds: [
 *                         {
 *                             headerName: "foo-response-2",
 *                             headerValue: "bar",
 *                             replace: true,
 *                         },
 *                         {
 *                             headerName: "foo-response-1",
 *                             headerValue: "bar",
 *                             replace: true,
 *                         },
 *                     ],
 *                     responseHeadersToRemoves: ["buzz"],
 *                 },
 *             },
 *         ],
 *         urlRewrite: {
 *             hostRewrite: "dev.example.com",
 *             pathPrefixRewrite: "/v1/api/",
 *         },
 *         corsPolicy: {
 *             disabled: false,
 *             allowCredentials: true,
 *             allowHeaders: ["foobar"],
 *             allowMethods: [
 *                 "GET",
 *                 "POST",
 *             ],
 *             allowOrigins: ["example.com"],
 *             exposeHeaders: ["foobar"],
 *             maxAge: 60,
 *         },
 *         faultInjectionPolicy: {
 *             delay: {
 *                 fixedDelay: {
 *                     seconds: "0",
 *                     nanos: 500,
 *                 },
 *                 percentage: 0.5,
 *             },
 *             abort: {
 *                 httpStatus: 500,
 *                 percentage: 0.5,
 *             },
 *         },
 *         timeout: {
 *             seconds: "0",
 *             nanos: 500,
 *         },
 *     },
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         pathRules: [
 *             {
 *                 paths: ["/home"],
 *                 service: home.id,
 *             },
 *             {
 *                 paths: ["/login"],
 *                 service: login.id,
 *             },
 *         ],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     region="us-central1",
 *     name="health-check",
 *     check_interval_sec=1,
 *     timeout_sec=1,
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *         request_path="/",
 *     ))
 * login = gcp.compute.RegionBackendService("login",
 *     region="us-central1",
 *     name="login",
 *     protocol="HTTP",
 *     load_balancing_scheme="INTERNAL_MANAGED",
 *     timeout_sec=10,
 *     health_checks=default.id)
 * home = gcp.compute.RegionBackendService("home",
 *     region="us-central1",
 *     name="home",
 *     protocol="HTTP",
 *     load_balancing_scheme="INTERNAL_MANAGED",
 *     timeout_sec=10,
 *     health_checks=default.id)
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     region="us-central1",
 *     name="regionurlmap",
 *     description="a description",
 *     default_route_action=gcp.compute.RegionUrlMapDefaultRouteActionArgs(
 *         retry_policy=gcp.compute.RegionUrlMapDefaultRouteActionRetryPolicyArgs(
 *             retry_conditions=[
 *                 "5xx",
 *                 "gateway-error",
 *             ],
 *             num_retries=3,
 *             per_try_timeout=gcp.compute.RegionUrlMapDefaultRouteActionRetryPolicyPerTryTimeoutArgs(
 *                 seconds="0",
 *                 nanos=500,
 *             ),
 *         ),
 *         request_mirror_policy=gcp.compute.RegionUrlMapDefaultRouteActionRequestMirrorPolicyArgs(
 *             backend_service=home.id,
 *         ),
 *         weighted_backend_services=[
 *             gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs(
 *                 backend_service=login.id,
 *                 weight=200,
 *                 header_action=gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs(
 *                     request_headers_to_adds=[gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs(
 *                         header_name="foo-request-1",
 *                         header_value="bar",
 *                         replace=True,
 *                     )],
 *                     request_headers_to_removes=["fizz"],
 *                     response_headers_to_adds=[gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs(
 *                         header_name="foo-response-1",
 *                         header_value="bar",
 *                         replace=True,
 *                     )],
 *                     response_headers_to_removes=["buzz"],
 *                 ),
 *             ),
 *             gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs(
 *                 backend_service=home.id,
 *                 weight=100,
 *                 header_action=gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs(
 *                     request_headers_to_adds=[
 *                         gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs(
 *                             header_name="foo-request-1",
 *                             header_value="bar",
 *                             replace=True,
 *                         ),
 *                         gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs(
 *                             header_name="foo-request-2",
 *                             header_value="bar",
 *                             replace=True,
 *                         ),
 *                     ],
 *                     request_headers_to_removes=["fizz"],
 *                     response_headers_to_adds=[
 *                         gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs(
 *                             header_name="foo-response-2",
 *                             header_value="bar",
 *                             replace=True,
 *                         ),
 *                         gcp.compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs(
 *                             header_name="foo-response-1",
 *                             header_value="bar",
 *                             replace=True,
 *                         ),
 *                     ],
 *                     response_headers_to_removes=["buzz"],
 *                 ),
 *             ),
 *         ],
 *         url_rewrite=gcp.compute.RegionUrlMapDefaultRouteActionUrlRewriteArgs(
 *             host_rewrite="dev.example.com",
 *             path_prefix_rewrite="/v1/api/",
 *         ),
 *         cors_policy=gcp.compute.RegionUrlMapDefaultRouteActionCorsPolicyArgs(
 *             disabled=False,
 *             allow_credentials=True,
 *             allow_headers=["foobar"],
 *             allow_methods=[
 *                 "GET",
 *                 "POST",
 *             ],
 *             allow_origins=["example.com"],
 *             expose_headers=["foobar"],
 *             max_age=60,
 *         ),
 *         fault_injection_policy=gcp.compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyArgs(
 *             delay=gcp.compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayArgs(
 *                 fixed_delay=gcp.compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayFixedDelayArgs(
 *                     seconds="0",
 *                     nanos=500,
 *                 ),
 *                 percentage=0.5,
 *             ),
 *             abort=gcp.compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyAbortArgs(
 *                 http_status=500,
 *                 percentage=0.5,
 *             ),
 *         ),
 *         timeout=gcp.compute.RegionUrlMapDefaultRouteActionTimeoutArgs(
 *             seconds="0",
 *             nanos=500,
 *         ),
 *     ),
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         path_rules=[
 *             gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *                 paths=["/home"],
 *                 service=home.id,
 *             ),
 *             gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *                 paths=["/login"],
 *                 service=login.id,
 *             ),
 *         ],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Region = "us-central1",
 *         Name = "health-check",
 *         CheckIntervalSec = 1,
 *         TimeoutSec = 1,
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *             RequestPath = "/",
 *         },
 *     });
 *     var login = new Gcp.Compute.RegionBackendService("login", new()
 *     {
 *         Region = "us-central1",
 *         Name = "login",
 *         Protocol = "HTTP",
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Region = "us-central1",
 *         Name = "home",
 *         Protocol = "HTTP",
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Region = "us-central1",
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultRouteAction = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionArgs
 *         {
 *             RetryPolicy = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionRetryPolicyArgs
 *             {
 *                 RetryConditions = new[]
 *                 {
 *                     "5xx",
 *                     "gateway-error",
 *                 },
 *                 NumRetries = 3,
 *                 PerTryTimeout = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionRetryPolicyPerTryTimeoutArgs
 *                 {
 *                     Seconds = "0",
 *                     Nanos = 500,
 *                 },
 *             },
 *             RequestMirrorPolicy = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionRequestMirrorPolicyArgs
 *             {
 *                 BackendService = home.Id,
 *             },
 *             WeightedBackendServices = new[]
 *             {
 *                 new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs
 *                 {
 *                     BackendService = login.Id,
 *                     Weight = 200,
 *                     HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs
 *                     {
 *                         RequestHeadersToAdds = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-request-1",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                         },
 *                         RequestHeadersToRemoves = new[]
 *                         {
 *                             "fizz",
 *                         },
 *                         ResponseHeadersToAdds = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-response-1",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                         },
 *                         ResponseHeadersToRemoves = new[]
 *                         {
 *                             "buzz",
 *                         },
 *                     },
 *                 },
 *                 new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs
 *                 {
 *                     BackendService = home.Id,
 *                     Weight = 100,
 *                     HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs
 *                     {
 *                         RequestHeadersToAdds = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-request-1",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-request-2",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                         },
 *                         RequestHeadersToRemoves = new[]
 *                         {
 *                             "fizz",
 *                         },
 *                         ResponseHeadersToAdds = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-response-2",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                             new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs
 *                             {
 *                                 HeaderName = "foo-response-1",
 *                                 HeaderValue = "bar",
 *                                 Replace = true,
 *                             },
 *                         },
 *                         ResponseHeadersToRemoves = new[]
 *                         {
 *                             "buzz",
 *                         },
 *                     },
 *                 },
 *             },
 *             UrlRewrite = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionUrlRewriteArgs
 *             {
 *                 HostRewrite = "dev.example.com",
 *                 PathPrefixRewrite = "/v1/api/",
 *             },
 *             CorsPolicy = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionCorsPolicyArgs
 *             {
 *                 Disabled = false,
 *                 AllowCredentials = true,
 *                 AllowHeaders = new[]
 *                 {
 *                     "foobar",
 *                 },
 *                 AllowMethods = new[]
 *                 {
 *                     "GET",
 *                     "POST",
 *                 },
 *                 AllowOrigins = new[]
 *                 {
 *                     "example.com",
 *                 },
 *                 ExposeHeaders = new[]
 *                 {
 *                     "foobar",
 *                 },
 *                 MaxAge = 60,
 *             },
 *             FaultInjectionPolicy = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyArgs
 *             {
 *                 Delay = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayArgs
 *                 {
 *                     FixedDelay = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayFixedDelayArgs
 *                     {
 *                         Seconds = "0",
 *                         Nanos = 500,
 *                     },
 *                     Percentage = 0.5,
 *                 },
 *                 Abort = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyAbortArgs
 *                 {
 *                     HttpStatus = 500,
 *                     Percentage = 0.5,
 *                 },
 *             },
 *             Timeout = new Gcp.Compute.Inputs.RegionUrlMapDefaultRouteActionTimeoutArgs
 *             {
 *                 Seconds = "0",
 *                 Nanos = 500,
 *             },
 *         },
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 PathRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/home",
 *                         },
 *                         Service = home.Id,
 *                     },
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/login",
 *                         },
 *                         Service = login.Id,
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Region:           pulumi.String("us-central1"),
 * 			Name:             pulumi.String("health-check"),
 * 			CheckIntervalSec: pulumi.Int(1),
 * 			TimeoutSec:       pulumi.Int(1),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port:        pulumi.Int(80),
 * 				RequestPath: pulumi.String("/"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		login, err := compute.NewRegionBackendService(ctx, "login", &compute.RegionBackendServiceArgs{
 * 			Region:              pulumi.String("us-central1"),
 * 			Name:                pulumi.String("login"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Region:              pulumi.String("us-central1"),
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Region:      pulumi.String("us-central1"),
 * 			Name:        pulumi.String("regionurlmap"),
 * 			Description: pulumi.String("a description"),
 * 			DefaultRouteAction: &compute.RegionUrlMapDefaultRouteActionArgs{
 * 				RetryPolicy: &compute.RegionUrlMapDefaultRouteActionRetryPolicyArgs{
 * 					RetryConditions: pulumi.StringArray{
 * 						pulumi.String("5xx"),
 * 						pulumi.String("gateway-error"),
 * 					},
 * 					NumRetries: pulumi.Int(3),
 * 					PerTryTimeout: &compute.RegionUrlMapDefaultRouteActionRetryPolicyPerTryTimeoutArgs{
 * 						Seconds: pulumi.String("0"),
 * 						Nanos:   pulumi.Int(500),
 * 					},
 * 				},
 * 				RequestMirrorPolicy: &compute.RegionUrlMapDefaultRouteActionRequestMirrorPolicyArgs{
 * 					BackendService: home.ID(),
 * 				},
 * 				WeightedBackendServices: compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceArray{
 * 					&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs{
 * 						BackendService: login.ID(),
 * 						Weight:         pulumi.Int(200),
 * 						HeaderAction: &compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs{
 * 							RequestHeadersToAdds: compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArray{
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-request-1"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 							},
 * 							RequestHeadersToRemoves: pulumi.StringArray{
 * 								pulumi.String("fizz"),
 * 							},
 * 							ResponseHeadersToAdds: compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArray{
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-response-1"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 							},
 * 							ResponseHeadersToRemoves: pulumi.StringArray{
 * 								pulumi.String("buzz"),
 * 							},
 * 						},
 * 					},
 * 					&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs{
 * 						BackendService: home.ID(),
 * 						Weight:         pulumi.Int(100),
 * 						HeaderAction: &compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs{
 * 							RequestHeadersToAdds: compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArray{
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-request-1"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-request-2"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 							},
 * 							RequestHeadersToRemoves: pulumi.StringArray{
 * 								pulumi.String("fizz"),
 * 							},
 * 							ResponseHeadersToAdds: compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArray{
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-response-2"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 								&compute.RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs{
 * 									HeaderName:  pulumi.String("foo-response-1"),
 * 									HeaderValue: pulumi.String("bar"),
 * 									Replace:     pulumi.Bool(true),
 * 								},
 * 							},
 * 							ResponseHeadersToRemoves: pulumi.StringArray{
 * 								pulumi.String("buzz"),
 * 							},
 * 						},
 * 					},
 * 				},
 * 				UrlRewrite: &compute.RegionUrlMapDefaultRouteActionUrlRewriteArgs{
 * 					HostRewrite:       pulumi.String("dev.example.com"),
 * 					PathPrefixRewrite: pulumi.String("/v1/api/"),
 * 				},
 * 				CorsPolicy: &compute.RegionUrlMapDefaultRouteActionCorsPolicyArgs{
 * 					Disabled:         pulumi.Bool(false),
 * 					AllowCredentials: pulumi.Bool(true),
 * 					AllowHeaders: pulumi.StringArray{
 * 						pulumi.String("foobar"),
 * 					},
 * 					AllowMethods: pulumi.StringArray{
 * 						pulumi.String("GET"),
 * 						pulumi.String("POST"),
 * 					},
 * 					AllowOrigins: pulumi.StringArray{
 * 						pulumi.String("example.com"),
 * 					},
 * 					ExposeHeaders: pulumi.StringArray{
 * 						pulumi.String("foobar"),
 * 					},
 * 					MaxAge: pulumi.Int(60),
 * 				},
 * 				FaultInjectionPolicy: &compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyArgs{
 * 					Delay: &compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayArgs{
 * 						FixedDelay: &compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayFixedDelayArgs{
 * 							Seconds: pulumi.String("0"),
 * 							Nanos:   pulumi.Int(500),
 * 						},
 * 						Percentage: pulumi.Float64(0.5),
 * 					},
 * 					Abort: &compute.RegionUrlMapDefaultRouteActionFaultInjectionPolicyAbortArgs{
 * 						HttpStatus: pulumi.Int(500),
 * 						Percentage: pulumi.Float64(0.5),
 * 					},
 * 				},
 * 				Timeout: &compute.RegionUrlMapDefaultRouteActionTimeoutArgs{
 * 					Seconds: pulumi.String("0"),
 * 					Nanos:   pulumi.Int(500),
 * 				},
 * 			},
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					PathRules: compute.RegionUrlMapPathMatcherPathRuleArray{
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/home"),
 * 							},
 * 							Service: home.ID(),
 * 						},
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/login"),
 * 							},
 * 							Service: login.ID(),
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionRetryPolicyArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionRetryPolicyPerTryTimeoutArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionRequestMirrorPolicyArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionUrlRewriteArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionCorsPolicyArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayFixedDelayArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionFaultInjectionPolicyAbortArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapDefaultRouteActionTimeoutArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .region("us-central1")
 *             .name("health-check")
 *             .checkIntervalSec(1)
 *             .timeoutSec(1)
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .requestPath("/")
 *                 .build())
 *             .build());
 *         var login = new RegionBackendService("login", RegionBackendServiceArgs.builder()
 *             .region("us-central1")
 *             .name("login")
 *             .protocol("HTTP")
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .region("us-central1")
 *             .name("home")
 *             .protocol("HTTP")
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .region("us-central1")
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultRouteAction(RegionUrlMapDefaultRouteActionArgs.builder()
 *                 .retryPolicy(RegionUrlMapDefaultRouteActionRetryPolicyArgs.builder()
 *                     .retryConditions(
 *                         "5xx",
 *                         "gateway-error")
 *                     .numRetries(3)
 *                     .perTryTimeout(RegionUrlMapDefaultRouteActionRetryPolicyPerTryTimeoutArgs.builder()
 *                         .seconds(0)
 *                         .nanos(500)
 *                         .build())
 *                     .build())
 *                 .requestMirrorPolicy(RegionUrlMapDefaultRouteActionRequestMirrorPolicyArgs.builder()
 *                     .backendService(home.id())
 *                     .build())
 *                 .weightedBackendServices(
 *                     RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs.builder()
 *                         .backendService(login.id())
 *                         .weight(200)
 *                         .headerAction(RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs.builder()
 *                             .requestHeadersToAdds(RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs.builder()
 *                                 .headerName("foo-request-1")
 *                                 .headerValue("bar")
 *                                 .replace(true)
 *                                 .build())
 *                             .requestHeadersToRemoves("fizz")
 *                             .responseHeadersToAdds(RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs.builder()
 *                                 .headerName("foo-response-1")
 *                                 .headerValue("bar")
 *                                 .replace(true)
 *                                 .build())
 *                             .responseHeadersToRemoves("buzz")
 *                             .build())
 *                         .build(),
 *                     RegionUrlMapDefaultRouteActionWeightedBackendServiceArgs.builder()
 *                         .backendService(home.id())
 *                         .weight(100)
 *                         .headerAction(RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionArgs.builder()
 *                             .requestHeadersToAdds(
 *                                 RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs.builder()
 *                                     .headerName("foo-request-1")
 *                                     .headerValue("bar")
 *                                     .replace(true)
 *                                     .build(),
 *                                 RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs.builder()
 *                                     .headerName("foo-request-2")
 *                                     .headerValue("bar")
 *                                     .replace(true)
 *                                     .build())
 *                             .requestHeadersToRemoves("fizz")
 *                             .responseHeadersToAdds(
 *                                 RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs.builder()
 *                                     .headerName("foo-response-2")
 *                                     .headerValue("bar")
 *                                     .replace(true)
 *                                     .build(),
 *                                 RegionUrlMapDefaultRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs.builder()
 *                                     .headerName("foo-response-1")
 *                                     .headerValue("bar")
 *                                     .replace(true)
 *                                     .build())
 *                             .responseHeadersToRemoves("buzz")
 *                             .build())
 *                         .build())
 *                 .urlRewrite(RegionUrlMapDefaultRouteActionUrlRewriteArgs.builder()
 *                     .hostRewrite("dev.example.com")
 *                     .pathPrefixRewrite("/v1/api/")
 *                     .build())
 *                 .corsPolicy(RegionUrlMapDefaultRouteActionCorsPolicyArgs.builder()
 *                     .disabled(false)
 *                     .allowCredentials(true)
 *                     .allowHeaders("foobar")
 *                     .allowMethods(
 *                         "GET",
 *                         "POST")
 *                     .allowOrigins("example.com")
 *                     .exposeHeaders("foobar")
 *                     .maxAge(60)
 *                     .build())
 *                 .faultInjectionPolicy(RegionUrlMapDefaultRouteActionFaultInjectionPolicyArgs.builder()
 *                     .delay(RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayArgs.builder()
 *                         .fixedDelay(RegionUrlMapDefaultRouteActionFaultInjectionPolicyDelayFixedDelayArgs.builder()
 *                             .seconds(0)
 *                             .nanos(500)
 *                             .build())
 *                         .percentage(0.5)
 *                         .build())
 *                     .abort(RegionUrlMapDefaultRouteActionFaultInjectionPolicyAbortArgs.builder()
 *                         .httpStatus(500)
 *                         .percentage(0.5)
 *                         .build())
 *                     .build())
 *                 .timeout(RegionUrlMapDefaultRouteActionTimeoutArgs.builder()
 *                     .seconds(0)
 *                     .nanos(500)
 *                     .build())
 *                 .build())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .pathRules(
 *                     RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                         .paths("/home")
 *                         .service(home.id())
 *                         .build(),
 *                     RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                         .paths("/login")
 *                         .service(login.id())
 *                         .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       region: us-central1
 *       name: regionurlmap
 *       description: a description
 *       defaultRouteAction:
 *         retryPolicy:
 *           retryConditions:
 *             - 5xx
 *             - gateway-error
 *           numRetries: 3
 *           perTryTimeout:
 *             seconds: 0
 *             nanos: 500
 *         requestMirrorPolicy:
 *           backendService: ${home.id}
 *         weightedBackendServices:
 *           - backendService: ${login.id}
 *             weight: 200
 *             headerAction:
 *               requestHeadersToAdds:
 *                 - headerName: foo-request-1
 *                   headerValue: bar
 *                   replace: true
 *               requestHeadersToRemoves:
 *                 - fizz
 *               responseHeadersToAdds:
 *                 - headerName: foo-response-1
 *                   headerValue: bar
 *                   replace: true
 *               responseHeadersToRemoves:
 *                 - buzz
 *           - backendService: ${home.id}
 *             weight: 100
 *             headerAction:
 *               requestHeadersToAdds:
 *                 - headerName: foo-request-1
 *                   headerValue: bar
 *                   replace: true
 *                 - headerName: foo-request-2
 *                   headerValue: bar
 *                   replace: true
 *               requestHeadersToRemoves:
 *                 - fizz
 *               responseHeadersToAdds:
 *                 - headerName: foo-response-2
 *                   headerValue: bar
 *                   replace: true
 *                 - headerName: foo-response-1
 *                   headerValue: bar
 *                   replace: true
 *               responseHeadersToRemoves:
 *                 - buzz
 *         urlRewrite:
 *           hostRewrite: dev.example.com
 *           pathPrefixRewrite: /v1/api/
 *         corsPolicy:
 *           disabled: false
 *           allowCredentials: true
 *           allowHeaders:
 *             - foobar
 *           allowMethods:
 *             - GET
 *             - POST
 *           allowOrigins:
 *             - example.com
 *           exposeHeaders:
 *             - foobar
 *           maxAge: 60
 *         faultInjectionPolicy:
 *           delay:
 *             fixedDelay:
 *               seconds: 0
 *               nanos: 500
 *             percentage: 0.5
 *           abort:
 *             httpStatus: 500
 *             percentage: 0.5
 *         timeout:
 *           seconds: 0
 *           nanos: 500
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           pathRules:
 *             - paths:
 *                 - /home
 *               service: ${home.id}
 *             - paths:
 *                 - /login
 *               service: ${login.id}
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   login:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       region: us-central1
 *       name: login
 *       protocol: HTTP
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       region: us-central1
 *       name: home
 *       protocol: HTTP
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       region: us-central1
 *       name: health-check
 *       checkIntervalSec: 1
 *       timeoutSec: 1
 *       httpHealthCheck:
 *         port: 80
 *         requestPath: /
 * ```
 * 
 * ### Region Url Map L7 Ilb Path
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     name: "health-check",
 *     httpHealthCheck: {
 *         port: 80,
 *     },
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     name: "home",
 *     protocol: "HTTP",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultService: home.id,
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         pathRules: [{
 *             paths: ["/home"],
 *             routeAction: {
 *                 corsPolicy: {
 *                     allowCredentials: true,
 *                     allowHeaders: ["Allowed content"],
 *                     allowMethods: ["GET"],
 *                     allowOrigins: ["Allowed origin"],
 *                     exposeHeaders: ["Exposed header"],
 *                     maxAge: 30,
 *                     disabled: false,
 *                 },
 *                 faultInjectionPolicy: {
 *                     abort: {
 *                         httpStatus: 234,
 *                         percentage: 5.6,
 *                     },
 *                     delay: {
 *                         fixedDelay: {
 *                             seconds: "0",
 *                             nanos: 50000,
 *                         },
 *                         percentage: 7.8,
 *                     },
 *                 },
 *                 requestMirrorPolicy: {
 *                     backendService: home.id,
 *                 },
 *                 retryPolicy: {
 *                     numRetries: 4,
 *                     perTryTimeout: {
 *                         seconds: "30",
 *                     },
 *                     retryConditions: [
 *                         "5xx",
 *                         "deadline-exceeded",
 *                     ],
 *                 },
 *                 timeout: {
 *                     seconds: "20",
 *                     nanos: 750000000,
 *                 },
 *                 urlRewrite: {
 *                     hostRewrite: "dev.example.com",
 *                     pathPrefixRewrite: "/v1/api/",
 *                 },
 *                 weightedBackendServices: [{
 *                     backendService: home.id,
 *                     weight: 400,
 *                     headerAction: {
 *                         requestHeadersToRemoves: ["RemoveMe"],
 *                         requestHeadersToAdds: [{
 *                             headerName: "AddMe",
 *                             headerValue: "MyValue",
 *                             replace: true,
 *                         }],
 *                         responseHeadersToRemoves: ["RemoveMe"],
 *                         responseHeadersToAdds: [{
 *                             headerName: "AddMe",
 *                             headerValue: "MyValue",
 *                             replace: false,
 *                         }],
 *                     },
 *                 }],
 *             },
 *         }],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     name="health-check",
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *     ))
 * home = gcp.compute.RegionBackendService("home",
 *     name="home",
 *     protocol="HTTP",
 *     timeout_sec=10,
 *     health_checks=default.id,
 *     load_balancing_scheme="INTERNAL_MANAGED")
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     name="regionurlmap",
 *     description="a description",
 *     default_service=home.id,
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         path_rules=[gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *             paths=["/home"],
 *             route_action=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionArgs(
 *                 cors_policy=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionCorsPolicyArgs(
 *                     allow_credentials=True,
 *                     allow_headers=["Allowed content"],
 *                     allow_methods=["GET"],
 *                     allow_origins=["Allowed origin"],
 *                     expose_headers=["Exposed header"],
 *                     max_age=30,
 *                     disabled=False,
 *                 ),
 *                 fault_injection_policy=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyArgs(
 *                     abort=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyAbortArgs(
 *                         http_status=234,
 *                         percentage=5.6,
 *                     ),
 *                     delay=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayArgs(
 *                         fixed_delay=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayFixedDelayArgs(
 *                             seconds="0",
 *                             nanos=50000,
 *                         ),
 *                         percentage=7.8,
 *                     ),
 *                 ),
 *                 request_mirror_policy=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionRequestMirrorPolicyArgs(
 *                     backend_service=home.id,
 *                 ),
 *                 retry_policy=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs(
 *                     num_retries=4,
 *                     per_try_timeout=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs(
 *                         seconds="30",
 *                     ),
 *                     retry_conditions=[
 *                         "5xx",
 *                         "deadline-exceeded",
 *                     ],
 *                 ),
 *                 timeout=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs(
 *                     seconds="20",
 *                     nanos=750000000,
 *                 ),
 *                 url_rewrite=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs(
 *                     host_rewrite="dev.example.com",
 *                     path_prefix_rewrite="/v1/api/",
 *                 ),
 *                 weighted_backend_services=[gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs(
 *                     backend_service=home.id,
 *                     weight=400,
 *                     header_action=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs(
 *                         request_headers_to_removes=["RemoveMe"],
 *                         request_headers_to_adds=[gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs(
 *                             header_name="AddMe",
 *                             header_value="MyValue",
 *                             replace=True,
 *                         )],
 *                         response_headers_to_removes=["RemoveMe"],
 *                         response_headers_to_adds=[gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs(
 *                             header_name="AddMe",
 *                             header_value="MyValue",
 *                             replace=False,
 *                         )],
 *                     ),
 *                 )],
 *             ),
 *         )],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Name = "health-check",
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *         },
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Name = "home",
 *         Protocol = "HTTP",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultService = home.Id,
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 PathRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/home",
 *                         },
 *                         RouteAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionArgs
 *                         {
 *                             CorsPolicy = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionCorsPolicyArgs
 *                             {
 *                                 AllowCredentials = true,
 *                                 AllowHeaders = new[]
 *                                 {
 *                                     "Allowed content",
 *                                 },
 *                                 AllowMethods = new[]
 *                                 {
 *                                     "GET",
 *                                 },
 *                                 AllowOrigins = new[]
 *                                 {
 *                                     "Allowed origin",
 *                                 },
 *                                 ExposeHeaders = new[]
 *                                 {
 *                                     "Exposed header",
 *                                 },
 *                                 MaxAge = 30,
 *                                 Disabled = false,
 *                             },
 *                             FaultInjectionPolicy = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyArgs
 *                             {
 *                                 Abort = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyAbortArgs
 *                                 {
 *                                     HttpStatus = 234,
 *                                     Percentage = 5.6,
 *                                 },
 *                                 Delay = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayArgs
 *                                 {
 *                                     FixedDelay = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayFixedDelayArgs
 *                                     {
 *                                         Seconds = "0",
 *                                         Nanos = 50000,
 *                                     },
 *                                     Percentage = 7.8,
 *                                 },
 *                             },
 *                             RequestMirrorPolicy = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionRequestMirrorPolicyArgs
 *                             {
 *                                 BackendService = home.Id,
 *                             },
 *                             RetryPolicy = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs
 *                             {
 *                                 NumRetries = 4,
 *                                 PerTryTimeout = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs
 *                                 {
 *                                     Seconds = "30",
 *                                 },
 *                                 RetryConditions = new[]
 *                                 {
 *                                     "5xx",
 *                                     "deadline-exceeded",
 *                                 },
 *                             },
 *                             Timeout = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs
 *                             {
 *                                 Seconds = "20",
 *                                 Nanos = 750000000,
 *                             },
 *                             UrlRewrite = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs
 *                             {
 *                                 HostRewrite = "dev.example.com",
 *                                 PathPrefixRewrite = "/v1/api/",
 *                             },
 *                             WeightedBackendServices = new[]
 *                             {
 *                                 new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs
 *                                 {
 *                                     BackendService = home.Id,
 *                                     Weight = 400,
 *                                     HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs
 *                                     {
 *                                         RequestHeadersToRemoves = new[]
 *                                         {
 *                                             "RemoveMe",
 *                                         },
 *                                         RequestHeadersToAdds = new[]
 *                                         {
 *                                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs
 *                                             {
 *                                                 HeaderName = "AddMe",
 *                                                 HeaderValue = "MyValue",
 *                                                 Replace = true,
 *                                             },
 *                                         },
 *                                         ResponseHeadersToRemoves = new[]
 *                                         {
 *                                             "RemoveMe",
 *                                         },
 *                                         ResponseHeadersToAdds = new[]
 *                                         {
 *                                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs
 *                                             {
 *                                                 HeaderName = "AddMe",
 *                                                 HeaderValue = "MyValue",
 *                                                 Replace = false,
 *                                             },
 *                                         },
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Name: pulumi.String("health-check"),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port: pulumi.Int(80),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Name:           pulumi.String("regionurlmap"),
 * 			Description:    pulumi.String("a description"),
 * 			DefaultService: home.ID(),
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					PathRules: compute.RegionUrlMapPathMatcherPathRuleArray{
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/home"),
 * 							},
 * 							RouteAction: &compute.RegionUrlMapPathMatcherPathRuleRouteActionArgs{
 * 								CorsPolicy: &compute.RegionUrlMapPathMatcherPathRuleRouteActionCorsPolicyArgs{
 * 									AllowCredentials: pulumi.Bool(true),
 * 									AllowHeaders: pulumi.StringArray{
 * 										pulumi.String("Allowed content"),
 * 									},
 * 									AllowMethods: pulumi.StringArray{
 * 										pulumi.String("GET"),
 * 									},
 * 									AllowOrigins: pulumi.StringArray{
 * 										pulumi.String("Allowed origin"),
 * 									},
 * 									ExposeHeaders: pulumi.StringArray{
 * 										pulumi.String("Exposed header"),
 * 									},
 * 									MaxAge:   pulumi.Int(30),
 * 									Disabled: pulumi.Bool(false),
 * 								},
 * 								FaultInjectionPolicy: &compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyArgs{
 * 									Abort: &compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyAbortArgs{
 * 										HttpStatus: pulumi.Int(234),
 * 										Percentage: pulumi.Float64(5.6),
 * 									},
 * 									Delay: &compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayArgs{
 * 										FixedDelay: &compute.RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayFixedDelayArgs{
 * 											Seconds: pulumi.String("0"),
 * 											Nanos:   pulumi.Int(50000),
 * 										},
 * 										Percentage: pulumi.Float64(7.8),
 * 									},
 * 								},
 * 								RequestMirrorPolicy: &compute.RegionUrlMapPathMatcherPathRuleRouteActionRequestMirrorPolicyArgs{
 * 									BackendService: home.ID(),
 * 								},
 * 								RetryPolicy: &compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs{
 * 									NumRetries: pulumi.Int(4),
 * 									PerTryTimeout: &compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs{
 * 										Seconds: pulumi.String("30"),
 * 									},
 * 									RetryConditions: pulumi.StringArray{
 * 										pulumi.String("5xx"),
 * 										pulumi.String("deadline-exceeded"),
 * 									},
 * 								},
 * 								Timeout: &compute.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs{
 * 									Seconds: pulumi.String("20"),
 * 									Nanos:   pulumi.Int(750000000),
 * 								},
 * 								UrlRewrite: &compute.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs{
 * 									HostRewrite:       pulumi.String("dev.example.com"),
 * 									PathPrefixRewrite: pulumi.String("/v1/api/"),
 * 								},
 * 								WeightedBackendServices: compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArray{
 * 									&compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs{
 * 										BackendService: home.ID(),
 * 										Weight:         pulumi.Int(400),
 * 										HeaderAction: &compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs{
 * 											RequestHeadersToRemoves: pulumi.StringArray{
 * 												pulumi.String("RemoveMe"),
 * 											},
 * 											RequestHeadersToAdds: compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArray{
 * 												&compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs{
 * 													HeaderName:  pulumi.String("AddMe"),
 * 													HeaderValue: pulumi.String("MyValue"),
 * 													Replace:     pulumi.Bool(true),
 * 												},
 * 											},
 * 											ResponseHeadersToRemoves: pulumi.StringArray{
 * 												pulumi.String("RemoveMe"),
 * 											},
 * 											ResponseHeadersToAdds: compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArray{
 * 												&compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs{
 * 													HeaderName:  pulumi.String("AddMe"),
 * 													HeaderValue: pulumi.String("MyValue"),
 * 													Replace:     pulumi.Bool(false),
 * 												},
 * 											},
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .name("health-check")
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .build())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .name("home")
 *             .protocol("HTTP")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultService(home.id())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .pathRules(RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                     .paths("/home")
 *                     .routeAction(RegionUrlMapPathMatcherPathRuleRouteActionArgs.builder()
 *                         .corsPolicy(RegionUrlMapPathMatcherPathRuleRouteActionCorsPolicyArgs.builder()
 *                             .allowCredentials(true)
 *                             .allowHeaders("Allowed content")
 *                             .allowMethods("GET")
 *                             .allowOrigins("Allowed origin")
 *                             .exposeHeaders("Exposed header")
 *                             .maxAge(30)
 *                             .disabled(false)
 *                             .build())
 *                         .faultInjectionPolicy(RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyArgs.builder()
 *                             .abort(RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyAbortArgs.builder()
 *                                 .httpStatus(234)
 *                                 .percentage(5.6)
 *                                 .build())
 *                             .delay(RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayArgs.builder()
 *                                 .fixedDelay(RegionUrlMapPathMatcherPathRuleRouteActionFaultInjectionPolicyDelayFixedDelayArgs.builder()
 *                                     .seconds(0)
 *                                     .nanos(50000)
 *                                     .build())
 *                                 .percentage(7.8)
 *                                 .build())
 *                             .build())
 *                         .requestMirrorPolicy(RegionUrlMapPathMatcherPathRuleRouteActionRequestMirrorPolicyArgs.builder()
 *                             .backendService(home.id())
 *                             .build())
 *                         .retryPolicy(RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs.builder()
 *                             .numRetries(4)
 *                             .perTryTimeout(RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs.builder()
 *                                 .seconds(30)
 *                                 .build())
 *                             .retryConditions(
 *                                 "5xx",
 *                                 "deadline-exceeded")
 *                             .build())
 *                         .timeout(RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs.builder()
 *                             .seconds(20)
 *                             .nanos(750000000)
 *                             .build())
 *                         .urlRewrite(RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs.builder()
 *                             .hostRewrite("dev.example.com")
 *                             .pathPrefixRewrite("/v1/api/")
 *                             .build())
 *                         .weightedBackendServices(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs.builder()
 *                             .backendService(home.id())
 *                             .weight(400)
 *                             .headerAction(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs.builder()
 *                                 .requestHeadersToRemoves("RemoveMe")
 *                                 .requestHeadersToAdds(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionRequestHeadersToAddArgs.builder()
 *                                     .headerName("AddMe")
 *                                     .headerValue("MyValue")
 *                                     .replace(true)
 *                                     .build())
 *                                 .responseHeadersToRemoves("RemoveMe")
 *                                 .responseHeadersToAdds(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs.builder()
 *                                     .headerName("AddMe")
 *                                     .headerValue("MyValue")
 *                                     .replace(false)
 *                                     .build())
 *                                 .build())
 *                             .build())
 *                         .build())
 *                     .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       name: regionurlmap
 *       description: a description
 *       defaultService: ${home.id}
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           pathRules:
 *             - paths:
 *                 - /home
 *               routeAction:
 *                 corsPolicy:
 *                   allowCredentials: true
 *                   allowHeaders:
 *                     - Allowed content
 *                   allowMethods:
 *                     - GET
 *                   allowOrigins:
 *                     - Allowed origin
 *                   exposeHeaders:
 *                     - Exposed header
 *                   maxAge: 30
 *                   disabled: false
 *                 faultInjectionPolicy:
 *                   abort:
 *                     httpStatus: 234
 *                     percentage: 5.6
 *                   delay:
 *                     fixedDelay:
 *                       seconds: 0
 *                       nanos: 50000
 *                     percentage: 7.8
 *                 requestMirrorPolicy:
 *                   backendService: ${home.id}
 *                 retryPolicy:
 *                   numRetries: 4
 *                   perTryTimeout:
 *                     seconds: 30
 *                   retryConditions:
 *                     - 5xx
 *                     - deadline-exceeded
 *                 timeout:
 *                   seconds: 20
 *                   nanos: 7.5e+08
 *                 urlRewrite:
 *                   hostRewrite: dev.example.com
 *                   pathPrefixRewrite: /v1/api/
 *                 weightedBackendServices:
 *                   - backendService: ${home.id}
 *                     weight: 400
 *                     headerAction:
 *                       requestHeadersToRemoves:
 *                         - RemoveMe
 *                       requestHeadersToAdds:
 *                         - headerName: AddMe
 *                           headerValue: MyValue
 *                           replace: true
 *                       responseHeadersToRemoves:
 *                         - RemoveMe
 *                       responseHeadersToAdds:
 *                         - headerName: AddMe
 *                           headerValue: MyValue
 *                           replace: false
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       name: home
 *       protocol: HTTP
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *       loadBalancingScheme: INTERNAL_MANAGED
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       name: health-check
 *       httpHealthCheck:
 *         port: 80
 * ```
 * 
 * ### Region Url Map L7 Ilb Path Partial
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     name: "health-check",
 *     httpHealthCheck: {
 *         port: 80,
 *     },
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     name: "home",
 *     protocol: "HTTP",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultService: home.id,
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         pathRules: [{
 *             paths: ["/home"],
 *             routeAction: {
 *                 retryPolicy: {
 *                     numRetries: 4,
 *                     perTryTimeout: {
 *                         seconds: "30",
 *                     },
 *                     retryConditions: [
 *                         "5xx",
 *                         "deadline-exceeded",
 *                     ],
 *                 },
 *                 timeout: {
 *                     seconds: "20",
 *                     nanos: 750000000,
 *                 },
 *                 urlRewrite: {
 *                     hostRewrite: "dev.example.com",
 *                     pathPrefixRewrite: "/v1/api/",
 *                 },
 *                 weightedBackendServices: [{
 *                     backendService: home.id,
 *                     weight: 400,
 *                     headerAction: {
 *                         responseHeadersToAdds: [{
 *                             headerName: "AddMe",
 *                             headerValue: "MyValue",
 *                             replace: false,
 *                         }],
 *                     },
 *                 }],
 *             },
 *         }],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     name="health-check",
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *     ))
 * home = gcp.compute.RegionBackendService("home",
 *     name="home",
 *     protocol="HTTP",
 *     timeout_sec=10,
 *     health_checks=default.id,
 *     load_balancing_scheme="INTERNAL_MANAGED")
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     name="regionurlmap",
 *     description="a description",
 *     default_service=home.id,
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         path_rules=[gcp.compute.RegionUrlMapPathMatcherPathRuleArgs(
 *             paths=["/home"],
 *             route_action=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionArgs(
 *                 retry_policy=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs(
 *                     num_retries=4,
 *                     per_try_timeout=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs(
 *                         seconds="30",
 *                     ),
 *                     retry_conditions=[
 *                         "5xx",
 *                         "deadline-exceeded",
 *                     ],
 *                 ),
 *                 timeout=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs(
 *                     seconds="20",
 *                     nanos=750000000,
 *                 ),
 *                 url_rewrite=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs(
 *                     host_rewrite="dev.example.com",
 *                     path_prefix_rewrite="/v1/api/",
 *                 ),
 *                 weighted_backend_services=[gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs(
 *                     backend_service=home.id,
 *                     weight=400,
 *                     header_action=gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs(
 *                         response_headers_to_adds=[gcp.compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs(
 *                             header_name="AddMe",
 *                             header_value="MyValue",
 *                             replace=False,
 *                         )],
 *                     ),
 *                 )],
 *             ),
 *         )],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Name = "health-check",
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *         },
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Name = "home",
 *         Protocol = "HTTP",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultService = home.Id,
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 PathRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleArgs
 *                     {
 *                         Paths = new[]
 *                         {
 *                             "/home",
 *                         },
 *                         RouteAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionArgs
 *                         {
 *                             RetryPolicy = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs
 *                             {
 *                                 NumRetries = 4,
 *                                 PerTryTimeout = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs
 *                                 {
 *                                     Seconds = "30",
 *                                 },
 *                                 RetryConditions = new[]
 *                                 {
 *                                     "5xx",
 *                                     "deadline-exceeded",
 *                                 },
 *                             },
 *                             Timeout = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs
 *                             {
 *                                 Seconds = "20",
 *                                 Nanos = 750000000,
 *                             },
 *                             UrlRewrite = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs
 *                             {
 *                                 HostRewrite = "dev.example.com",
 *                                 PathPrefixRewrite = "/v1/api/",
 *                             },
 *                             WeightedBackendServices = new[]
 *                             {
 *                                 new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs
 *                                 {
 *                                     BackendService = home.Id,
 *                                     Weight = 400,
 *                                     HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs
 *                                     {
 *                                         ResponseHeadersToAdds = new[]
 *                                         {
 *                                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs
 *                                             {
 *                                                 HeaderName = "AddMe",
 *                                                 HeaderValue = "MyValue",
 *                                                 Replace = false,
 *                                             },
 *                                         },
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Name: pulumi.String("health-check"),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port: pulumi.Int(80),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Name:           pulumi.String("regionurlmap"),
 * 			Description:    pulumi.String("a description"),
 * 			DefaultService: home.ID(),
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					PathRules: compute.RegionUrlMapPathMatcherPathRuleArray{
 * 						&compute.RegionUrlMapPathMatcherPathRuleArgs{
 * 							Paths: pulumi.StringArray{
 * 								pulumi.String("/home"),
 * 							},
 * 							RouteAction: &compute.RegionUrlMapPathMatcherPathRuleRouteActionArgs{
 * 								RetryPolicy: &compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs{
 * 									NumRetries: pulumi.Int(4),
 * 									PerTryTimeout: &compute.RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs{
 * 										Seconds: pulumi.String("30"),
 * 									},
 * 									RetryConditions: pulumi.StringArray{
 * 										pulumi.String("5xx"),
 * 										pulumi.String("deadline-exceeded"),
 * 									},
 * 								},
 * 								Timeout: &compute.RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs{
 * 									Seconds: pulumi.String("20"),
 * 									Nanos:   pulumi.Int(750000000),
 * 								},
 * 								UrlRewrite: &compute.RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs{
 * 									HostRewrite:       pulumi.String("dev.example.com"),
 * 									PathPrefixRewrite: pulumi.String("/v1/api/"),
 * 								},
 * 								WeightedBackendServices: compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArray{
 * 									&compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs{
 * 										BackendService: home.ID(),
 * 										Weight:         pulumi.Int(400),
 * 										HeaderAction: &compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs{
 * 											ResponseHeadersToAdds: compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArray{
 * 												&compute.RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs{
 * 													HeaderName:  pulumi.String("AddMe"),
 * 													HeaderValue: pulumi.String("MyValue"),
 * 													Replace:     pulumi.Bool(false),
 * 												},
 * 											},
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .name("health-check")
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .build())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .name("home")
 *             .protocol("HTTP")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultService(home.id())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .pathRules(RegionUrlMapPathMatcherPathRuleArgs.builder()
 *                     .paths("/home")
 *                     .routeAction(RegionUrlMapPathMatcherPathRuleRouteActionArgs.builder()
 *                         .retryPolicy(RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyArgs.builder()
 *                             .numRetries(4)
 *                             .perTryTimeout(RegionUrlMapPathMatcherPathRuleRouteActionRetryPolicyPerTryTimeoutArgs.builder()
 *                                 .seconds(30)
 *                                 .build())
 *                             .retryConditions(
 *                                 "5xx",
 *                                 "deadline-exceeded")
 *                             .build())
 *                         .timeout(RegionUrlMapPathMatcherPathRuleRouteActionTimeoutArgs.builder()
 *                             .seconds(20)
 *                             .nanos(750000000)
 *                             .build())
 *                         .urlRewrite(RegionUrlMapPathMatcherPathRuleRouteActionUrlRewriteArgs.builder()
 *                             .hostRewrite("dev.example.com")
 *                             .pathPrefixRewrite("/v1/api/")
 *                             .build())
 *                         .weightedBackendServices(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceArgs.builder()
 *                             .backendService(home.id())
 *                             .weight(400)
 *                             .headerAction(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionArgs.builder()
 *                                 .responseHeadersToAdds(RegionUrlMapPathMatcherPathRuleRouteActionWeightedBackendServiceHeaderActionResponseHeadersToAddArgs.builder()
 *                                     .headerName("AddMe")
 *                                     .headerValue("MyValue")
 *                                     .replace(false)
 *                                     .build())
 *                                 .build())
 *                             .build())
 *                         .build())
 *                     .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       name: regionurlmap
 *       description: a description
 *       defaultService: ${home.id}
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           pathRules:
 *             - paths:
 *                 - /home
 *               routeAction:
 *                 retryPolicy:
 *                   numRetries: 4
 *                   perTryTimeout:
 *                     seconds: 30
 *                   retryConditions:
 *                     - 5xx
 *                     - deadline-exceeded
 *                 timeout:
 *                   seconds: 20
 *                   nanos: 7.5e+08
 *                 urlRewrite:
 *                   hostRewrite: dev.example.com
 *                   pathPrefixRewrite: /v1/api/
 *                 weightedBackendServices:
 *                   - backendService: ${home.id}
 *                     weight: 400
 *                     headerAction:
 *                       responseHeadersToAdds:
 *                         - headerName: AddMe
 *                           headerValue: MyValue
 *                           replace: false
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       name: home
 *       protocol: HTTP
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *       loadBalancingScheme: INTERNAL_MANAGED
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       name: health-check
 *       httpHealthCheck:
 *         port: 80
 * ```
 * 
 * ### Region Url Map L7 Ilb Route
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     name: "health-check",
 *     httpHealthCheck: {
 *         port: 80,
 *     },
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     name: "home",
 *     protocol: "HTTP",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultService: home.id,
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         routeRules: [{
 *             priority: 1,
 *             headerAction: {
 *                 requestHeadersToRemoves: ["RemoveMe2"],
 *                 requestHeadersToAdds: [{
 *                     headerName: "AddSomethingElse",
 *                     headerValue: "MyOtherValue",
 *                     replace: true,
 *                 }],
 *                 responseHeadersToRemoves: ["RemoveMe3"],
 *                 responseHeadersToAdds: [{
 *                     headerName: "AddMe",
 *                     headerValue: "MyValue",
 *                     replace: false,
 *                 }],
 *             },
 *             matchRules: [{
 *                 fullPathMatch: "a full path",
 *                 headerMatches: [{
 *                     headerName: "someheader",
 *                     exactMatch: "match this exactly",
 *                     invertMatch: true,
 *                 }],
 *                 ignoreCase: true,
 *                 metadataFilters: [{
 *                     filterMatchCriteria: "MATCH_ANY",
 *                     filterLabels: [{
 *                         name: "PLANET",
 *                         value: "MARS",
 *                     }],
 *                 }],
 *                 queryParameterMatches: [{
 *                     name: "a query parameter",
 *                     presentMatch: true,
 *                 }],
 *             }],
 *             urlRedirect: {
 *                 hostRedirect: "A host",
 *                 httpsRedirect: false,
 *                 pathRedirect: "some/path",
 *                 redirectResponseCode: "TEMPORARY_REDIRECT",
 *                 stripQuery: true,
 *             },
 *         }],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     name="health-check",
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *     ))
 * home = gcp.compute.RegionBackendService("home",
 *     name="home",
 *     protocol="HTTP",
 *     timeout_sec=10,
 *     health_checks=default.id,
 *     load_balancing_scheme="INTERNAL_MANAGED")
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     name="regionurlmap",
 *     description="a description",
 *     default_service=home.id,
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         route_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleArgs(
 *             priority=1,
 *             header_action=gcp.compute.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs(
 *                 request_headers_to_removes=["RemoveMe2"],
 *                 request_headers_to_adds=[gcp.compute.RegionUrlMapPathMatcherRouteRuleHeaderActionRequestHeadersToAddArgs(
 *                     header_name="AddSomethingElse",
 *                     header_value="MyOtherValue",
 *                     replace=True,
 *                 )],
 *                 response_headers_to_removes=["RemoveMe3"],
 *                 response_headers_to_adds=[gcp.compute.RegionUrlMapPathMatcherRouteRuleHeaderActionResponseHeadersToAddArgs(
 *                     header_name="AddMe",
 *                     header_value="MyValue",
 *                     replace=False,
 *                 )],
 *             ),
 *             match_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs(
 *                 full_path_match="a full path",
 *                 header_matches=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs(
 *                     header_name="someheader",
 *                     exact_match="match this exactly",
 *                     invert_match=True,
 *                 )],
 *                 ignore_case=True,
 *                 metadata_filters=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterArgs(
 *                     filter_match_criteria="MATCH_ANY",
 *                     filter_labels=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterFilterLabelArgs(
 *                         name="PLANET",
 *                         value="MARS",
 *                     )],
 *                 )],
 *                 query_parameter_matches=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs(
 *                     name="a query parameter",
 *                     present_match=True,
 *                 )],
 *             )],
 *             url_redirect=gcp.compute.RegionUrlMapPathMatcherRouteRuleUrlRedirectArgs(
 *                 host_redirect="A host",
 *                 https_redirect=False,
 *                 path_redirect="some/path",
 *                 redirect_response_code="TEMPORARY_REDIRECT",
 *                 strip_query=True,
 *             ),
 *         )],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Name = "health-check",
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *         },
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Name = "home",
 *         Protocol = "HTTP",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultService = home.Id,
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 RouteRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleArgs
 *                     {
 *                         Priority = 1,
 *                         HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs
 *                         {
 *                             RequestHeadersToRemoves = new[]
 *                             {
 *                                 "RemoveMe2",
 *                             },
 *                             RequestHeadersToAdds = new[]
 *                             {
 *                                 new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleHeaderActionRequestHeadersToAddArgs
 *                                 {
 *                                     HeaderName = "AddSomethingElse",
 *                                     HeaderValue = "MyOtherValue",
 *                                     Replace = true,
 *                                 },
 *                             },
 *                             ResponseHeadersToRemoves = new[]
 *                             {
 *                                 "RemoveMe3",
 *                             },
 *                             ResponseHeadersToAdds = new[]
 *                             {
 *                                 new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleHeaderActionResponseHeadersToAddArgs
 *                                 {
 *                                     HeaderName = "AddMe",
 *                                     HeaderValue = "MyValue",
 *                                     Replace = false,
 *                                 },
 *                             },
 *                         },
 *                         MatchRules = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs
 *                             {
 *                                 FullPathMatch = "a full path",
 *                                 HeaderMatches = new[]
 *                                 {
 *                                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs
 *                                     {
 *                                         HeaderName = "someheader",
 *                                         ExactMatch = "match this exactly",
 *                                         InvertMatch = true,
 *                                     },
 *                                 },
 *                                 IgnoreCase = true,
 *                                 MetadataFilters = new[]
 *                                 {
 *                                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterArgs
 *                                     {
 *                                         FilterMatchCriteria = "MATCH_ANY",
 *                                         FilterLabels = new[]
 *                                         {
 *                                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterFilterLabelArgs
 *                                             {
 *                                                 Name = "PLANET",
 *                                                 Value = "MARS",
 *                                             },
 *                                         },
 *                                     },
 *                                 },
 *                                 QueryParameterMatches = new[]
 *                                 {
 *                                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs
 *                                     {
 *                                         Name = "a query parameter",
 *                                         PresentMatch = true,
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                         UrlRedirect = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleUrlRedirectArgs
 *                         {
 *                             HostRedirect = "A host",
 *                             HttpsRedirect = false,
 *                             PathRedirect = "some/path",
 *                             RedirectResponseCode = "TEMPORARY_REDIRECT",
 *                             StripQuery = true,
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Name: pulumi.String("health-check"),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port: pulumi.Int(80),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Name:           pulumi.String("regionurlmap"),
 * 			Description:    pulumi.String("a description"),
 * 			DefaultService: home.ID(),
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					RouteRules: compute.RegionUrlMapPathMatcherRouteRuleArray{
 * 						&compute.RegionUrlMapPathMatcherRouteRuleArgs{
 * 							Priority: pulumi.Int(1),
 * 							HeaderAction: &compute.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs{
 * 								RequestHeadersToRemoves: pulumi.StringArray{
 * 									pulumi.String("RemoveMe2"),
 * 								},
 * 								RequestHeadersToAdds: compute.RegionUrlMapPathMatcherRouteRuleHeaderActionRequestHeadersToAddArray{
 * 									&compute.RegionUrlMapPathMatcherRouteRuleHeaderActionRequestHeadersToAddArgs{
 * 										HeaderName:  pulumi.String("AddSomethingElse"),
 * 										HeaderValue: pulumi.String("MyOtherValue"),
 * 										Replace:     pulumi.Bool(true),
 * 									},
 * 								},
 * 								ResponseHeadersToRemoves: pulumi.StringArray{
 * 									pulumi.String("RemoveMe3"),
 * 								},
 * 								ResponseHeadersToAdds: compute.RegionUrlMapPathMatcherRouteRuleHeaderActionResponseHeadersToAddArray{
 * 									&compute.RegionUrlMapPathMatcherRouteRuleHeaderActionResponseHeadersToAddArgs{
 * 										HeaderName:  pulumi.String("AddMe"),
 * 										HeaderValue: pulumi.String("MyValue"),
 * 										Replace:     pulumi.Bool(false),
 * 									},
 * 								},
 * 							},
 * 							MatchRules: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArray{
 * 								&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs{
 * 									FullPathMatch: pulumi.String("a full path"),
 * 									HeaderMatches: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArray{
 * 										&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs{
 * 											HeaderName:  pulumi.String("someheader"),
 * 											ExactMatch:  pulumi.String("match this exactly"),
 * 											InvertMatch: pulumi.Bool(true),
 * 										},
 * 									},
 * 									IgnoreCase: pulumi.Bool(true),
 * 									MetadataFilters: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterArray{
 * 										&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterArgs{
 * 											FilterMatchCriteria: pulumi.String("MATCH_ANY"),
 * 											FilterLabels: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterFilterLabelArray{
 * 												&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterFilterLabelArgs{
 * 													Name:  pulumi.String("PLANET"),
 * 													Value: pulumi.String("MARS"),
 * 												},
 * 											},
 * 										},
 * 									},
 * 									QueryParameterMatches: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArray{
 * 										&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs{
 * 											Name:         pulumi.String("a query parameter"),
 * 											PresentMatch: pulumi.Bool(true),
 * 										},
 * 									},
 * 								},
 * 							},
 * 							UrlRedirect: &compute.RegionUrlMapPathMatcherRouteRuleUrlRedirectArgs{
 * 								HostRedirect:         pulumi.String("A host"),
 * 								HttpsRedirect:        pulumi.Bool(false),
 * 								PathRedirect:         pulumi.String("some/path"),
 * 								RedirectResponseCode: pulumi.String("TEMPORARY_REDIRECT"),
 * 								StripQuery:           pulumi.Bool(true),
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .name("health-check")
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .build())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .name("home")
 *             .protocol("HTTP")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultService(home.id())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .routeRules(RegionUrlMapPathMatcherRouteRuleArgs.builder()
 *                     .priority(1)
 *                     .headerAction(RegionUrlMapPathMatcherRouteRuleHeaderActionArgs.builder()
 *                         .requestHeadersToRemoves("RemoveMe2")
 *                         .requestHeadersToAdds(RegionUrlMapPathMatcherRouteRuleHeaderActionRequestHeadersToAddArgs.builder()
 *                             .headerName("AddSomethingElse")
 *                             .headerValue("MyOtherValue")
 *                             .replace(true)
 *                             .build())
 *                         .responseHeadersToRemoves("RemoveMe3")
 *                         .responseHeadersToAdds(RegionUrlMapPathMatcherRouteRuleHeaderActionResponseHeadersToAddArgs.builder()
 *                             .headerName("AddMe")
 *                             .headerValue("MyValue")
 *                             .replace(false)
 *                             .build())
 *                         .build())
 *                     .matchRules(RegionUrlMapPathMatcherRouteRuleMatchRuleArgs.builder()
 *                         .fullPathMatch("a full path")
 *                         .headerMatches(RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs.builder()
 *                             .headerName("someheader")
 *                             .exactMatch("match this exactly")
 *                             .invertMatch(true)
 *                             .build())
 *                         .ignoreCase(true)
 *                         .metadataFilters(RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterArgs.builder()
 *                             .filterMatchCriteria("MATCH_ANY")
 *                             .filterLabels(RegionUrlMapPathMatcherRouteRuleMatchRuleMetadataFilterFilterLabelArgs.builder()
 *                                 .name("PLANET")
 *                                 .value("MARS")
 *                                 .build())
 *                             .build())
 *                         .queryParameterMatches(RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs.builder()
 *                             .name("a query parameter")
 *                             .presentMatch(true)
 *                             .build())
 *                         .build())
 *                     .urlRedirect(RegionUrlMapPathMatcherRouteRuleUrlRedirectArgs.builder()
 *                         .hostRedirect("A host")
 *                         .httpsRedirect(false)
 *                         .pathRedirect("some/path")
 *                         .redirectResponseCode("TEMPORARY_REDIRECT")
 *                         .stripQuery(true)
 *                         .build())
 *                     .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       name: regionurlmap
 *       description: a description
 *       defaultService: ${home.id}
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           routeRules:
 *             - priority: 1
 *               headerAction:
 *                 requestHeadersToRemoves:
 *                   - RemoveMe2
 *                 requestHeadersToAdds:
 *                   - headerName: AddSomethingElse
 *                     headerValue: MyOtherValue
 *                     replace: true
 *                 responseHeadersToRemoves:
 *                   - RemoveMe3
 *                 responseHeadersToAdds:
 *                   - headerName: AddMe
 *                     headerValue: MyValue
 *                     replace: false
 *               matchRules:
 *                 - fullPathMatch: a full path
 *                   headerMatches:
 *                     - headerName: someheader
 *                       exactMatch: match this exactly
 *                       invertMatch: true
 *                   ignoreCase: true
 *                   metadataFilters:
 *                     - filterMatchCriteria: MATCH_ANY
 *                       filterLabels:
 *                         - name: PLANET
 *                           value: MARS
 *                   queryParameterMatches:
 *                     - name: a query parameter
 *                       presentMatch: true
 *               urlRedirect:
 *                 hostRedirect: A host
 *                 httpsRedirect: false
 *                 pathRedirect: some/path
 *                 redirectResponseCode: TEMPORARY_REDIRECT
 *                 stripQuery: true
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       name: home
 *       protocol: HTTP
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *       loadBalancingScheme: INTERNAL_MANAGED
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       name: health-check
 *       httpHealthCheck:
 *         port: 80
 * ```
 * 
 * ### Region Url Map L7 Ilb Route Partial
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.compute.RegionHealthCheck("default", {
 *     name: "health-check",
 *     httpHealthCheck: {
 *         port: 80,
 *     },
 * });
 * const home = new gcp.compute.RegionBackendService("home", {
 *     name: "home",
 *     protocol: "HTTP",
 *     timeoutSec: 10,
 *     healthChecks: _default.id,
 *     loadBalancingScheme: "INTERNAL_MANAGED",
 * });
 * const regionurlmap = new gcp.compute.RegionUrlMap("regionurlmap", {
 *     name: "regionurlmap",
 *     description: "a description",
 *     defaultService: home.id,
 *     hostRules: [{
 *         hosts: ["mysite.com"],
 *         pathMatcher: "allpaths",
 *     }],
 *     pathMatchers: [{
 *         name: "allpaths",
 *         defaultService: home.id,
 *         routeRules: [{
 *             priority: 1,
 *             service: home.id,
 *             headerAction: {
 *                 requestHeadersToRemoves: ["RemoveMe2"],
 *             },
 *             matchRules: [{
 *                 fullPathMatch: "a full path",
 *                 headerMatches: [{
 *                     headerName: "someheader",
 *                     exactMatch: "match this exactly",
 *                     invertMatch: true,
 *                 }],
 *                 queryParameterMatches: [{
 *                     name: "a query parameter",
 *                     presentMatch: true,
 *                 }],
 *             }],
 *         }],
 *     }],
 *     tests: [{
 *         service: home.id,
 *         host: "hi.com",
 *         path: "/home",
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.compute.RegionHealthCheck("default",
 *     name="health-check",
 *     http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs(
 *         port=80,
 *     ))
 * home = gcp.compute.RegionBackendService("home",
 *     name="home",
 *     protocol="HTTP",
 *     timeout_sec=10,
 *     health_checks=default.id,
 *     load_balancing_scheme="INTERNAL_MANAGED")
 * regionurlmap = gcp.compute.RegionUrlMap("regionurlmap",
 *     name="regionurlmap",
 *     description="a description",
 *     default_service=home.id,
 *     host_rules=[gcp.compute.RegionUrlMapHostRuleArgs(
 *         hosts=["mysite.com"],
 *         path_matcher="allpaths",
 *     )],
 *     path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs(
 *         name="allpaths",
 *         default_service=home.id,
 *         route_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleArgs(
 *             priority=1,
 *             service=home.id,
 *             header_action=gcp.compute.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs(
 *                 request_headers_to_removes=["RemoveMe2"],
 *             ),
 *             match_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs(
 *                 full_path_match="a full path",
 *                 header_matches=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs(
 *                     header_name="someheader",
 *                     exact_match="match this exactly",
 *                     invert_match=True,
 *                 )],
 *                 query_parameter_matches=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs(
 *                     name="a query parameter",
 *                     present_match=True,
 *                 )],
 *             )],
 *         )],
 *     )],
 *     tests=[gcp.compute.RegionUrlMapTestArgs(
 *         service=home.id,
 *         host="hi.com",
 *         path="/home",
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Compute.RegionHealthCheck("default", new()
 *     {
 *         Name = "health-check",
 *         HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs
 *         {
 *             Port = 80,
 *         },
 *     });
 *     var home = new Gcp.Compute.RegionBackendService("home", new()
 *     {
 *         Name = "home",
 *         Protocol = "HTTP",
 *         TimeoutSec = 10,
 *         HealthChecks = @default.Id,
 *         LoadBalancingScheme = "INTERNAL_MANAGED",
 *     });
 *     var regionurlmap = new Gcp.Compute.RegionUrlMap("regionurlmap", new()
 *     {
 *         Name = "regionurlmap",
 *         Description = "a description",
 *         DefaultService = home.Id,
 *         HostRules = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs
 *             {
 *                 Hosts = new[]
 *                 {
 *                     "mysite.com",
 *                 },
 *                 PathMatcher = "allpaths",
 *             },
 *         },
 *         PathMatchers = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs
 *             {
 *                 Name = "allpaths",
 *                 DefaultService = home.Id,
 *                 RouteRules = new[]
 *                 {
 *                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleArgs
 *                     {
 *                         Priority = 1,
 *                         Service = home.Id,
 *                         HeaderAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs
 *                         {
 *                             RequestHeadersToRemoves = new[]
 *                             {
 *                                 "RemoveMe2",
 *                             },
 *                         },
 *                         MatchRules = new[]
 *                         {
 *                             new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs
 *                             {
 *                                 FullPathMatch = "a full path",
 *                                 HeaderMatches = new[]
 *                                 {
 *                                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs
 *                                     {
 *                                         HeaderName = "someheader",
 *                                         ExactMatch = "match this exactly",
 *                                         InvertMatch = true,
 *                                     },
 *                                 },
 *                                 QueryParameterMatches = new[]
 *                                 {
 *                                     new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs
 *                                     {
 *                                         Name = "a query parameter",
 *                                         PresentMatch = true,
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *         Tests = new[]
 *         {
 *             new Gcp.Compute.Inputs.RegionUrlMapTestArgs
 *             {
 *                 Service = home.Id,
 *                 Host = "hi.com",
 *                 Path = "/home",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{
 * 			Name: pulumi.String("health-check"),
 * 			HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{
 * 				Port: pulumi.Int(80),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		home, err := compute.NewRegionBackendService(ctx, "home", &compute.RegionBackendServiceArgs{
 * 			Name:                pulumi.String("home"),
 * 			Protocol:            pulumi.String("HTTP"),
 * 			TimeoutSec:          pulumi.Int(10),
 * 			HealthChecks:        _default.ID(),
 * 			LoadBalancingScheme: pulumi.String("INTERNAL_MANAGED"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewRegionUrlMap(ctx, "regionurlmap", &compute.RegionUrlMapArgs{
 * 			Name:           pulumi.String("regionurlmap"),
 * 			Description:    pulumi.String("a description"),
 * 			DefaultService: home.ID(),
 * 			HostRules: compute.RegionUrlMapHostRuleArray{
 * 				&compute.RegionUrlMapHostRuleArgs{
 * 					Hosts: pulumi.StringArray{
 * 						pulumi.String("mysite.com"),
 * 					},
 * 					PathMatcher: pulumi.String("allpaths"),
 * 				},
 * 			},
 * 			PathMatchers: compute.RegionUrlMapPathMatcherArray{
 * 				&compute.RegionUrlMapPathMatcherArgs{
 * 					Name:           pulumi.String("allpaths"),
 * 					DefaultService: home.ID(),
 * 					RouteRules: compute.RegionUrlMapPathMatcherRouteRuleArray{
 * 						&compute.RegionUrlMapPathMatcherRouteRuleArgs{
 * 							Priority: pulumi.Int(1),
 * 							Service:  home.ID(),
 * 							HeaderAction: &compute.RegionUrlMapPathMatcherRouteRuleHeaderActionArgs{
 * 								RequestHeadersToRemoves: pulumi.StringArray{
 * 									pulumi.String("RemoveMe2"),
 * 								},
 * 							},
 * 							MatchRules: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArray{
 * 								&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs{
 * 									FullPathMatch: pulumi.String("a full path"),
 * 									HeaderMatches: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArray{
 * 										&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs{
 * 											HeaderName:  pulumi.String("someheader"),
 * 											ExactMatch:  pulumi.String("match this exactly"),
 * 											InvertMatch: pulumi.Bool(true),
 * 										},
 * 									},
 * 									QueryParameterMatches: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArray{
 * 										&compute.RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs{
 * 											Name:         pulumi.String("a query parameter"),
 * 											PresentMatch: pulumi.Bool(true),
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Tests: compute.RegionUrlMapTestArray{
 * 				&compute.RegionUrlMapTestArgs{
 * 					Service: home.ID(),
 * 					Host:    pulumi.String("hi.com"),
 * 					Path:    pulumi.String("/home"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.compute.RegionHealthCheck;
 * import com.pulumi.gcp.compute.RegionHealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.RegionBackendService;
 * import com.pulumi.gcp.compute.RegionBackendServiceArgs;
 * import com.pulumi.gcp.compute.RegionUrlMap;
 * import com.pulumi.gcp.compute.RegionUrlMapArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs;
 * import com.pulumi.gcp.compute.inputs.RegionUrlMapTestArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder()
 *             .name("health-check")
 *             .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder()
 *                 .port(80)
 *                 .build())
 *             .build());
 *         var home = new RegionBackendService("home", RegionBackendServiceArgs.builder()
 *             .name("home")
 *             .protocol("HTTP")
 *             .timeoutSec(10)
 *             .healthChecks(default_.id())
 *             .loadBalancingScheme("INTERNAL_MANAGED")
 *             .build());
 *         var regionurlmap = new RegionUrlMap("regionurlmap", RegionUrlMapArgs.builder()
 *             .name("regionurlmap")
 *             .description("a description")
 *             .defaultService(home.id())
 *             .hostRules(RegionUrlMapHostRuleArgs.builder()
 *                 .hosts("mysite.com")
 *                 .pathMatcher("allpaths")
 *                 .build())
 *             .pathMatchers(RegionUrlMapPathMatcherArgs.builder()
 *                 .name("allpaths")
 *                 .defaultService(home.id())
 *                 .routeRules(RegionUrlMapPathMatcherRouteRuleArgs.builder()
 *                     .priority(1)
 *                     .service(home.id())
 *                     .headerAction(RegionUrlMapPathMatcherRouteRuleHeaderActionArgs.builder()
 *                         .requestHeadersToRemoves("RemoveMe2")
 *                         .build())
 *                     .matchRules(RegionUrlMapPathMatcherRouteRuleMatchRuleArgs.builder()
 *                         .fullPathMatch("a full path")
 *                         .headerMatches(RegionUrlMapPathMatcherRouteRuleMatchRuleHeaderMatchArgs.builder()
 *                             .headerName("someheader")
 *                             .exactMatch("match this exactly")
 *                             .invertMatch(true)
 *                             .build())
 *                         .queryParameterMatches(RegionUrlMapPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs.builder()
 *                             .name("a query parameter")
 *                             .presentMatch(true)
 *                             .build())
 *                         .build())
 *                     .build())
 *                 .build())
 *             .tests(RegionUrlMapTestArgs.builder()
 *                 .service(home.id())
 *                 .host("hi.com")
 *                 .path("/home")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   regionurlmap:
 *     type: gcp:compute:RegionUrlMap
 *     properties:
 *       name: regionurlmap
 *       description: a description
 *       defaultService: ${home.id}
 *       hostRules:
 *         - hosts:
 *             - mysite.com
 *           pathMatcher: allpaths
 *       pathMatchers:
 *         - name: allpaths
 *           defaultService: ${home.id}
 *           routeRules:
 *             - priority: 1
 *               service: ${home.id}
 *               headerAction:
 *                 requestHeadersToRemoves:
 *                   - RemoveMe2
 *               matchRules:
 *                 - fullPathMatch: a full path
 *                   headerMatches:
 *                     - headerName: someheader
 *                       exactMatch: match this exactly
 *                       invertMatch: true
 *                   queryParameterMatches:
 *                     - name: a query parameter
 *                       presentMatch: true
 *       tests:
 *         - service: ${home.id}
 *           host: hi.com
 *           path: /home
 *   home:
 *     type: gcp:compute:RegionBackendService
 *     properties:
 *       name: home
 *       protocol: HTTP
 *       timeoutSec: 10
 *       healthChecks: ${default.id}
 *       loadBalancingScheme: INTERNAL_MANAGED
 *   default:
 *     type: gcp:compute:RegionHealthCheck
 *     properties:
 *       name: health-check
 *       httpHealthCheck:
 *         port: 80
 * ```
 * 
 * ### Int Https Lb Https Redirect
 * 
 * ```yaml
 * resources:
 *   # Internal HTTPS load balancer with HTTP-to-HTTPS redirect
 *   # VPC network
 *   default:
 *     type: gcp:compute:Network
 *     properties:
 *       name: l7-ilb-network
 *       autoCreateSubnetworks: false
 *   # Proxy-only subnet
 *   proxySubnet:
 *     type: gcp:compute:Subnetwork
 *     name: proxy_subnet
 *     properties:
 *       name: l7-ilb-proxy-subnet
 *       ipCidrRange: 10.0.0.0/24
 *       region: europe-west1
 *       purpose: REGIONAL_MANAGED_PROXY
 *       role: ACTIVE
 *       network: ${default.id}
 *   # Backend subnet
 *   defaultSubnetwork:
 *     type: gcp:compute:Subnetwork
 *     name: default
 *     properties:
 *       name: l7-ilb-subnet
 *       ipCidrRange: 10.0.1.0/24
 *       region: europe-west1
 *       network: ${default.id}
 *   # Reserved internal address
 *   defaultAddress:
 *     type: gcp:compute:Address
 *     name: default
 *     properties:
 *       name: l7-ilb-ip
 *       subnetwork: ${defaultSubnetwork.id}
 *       addressType: INTERNAL
 *       address: 10.0.1.5
 *       region: europe-west1
 *       purpose: SHARED_LOADBALANCER_VIP
 *   # Regional forwarding rule
 *   defaultForwardingRule:
 *     type: gcp:compute:ForwardingRule
 *     name: default
 *     properties:
 *       name: l7-ilb-forwarding-rule
 *       region: europe-west1
 *       ipProtocol: TCP
 *       ipAddress: ${defaultAddress.address}
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       portRange: '443'
 *       target: ${defaultRegionTargetHttpsProxy.id}
 *       network: ${default.id}
 *       subnetwork: ${defaultSubnetwork.id}
 *       networkTier: PREMIUM
 *   # Self-signed regional SSL certificate for testing
 *   defaultPrivateKey:
 *     type: tls:PrivateKey
 *     name: default
 *     properties:
 *       algorithm: RSA
 *       rsaBits: 2048
 *   defaultSelfSignedCert:
 *     type: tls:SelfSignedCert
 *     name: default
 *     properties:
 *       keyAlgorithm: ${defaultPrivateKey.algorithm}
 *       privateKeyPem: ${defaultPrivateKey.privateKeyPem}
 *       validityPeriodHours: 12 # Generate a new certificate if Terraform is run within three
 *       #   # hours of the certificate's expiration time.
 *       earlyRenewalHours: 3 # Reasonable set of uses for a server SSL certificate.
 *       allowedUses:
 *         - key_encipherment
 *         - digital_signature
 *         - server_auth
 *       dnsNames:
 *         - example.com
 *       subject:
 *         commonName: example.com
 *         organization: ACME Examples, Inc
 *   defaultRegionSslCertificate:
 *     type: gcp:compute:RegionSslCertificate
 *     name: default
 *     properties:
 *       namePrefix: my-certificate-
 *       privateKey: ${defaultPrivateKey.privateKeyPem}
 *       certificate: ${defaultSelfSignedCert.certPem}
 *       region: europe-west1
 *   # Regional target HTTPS proxy
 *   defaultRegionTargetHttpsProxy:
 *     type: gcp:compute:RegionTargetHttpsProxy
 *     name: default
 *     properties:
 *       name: l7-ilb-target-https-proxy
 *       region: europe-west1
 *       urlMap: ${httpsLb.id}
 *       sslCertificates:
 *         - ${defaultRegionSslCertificate.selfLink}
 *   # Regional URL map
 *   httpsLb:
 *     type: gcp:compute:RegionUrlMap
 *     name: https_lb
 *     properties:
 *       name: l7-ilb-regional-url-map
 *       region: europe-west1
 *       defaultService: ${defaultRegionBackendService.id}
 *   # Regional backend service
 *   defaultRegionBackendService:
 *     type: gcp:compute:RegionBackendService
 *     name: default
 *     properties:
 *       name: l7-ilb-backend-service
 *       region: europe-west1
 *       protocol: HTTP
 *       portName: http-server
 *       loadBalancingScheme: INTERNAL_MANAGED
 *       timeoutSec: 10
 *       healthChecks: ${defaultRegionHealthCheck.id}
 *       backends:
 *         - group: ${defaultRegionInstanceGroupManager.instanceGroup}
 *           balancingMode: UTILIZATION
 *           capacityScaler: 1
 *   # Instance template
 *   defaultInstanceTemplate:
 *     type: gcp:compute:InstanceTemplate
 *     name: default
 *     properties:
 *       networkInterfaces:
 *         - accessConfigs:
 *             - {}
 *           network: ${default.id}
 *           subnetwork: ${defaultSubnetwork.id}
 *       name: l7-ilb-mig-template
 *       machineType: e2-small
 *       tags:
 *         - http-server
 *       disks:
 *         - sourceImage: debian-cloud/debian-10
 *           autoDelete: true
 *           boot: true
 *       metadata:
 *         startup-script: |
 *           #! /bin/bash
 *           set -euo pipefail
 *           export DEBIAN_FRONTEND=noninteractive
 *           apt-get update
 *           apt-get install -y nginx-light jq
 *           NAME=$(curl -H "Metadata-Flavor: Google" "http://metadata.google.internal/computeMetadata/v1/instance/hostname")
 *           IP=$(curl -H "Metadata-Flavor: Google" "http://metadata.google.internal/computeMetadata/v1/instance/network-interfaces/0/ip")
 *           METADATA=$(curl -f -H "Metadata-Flavor: Google" "http://metadata.google.internal/computeMetadata/v1/instance/attributes/?recursive=True" | jq 'del(.["startup-script"])')
 *           cat < /var/www/html/index.html
 *           
 *           Name: $NAME
 *           IP: $IP
 *           Metadata: $METADATA
 *           
* EOF * # Regional health check * defaultRegionHealthCheck: * type: gcp:compute:RegionHealthCheck * name: default * properties: * name: l7-ilb-hc * region: europe-west1 * httpHealthCheck: * portSpecification: USE_SERVING_PORT * # Regional MIG * defaultRegionInstanceGroupManager: * type: gcp:compute:RegionInstanceGroupManager * name: default * properties: * name: l7-ilb-mig1 * region: europe-west1 * versions: * - instanceTemplate: ${defaultInstanceTemplate.id} * name: primary * namedPorts: * - name: http-server * port: 80 * baseInstanceName: vm * targetSize: 2 * # Allow all access to health check ranges * defaultFirewall: * type: gcp:compute:Firewall * name: default * properties: * name: l7-ilb-fw-allow-hc * direction: INGRESS * network: ${default.id} * sourceRanges: * - 130.211.0.0/22 * - 35.191.0.0/16 * - 35.235.240.0/20 * allows: * - protocol: tcp * # Allow http from proxy subnet to backends * backends: * type: gcp:compute:Firewall * properties: * name: l7-ilb-fw-allow-ilb-to-backends * direction: INGRESS * network: ${default.id} * sourceRanges: * - 10.0.0.0/24 * targetTags: * - http-server * allows: * - protocol: tcp * ports: * - '80' * - '443' * - '8080' * # Test instance * defaultInstance: ### HTTP-to-HTTPS redirect ### * type: gcp:compute:Instance * name: default * properties: * name: l7-ilb-test-vm * zone: europe-west1-b * machineType: e2-small * networkInterfaces: * - network: ${default.id} * subnetwork: ${defaultSubnetwork.id} * bootDisk: * initializeParams: * image: debian-cloud/debian-10 * # Regional forwarding rule * redirect: * type: gcp:compute:ForwardingRule * properties: * name: l7-ilb-redirect * region: europe-west1 * ipProtocol: TCP * ipAddress: ${defaultAddress.address} * loadBalancingScheme: INTERNAL_MANAGED * portRange: '80' * target: ${defaultRegionTargetHttpProxy.id} * network: ${default.id} * subnetwork: ${defaultSubnetwork.id} * networkTier: PREMIUM * # Regional HTTP proxy * defaultRegionTargetHttpProxy: * type: gcp:compute:RegionTargetHttpProxy * name: default * properties: * name: l7-ilb-target-http-proxy * region: europe-west1 * urlMap: ${redirectRegionUrlMap.id} * # Regional URL map * redirectRegionUrlMap: * type: gcp:compute:RegionUrlMap * name: redirect * properties: * name: l7-ilb-redirect-url-map * region: europe-west1 * defaultService: ${defaultRegionBackendService.id} * hostRules: * - hosts: * - '*' * pathMatcher: allpaths * pathMatchers: * - name: allpaths * defaultService: ${defaultRegionBackendService.id} * pathRules: * - paths: * - / * urlRedirect: * httpsRedirect: true * hostRedirect: 10.0.1.5:443 * redirectResponseCode: PERMANENT_REDIRECT * stripQuery: true * ``` * * ### Region Url Map Path Template Match * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as gcp from "@pulumi/gcp"; * const _default = new gcp.compute.RegionHealthCheck("default", { * region: "us-central1", * name: "health-check", * checkIntervalSec: 1, * timeoutSec: 1, * httpHealthCheck: { * port: 80, * requestPath: "/", * }, * }); * const home_backend = new gcp.compute.RegionBackendService("home-backend", { * region: "us-central1", * name: "home-service", * portName: "http", * protocol: "HTTP", * timeoutSec: 10, * loadBalancingScheme: "EXTERNAL_MANAGED", * healthChecks: _default.id, * }); * const cart_backend = new gcp.compute.RegionBackendService("cart-backend", { * region: "us-central1", * name: "cart-service", * portName: "http", * protocol: "HTTP", * timeoutSec: 10, * loadBalancingScheme: "EXTERNAL_MANAGED", * healthChecks: _default.id, * }); * const user_backend = new gcp.compute.RegionBackendService("user-backend", { * region: "us-central1", * name: "user-service", * portName: "http", * protocol: "HTTP", * timeoutSec: 10, * loadBalancingScheme: "EXTERNAL_MANAGED", * healthChecks: _default.id, * }); * const urlmap = new gcp.compute.RegionUrlMap("urlmap", { * region: "us-central1", * name: "urlmap", * description: "a description", * defaultService: home_backend.id, * hostRules: [{ * hosts: ["mysite.com"], * pathMatcher: "mysite", * }], * pathMatchers: [{ * name: "mysite", * defaultService: home_backend.id, * routeRules: [ * { * matchRules: [{ * pathTemplateMatch: "/xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**}", * }], * service: cart_backend.id, * priority: 1, * routeAction: { * urlRewrite: { * pathTemplateRewrite: "/{username}-{cartid}/", * }, * }, * }, * { * matchRules: [{ * pathTemplateMatch: "/xyzwebservices/v2/xyz/users/*/accountinfo/*", * }], * service: user_backend.id, * priority: 2, * }, * ], * }], * }); * ``` * ```python * import pulumi * import pulumi_gcp as gcp * default = gcp.compute.RegionHealthCheck("default", * region="us-central1", * name="health-check", * check_interval_sec=1, * timeout_sec=1, * http_health_check=gcp.compute.RegionHealthCheckHttpHealthCheckArgs( * port=80, * request_path="/", * )) * home_backend = gcp.compute.RegionBackendService("home-backend", * region="us-central1", * name="home-service", * port_name="http", * protocol="HTTP", * timeout_sec=10, * load_balancing_scheme="EXTERNAL_MANAGED", * health_checks=default.id) * cart_backend = gcp.compute.RegionBackendService("cart-backend", * region="us-central1", * name="cart-service", * port_name="http", * protocol="HTTP", * timeout_sec=10, * load_balancing_scheme="EXTERNAL_MANAGED", * health_checks=default.id) * user_backend = gcp.compute.RegionBackendService("user-backend", * region="us-central1", * name="user-service", * port_name="http", * protocol="HTTP", * timeout_sec=10, * load_balancing_scheme="EXTERNAL_MANAGED", * health_checks=default.id) * urlmap = gcp.compute.RegionUrlMap("urlmap", * region="us-central1", * name="urlmap", * description="a description", * default_service=home_backend.id, * host_rules=[gcp.compute.RegionUrlMapHostRuleArgs( * hosts=["mysite.com"], * path_matcher="mysite", * )], * path_matchers=[gcp.compute.RegionUrlMapPathMatcherArgs( * name="mysite", * default_service=home_backend.id, * route_rules=[ * gcp.compute.RegionUrlMapPathMatcherRouteRuleArgs( * match_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs( * path_template_match="/xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**}", * )], * service=cart_backend.id, * priority=1, * route_action=gcp.compute.RegionUrlMapPathMatcherRouteRuleRouteActionArgs( * url_rewrite=gcp.compute.RegionUrlMapPathMatcherRouteRuleRouteActionUrlRewriteArgs( * path_template_rewrite="/{username}-{cartid}/", * ), * ), * ), * gcp.compute.RegionUrlMapPathMatcherRouteRuleArgs( * match_rules=[gcp.compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs( * path_template_match="/xyzwebservices/v2/xyz/users/*/accountinfo/*", * )], * service=user_backend.id, * priority=2, * ), * ], * )]) * ``` * ```csharp * using System.Collections.Generic; * using System.Linq; * using Pulumi; * using Gcp = Pulumi.Gcp; * return await Deployment.RunAsync(() => * { * var @default = new Gcp.Compute.RegionHealthCheck("default", new() * { * Region = "us-central1", * Name = "health-check", * CheckIntervalSec = 1, * TimeoutSec = 1, * HttpHealthCheck = new Gcp.Compute.Inputs.RegionHealthCheckHttpHealthCheckArgs * { * Port = 80, * RequestPath = "/", * }, * }); * var home_backend = new Gcp.Compute.RegionBackendService("home-backend", new() * { * Region = "us-central1", * Name = "home-service", * PortName = "http", * Protocol = "HTTP", * TimeoutSec = 10, * LoadBalancingScheme = "EXTERNAL_MANAGED", * HealthChecks = @default.Id, * }); * var cart_backend = new Gcp.Compute.RegionBackendService("cart-backend", new() * { * Region = "us-central1", * Name = "cart-service", * PortName = "http", * Protocol = "HTTP", * TimeoutSec = 10, * LoadBalancingScheme = "EXTERNAL_MANAGED", * HealthChecks = @default.Id, * }); * var user_backend = new Gcp.Compute.RegionBackendService("user-backend", new() * { * Region = "us-central1", * Name = "user-service", * PortName = "http", * Protocol = "HTTP", * TimeoutSec = 10, * LoadBalancingScheme = "EXTERNAL_MANAGED", * HealthChecks = @default.Id, * }); * var urlmap = new Gcp.Compute.RegionUrlMap("urlmap", new() * { * Region = "us-central1", * Name = "urlmap", * Description = "a description", * DefaultService = home_backend.Id, * HostRules = new[] * { * new Gcp.Compute.Inputs.RegionUrlMapHostRuleArgs * { * Hosts = new[] * { * "mysite.com", * }, * PathMatcher = "mysite", * }, * }, * PathMatchers = new[] * { * new Gcp.Compute.Inputs.RegionUrlMapPathMatcherArgs * { * Name = "mysite", * DefaultService = home_backend.Id, * RouteRules = new[] * { * new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleArgs * { * MatchRules = new[] * { * new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs * { * PathTemplateMatch = "/xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**}", * }, * }, * Service = cart_backend.Id, * Priority = 1, * RouteAction = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleRouteActionArgs * { * UrlRewrite = new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleRouteActionUrlRewriteArgs * { * PathTemplateRewrite = "/{username}-{cartid}/", * }, * }, * }, * new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleArgs * { * MatchRules = new[] * { * new Gcp.Compute.Inputs.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs * { * PathTemplateMatch = "/xyzwebservices/v2/xyz/users/*/accountinfo/*", * }, * }, * Service = user_backend.Id, * Priority = 2, * }, * }, * }, * }, * }); * }); * ``` * ```go * package main * import ( * "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute" * "github.com/pulumi/pulumi/sdk/v3/go/pulumi" * ) * func main() { * pulumi.Run(func(ctx *pulumi.Context) error { * _, err := compute.NewRegionHealthCheck(ctx, "default", &compute.RegionHealthCheckArgs{ * Region: pulumi.String("us-central1"), * Name: pulumi.String("health-check"), * CheckIntervalSec: pulumi.Int(1), * TimeoutSec: pulumi.Int(1), * HttpHealthCheck: &compute.RegionHealthCheckHttpHealthCheckArgs{ * Port: pulumi.Int(80), * RequestPath: pulumi.String("/"), * }, * }) * if err != nil { * return err * } * _, err = compute.NewRegionBackendService(ctx, "home-backend", &compute.RegionBackendServiceArgs{ * Region: pulumi.String("us-central1"), * Name: pulumi.String("home-service"), * PortName: pulumi.String("http"), * Protocol: pulumi.String("HTTP"), * TimeoutSec: pulumi.Int(10), * LoadBalancingScheme: pulumi.String("EXTERNAL_MANAGED"), * HealthChecks: _default.ID(), * }) * if err != nil { * return err * } * _, err = compute.NewRegionBackendService(ctx, "cart-backend", &compute.RegionBackendServiceArgs{ * Region: pulumi.String("us-central1"), * Name: pulumi.String("cart-service"), * PortName: pulumi.String("http"), * Protocol: pulumi.String("HTTP"), * TimeoutSec: pulumi.Int(10), * LoadBalancingScheme: pulumi.String("EXTERNAL_MANAGED"), * HealthChecks: _default.ID(), * }) * if err != nil { * return err * } * _, err = compute.NewRegionBackendService(ctx, "user-backend", &compute.RegionBackendServiceArgs{ * Region: pulumi.String("us-central1"), * Name: pulumi.String("user-service"), * PortName: pulumi.String("http"), * Protocol: pulumi.String("HTTP"), * TimeoutSec: pulumi.Int(10), * LoadBalancingScheme: pulumi.String("EXTERNAL_MANAGED"), * HealthChecks: _default.ID(), * }) * if err != nil { * return err * } * _, err = compute.NewRegionUrlMap(ctx, "urlmap", &compute.RegionUrlMapArgs{ * Region: pulumi.String("us-central1"), * Name: pulumi.String("urlmap"), * Description: pulumi.String("a description"), * DefaultService: home_backend.ID(), * HostRules: compute.RegionUrlMapHostRuleArray{ * &compute.RegionUrlMapHostRuleArgs{ * Hosts: pulumi.StringArray{ * pulumi.String("mysite.com"), * }, * PathMatcher: pulumi.String("mysite"), * }, * }, * PathMatchers: compute.RegionUrlMapPathMatcherArray{ * &compute.RegionUrlMapPathMatcherArgs{ * Name: pulumi.String("mysite"), * DefaultService: home_backend.ID(), * RouteRules: compute.RegionUrlMapPathMatcherRouteRuleArray{ * &compute.RegionUrlMapPathMatcherRouteRuleArgs{ * MatchRules: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArray{ * &compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs{ * PathTemplateMatch: pulumi.String("/xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**}"), * }, * }, * Service: cart_backend.ID(), * Priority: pulumi.Int(1), * RouteAction: &compute.RegionUrlMapPathMatcherRouteRuleRouteActionArgs{ * UrlRewrite: &compute.RegionUrlMapPathMatcherRouteRuleRouteActionUrlRewriteArgs{ * PathTemplateRewrite: pulumi.String("/{username}-{cartid}/"), * }, * }, * }, * &compute.RegionUrlMapPathMatcherRouteRuleArgs{ * MatchRules: compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArray{ * &compute.RegionUrlMapPathMatcherRouteRuleMatchRuleArgs{ * PathTemplateMatch: pulumi.String("/xyzwebservices/v2/xyz/users/*/accountinfo/*"), * }, * }, * Service: user_backend.ID(), * Priority: pulumi.Int(2), * }, * }, * }, * }, * }) * if err != nil { * return err * } * return nil * }) * } * ``` * ```java * package generated_program; * import com.pulumi.Context; * import com.pulumi.Pulumi; * import com.pulumi.core.Output; * import com.pulumi.gcp.compute.RegionHealthCheck; * import com.pulumi.gcp.compute.RegionHealthCheckArgs; * import com.pulumi.gcp.compute.inputs.RegionHealthCheckHttpHealthCheckArgs; * import com.pulumi.gcp.compute.RegionBackendService; * import com.pulumi.gcp.compute.RegionBackendServiceArgs; * import com.pulumi.gcp.compute.RegionUrlMap; * import com.pulumi.gcp.compute.RegionUrlMapArgs; * import com.pulumi.gcp.compute.inputs.RegionUrlMapHostRuleArgs; * import com.pulumi.gcp.compute.inputs.RegionUrlMapPathMatcherArgs; * import java.util.List; * import java.util.ArrayList; * import java.util.Map; * import java.io.File; * import java.nio.file.Files; * import java.nio.file.Paths; * public class App { * public static void main(String[] args) { * Pulumi.run(App::stack); * } * public static void stack(Context ctx) { * var default_ = new RegionHealthCheck("default", RegionHealthCheckArgs.builder() * .region("us-central1") * .name("health-check") * .checkIntervalSec(1) * .timeoutSec(1) * .httpHealthCheck(RegionHealthCheckHttpHealthCheckArgs.builder() * .port(80) * .requestPath("/") * .build()) * .build()); * var home_backend = new RegionBackendService("home-backend", RegionBackendServiceArgs.builder() * .region("us-central1") * .name("home-service") * .portName("http") * .protocol("HTTP") * .timeoutSec(10) * .loadBalancingScheme("EXTERNAL_MANAGED") * .healthChecks(default_.id()) * .build()); * var cart_backend = new RegionBackendService("cart-backend", RegionBackendServiceArgs.builder() * .region("us-central1") * .name("cart-service") * .portName("http") * .protocol("HTTP") * .timeoutSec(10) * .loadBalancingScheme("EXTERNAL_MANAGED") * .healthChecks(default_.id()) * .build()); * var user_backend = new RegionBackendService("user-backend", RegionBackendServiceArgs.builder() * .region("us-central1") * .name("user-service") * .portName("http") * .protocol("HTTP") * .timeoutSec(10) * .loadBalancingScheme("EXTERNAL_MANAGED") * .healthChecks(default_.id()) * .build()); * var urlmap = new RegionUrlMap("urlmap", RegionUrlMapArgs.builder() * .region("us-central1") * .name("urlmap") * .description("a description") * .defaultService(home_backend.id()) * .hostRules(RegionUrlMapHostRuleArgs.builder() * .hosts("mysite.com") * .pathMatcher("mysite") * .build()) * .pathMatchers(RegionUrlMapPathMatcherArgs.builder() * .name("mysite") * .defaultService(home_backend.id()) * .routeRules( * RegionUrlMapPathMatcherRouteRuleArgs.builder() * .matchRules(RegionUrlMapPathMatcherRouteRuleMatchRuleArgs.builder() * .pathTemplateMatch("/xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**}") * .build()) * .service(cart_backend.id()) * .priority(1) * .routeAction(RegionUrlMapPathMatcherRouteRuleRouteActionArgs.builder() * .urlRewrite(RegionUrlMapPathMatcherRouteRuleRouteActionUrlRewriteArgs.builder() * .pathTemplateRewrite("/{username}-{cartid}/") * .build()) * .build()) * .build(), * RegionUrlMapPathMatcherRouteRuleArgs.builder() * .matchRules(RegionUrlMapPathMatcherRouteRuleMatchRuleArgs.builder() * .pathTemplateMatch("/xyzwebservices/v2/xyz/users/*/accountinfo/*") * .build()) * .service(user_backend.id()) * .priority(2) * .build()) * .build()) * .build()); * } * } * ``` * ```yaml * resources: * urlmap: * type: gcp:compute:RegionUrlMap * properties: * region: us-central1 * name: urlmap * description: a description * defaultService: ${["home-backend"].id} * hostRules: * - hosts: * - mysite.com * pathMatcher: mysite * pathMatchers: * - name: mysite * defaultService: ${["home-backend"].id} * routeRules: * - matchRules: * - pathTemplateMatch: /xyzwebservices/v2/xyz/users/{username=*}/carts/{cartid=**} * service: ${["cart-backend"].id} * priority: 1 * routeAction: * urlRewrite: * pathTemplateRewrite: /{username}-{cartid}/ * - matchRules: * - pathTemplateMatch: /xyzwebservices/v2/xyz/users/*/accountinfo/* * service: ${["user-backend"].id} * priority: 2 * home-backend: * type: gcp:compute:RegionBackendService * properties: * region: us-central1 * name: home-service * portName: http * protocol: HTTP * timeoutSec: 10 * loadBalancingScheme: EXTERNAL_MANAGED * healthChecks: ${default.id} * cart-backend: * type: gcp:compute:RegionBackendService * properties: * region: us-central1 * name: cart-service * portName: http * protocol: HTTP * timeoutSec: 10 * loadBalancingScheme: EXTERNAL_MANAGED * healthChecks: ${default.id} * user-backend: * type: gcp:compute:RegionBackendService * properties: * region: us-central1 * name: user-service * portName: http * protocol: HTTP * timeoutSec: 10 * loadBalancingScheme: EXTERNAL_MANAGED * healthChecks: ${default.id} * default: * type: gcp:compute:RegionHealthCheck * properties: * region: us-central1 * name: health-check * checkIntervalSec: 1 * timeoutSec: 1 * httpHealthCheck: * port: 80 * requestPath: / * ``` * * ## Import * RegionUrlMap can be imported using any of these accepted formats: * * `projects/{{project}}/regions/{{region}}/urlMaps/{{name}}` * * `{{project}}/{{region}}/{{name}}` * * `{{region}}/{{name}}` * * `{{name}}` * When using the `pulumi import` command, RegionUrlMap can be imported using one of the formats above. For example: * ```sh * $ pulumi import gcp:compute/regionUrlMap:RegionUrlMap default projects/{{project}}/regions/{{region}}/urlMaps/{{name}} * ``` * ```sh * $ pulumi import gcp:compute/regionUrlMap:RegionUrlMap default {{project}}/{{region}}/{{name}} * ``` * ```sh * $ pulumi import gcp:compute/regionUrlMap:RegionUrlMap default {{region}}/{{name}} * ``` * ```sh * $ pulumi import gcp:compute/regionUrlMap:RegionUrlMap default {{name}} * ``` * @property defaultRouteAction defaultRouteAction takes effect when none of the hostRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. * Only one of defaultRouteAction or defaultUrlRedirect must be set. * URL maps for Classic external HTTP(S) load balancers only support the urlRewrite action within defaultRouteAction. * defaultRouteAction has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true. * Structure is documented below. * @property defaultService The full or partial URL of the defaultService resource to which traffic is directed if * none of the hostRules match. If defaultRouteAction is additionally specified, advanced * routing actions like URL Rewrites, etc. take effect prior to sending the request to the * backend. However, if defaultService is specified, defaultRouteAction cannot contain any * weightedBackendServices. Conversely, if routeAction specifies any * weightedBackendServices, service must not be specified. Only one of defaultService, * defaultUrlRedirect or defaultRouteAction.weightedBackendService must be set. * @property defaultUrlRedirect When none of the specified hostRules match, the request is redirected to a URL specified * by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or * defaultRouteAction must not be set. * Structure is documented below. * @property description An optional description of this resource. Provide this property when * you create the resource. * @property hostRules The list of HostRules to use against the URL. * Structure is documented below. * @property name Name of the resource. Provided by the client when the resource is * created. The name must be 1-63 characters long, and comply with * RFC1035. Specifically, the name must be 1-63 characters long and match * the regular expression `a-z?` which means the * first character must be a lowercase letter, and all following * characters must be a dash, lowercase letter, or digit, except the last * character, which cannot be a dash. * - - - * @property pathMatchers The list of named PathMatchers to use against the URL. * Structure is documented below. * @property project The ID of the project in which the resource belongs. * If it is not provided, the provider project is used. * @property region The Region in which the url map should reside. * If it is not provided, the provider region is used. * @property tests The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. * */*/*/*/*/*/*/*/*/*/*/*/ */ public data class RegionUrlMapArgs( public val defaultRouteAction: Output? = null, public val defaultService: Output? = null, public val defaultUrlRedirect: Output? = null, public val description: Output? = null, public val hostRules: Output>? = null, public val name: Output? = null, public val pathMatchers: Output>? = null, public val project: Output? = null, public val region: Output? = null, public val tests: Output>? = null, ) : ConvertibleToJava { override fun toJava(): com.pulumi.gcp.compute.RegionUrlMapArgs = com.pulumi.gcp.compute.RegionUrlMapArgs.builder() .defaultRouteAction( defaultRouteAction?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }), ) .defaultService(defaultService?.applyValue({ args0 -> args0 })) .defaultUrlRedirect( defaultUrlRedirect?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }), ) .description(description?.applyValue({ args0 -> args0 })) .hostRules( hostRules?.applyValue({ args0 -> args0.map({ args0 -> args0.let({ args0 -> args0.toJava() }) }) }), ) .name(name?.applyValue({ args0 -> args0 })) .pathMatchers( pathMatchers?.applyValue({ args0 -> args0.map({ args0 -> args0.let({ args0 -> args0.toJava() }) }) }), ) .project(project?.applyValue({ args0 -> args0 })) .region(region?.applyValue({ args0 -> args0 })) .tests( tests?.applyValue({ args0 -> args0.map({ args0 -> args0.let({ args0 -> args0.toJava() }) }) }), ).build() } /** * Builder for [RegionUrlMapArgs]. */ @PulumiTagMarker public class RegionUrlMapArgsBuilder internal constructor() { private var defaultRouteAction: Output? = null private var defaultService: Output? = null private var defaultUrlRedirect: Output? = null private var description: Output? = null private var hostRules: Output>? = null private var name: Output? = null private var pathMatchers: Output>? = null private var project: Output? = null private var region: Output? = null private var tests: Output>? = null /** * @param value defaultRouteAction takes effect when none of the hostRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. * Only one of defaultRouteAction or defaultUrlRedirect must be set. * URL maps for Classic external HTTP(S) load balancers only support the urlRewrite action within defaultRouteAction. * defaultRouteAction has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true. * Structure is documented below. */ @JvmName("sqyngmkhyqscmoxv") public suspend fun defaultRouteAction(`value`: Output) { this.defaultRouteAction = value } /** * @param value The full or partial URL of the defaultService resource to which traffic is directed if * none of the hostRules match. If defaultRouteAction is additionally specified, advanced * routing actions like URL Rewrites, etc. take effect prior to sending the request to the * backend. However, if defaultService is specified, defaultRouteAction cannot contain any * weightedBackendServices. Conversely, if routeAction specifies any * weightedBackendServices, service must not be specified. Only one of defaultService, * defaultUrlRedirect or defaultRouteAction.weightedBackendService must be set. */ @JvmName("ynipiaifsakiyhqg") public suspend fun defaultService(`value`: Output) { this.defaultService = value } /** * @param value When none of the specified hostRules match, the request is redirected to a URL specified * by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or * defaultRouteAction must not be set. * Structure is documented below. */ @JvmName("uwueoqrxijgpvnml") public suspend fun defaultUrlRedirect(`value`: Output) { this.defaultUrlRedirect = value } /** * @param value An optional description of this resource. Provide this property when * you create the resource. */ @JvmName("nbqlkcpmmhtschiy") public suspend fun description(`value`: Output) { this.description = value } /** * @param value The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("sgbmnrilyrydeqct") public suspend fun hostRules(`value`: Output>) { this.hostRules = value } @JvmName("gdrmvmebrvhibyng") public suspend fun hostRules(vararg values: Output) { this.hostRules = Output.all(values.asList()) } /** * @param values The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("tqybobeqtbofdvaw") public suspend fun hostRules(values: List>) { this.hostRules = Output.all(values) } /** * @param value Name of the resource. Provided by the client when the resource is * created. The name must be 1-63 characters long, and comply with * RFC1035. Specifically, the name must be 1-63 characters long and match * the regular expression `a-z?` which means the * first character must be a lowercase letter, and all following * characters must be a dash, lowercase letter, or digit, except the last * character, which cannot be a dash. * - - - */ @JvmName("bgqwmesflijonhia") public suspend fun name(`value`: Output) { this.name = value } /** * @param value The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("jxawxkeautuwwmjs") public suspend fun pathMatchers(`value`: Output>) { this.pathMatchers = value } @JvmName("cuknplqbkoipbqky") public suspend fun pathMatchers(vararg values: Output) { this.pathMatchers = Output.all(values.asList()) } /** * @param values The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("efchnbvhmrfiqiwg") public suspend fun pathMatchers(values: List>) { this.pathMatchers = Output.all(values) } /** * @param value The ID of the project in which the resource belongs. * If it is not provided, the provider project is used. */ @JvmName("afnmnessqhhgidxn") public suspend fun project(`value`: Output) { this.project = value } /** * @param value The Region in which the url map should reside. * If it is not provided, the provider region is used. */ @JvmName("lnkhntpcoevwwqnd") public suspend fun region(`value`: Output) { this.region = value } /** * @param value The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("qwaefiekxaueupgt") public suspend fun tests(`value`: Output>) { this.tests = value } @JvmName("wcresxuujfcrbjun") public suspend fun tests(vararg values: Output) { this.tests = Output.all(values.asList()) } /** * @param values The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("pdtxmatnlcdwufek") public suspend fun tests(values: List>) { this.tests = Output.all(values) } /** * @param value defaultRouteAction takes effect when none of the hostRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. * Only one of defaultRouteAction or defaultUrlRedirect must be set. * URL maps for Classic external HTTP(S) load balancers only support the urlRewrite action within defaultRouteAction. * defaultRouteAction has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true. * Structure is documented below. */ @JvmName("qhqicwicuyktowbw") public suspend fun defaultRouteAction(`value`: RegionUrlMapDefaultRouteActionArgs?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.defaultRouteAction = mapped } /** * @param argument defaultRouteAction takes effect when none of the hostRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. * Only one of defaultRouteAction or defaultUrlRedirect must be set. * URL maps for Classic external HTTP(S) load balancers only support the urlRewrite action within defaultRouteAction. * defaultRouteAction has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true. * Structure is documented below. */ @JvmName("ewbmhewirqxnnpii") public suspend fun defaultRouteAction(argument: suspend RegionUrlMapDefaultRouteActionArgsBuilder.() -> Unit) { val toBeMapped = RegionUrlMapDefaultRouteActionArgsBuilder().applySuspend { argument() }.build() val mapped = of(toBeMapped) this.defaultRouteAction = mapped } /** * @param value The full or partial URL of the defaultService resource to which traffic is directed if * none of the hostRules match. If defaultRouteAction is additionally specified, advanced * routing actions like URL Rewrites, etc. take effect prior to sending the request to the * backend. However, if defaultService is specified, defaultRouteAction cannot contain any * weightedBackendServices. Conversely, if routeAction specifies any * weightedBackendServices, service must not be specified. Only one of defaultService, * defaultUrlRedirect or defaultRouteAction.weightedBackendService must be set. */ @JvmName("gairedqynreuydrq") public suspend fun defaultService(`value`: String?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.defaultService = mapped } /** * @param value When none of the specified hostRules match, the request is redirected to a URL specified * by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or * defaultRouteAction must not be set. * Structure is documented below. */ @JvmName("cleiptpaqfwydssn") public suspend fun defaultUrlRedirect(`value`: RegionUrlMapDefaultUrlRedirectArgs?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.defaultUrlRedirect = mapped } /** * @param argument When none of the specified hostRules match, the request is redirected to a URL specified * by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or * defaultRouteAction must not be set. * Structure is documented below. */ @JvmName("popkefoelfmrnppk") public suspend fun defaultUrlRedirect(argument: suspend RegionUrlMapDefaultUrlRedirectArgsBuilder.() -> Unit) { val toBeMapped = RegionUrlMapDefaultUrlRedirectArgsBuilder().applySuspend { argument() }.build() val mapped = of(toBeMapped) this.defaultUrlRedirect = mapped } /** * @param value An optional description of this resource. Provide this property when * you create the resource. */ @JvmName("yavrbafnsjthckow") public suspend fun description(`value`: String?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.description = mapped } /** * @param value The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("ujmstwfekituxbol") public suspend fun hostRules(`value`: List?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.hostRules = mapped } /** * @param argument The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("gwnsjmsramhsbxvg") public suspend fun hostRules(argument: List Unit>) { val toBeMapped = argument.toList().map { RegionUrlMapHostRuleArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.hostRules = mapped } /** * @param argument The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("sqckdknvucbkqiik") public suspend fun hostRules(vararg argument: suspend RegionUrlMapHostRuleArgsBuilder.() -> Unit) { val toBeMapped = argument.toList().map { RegionUrlMapHostRuleArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.hostRules = mapped } /** * @param argument The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("amxmyfafonlkyrmi") public suspend fun hostRules(argument: suspend RegionUrlMapHostRuleArgsBuilder.() -> Unit) { val toBeMapped = listOf(RegionUrlMapHostRuleArgsBuilder().applySuspend { argument() }.build()) val mapped = of(toBeMapped) this.hostRules = mapped } /** * @param values The list of HostRules to use against the URL. * Structure is documented below. */ @JvmName("eahrituyycdqrvis") public suspend fun hostRules(vararg values: RegionUrlMapHostRuleArgs) { val toBeMapped = values.toList() val mapped = toBeMapped.let({ args0 -> of(args0) }) this.hostRules = mapped } /** * @param value Name of the resource. Provided by the client when the resource is * created. The name must be 1-63 characters long, and comply with * RFC1035. Specifically, the name must be 1-63 characters long and match * the regular expression `a-z?` which means the * first character must be a lowercase letter, and all following * characters must be a dash, lowercase letter, or digit, except the last * character, which cannot be a dash. * - - - */ @JvmName("oaliddjxjwhdsldt") public suspend fun name(`value`: String?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.name = mapped } /** * @param value The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("lbmegsojltujrhrq") public suspend fun pathMatchers(`value`: List?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.pathMatchers = mapped } /** * @param argument The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("yggkkjppknknperr") public suspend fun pathMatchers(argument: List Unit>) { val toBeMapped = argument.toList().map { RegionUrlMapPathMatcherArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.pathMatchers = mapped } /** * @param argument The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("xhapuvrkdeqjpfar") public suspend fun pathMatchers(vararg argument: suspend RegionUrlMapPathMatcherArgsBuilder.() -> Unit) { val toBeMapped = argument.toList().map { RegionUrlMapPathMatcherArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.pathMatchers = mapped } /** * @param argument The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("ctavowkxunkhgdfc") public suspend fun pathMatchers(argument: suspend RegionUrlMapPathMatcherArgsBuilder.() -> Unit) { val toBeMapped = listOf( RegionUrlMapPathMatcherArgsBuilder().applySuspend { argument() }.build(), ) val mapped = of(toBeMapped) this.pathMatchers = mapped } /** * @param values The list of named PathMatchers to use against the URL. * Structure is documented below. */ @JvmName("dijtkdqeasgwfxmi") public suspend fun pathMatchers(vararg values: RegionUrlMapPathMatcherArgs) { val toBeMapped = values.toList() val mapped = toBeMapped.let({ args0 -> of(args0) }) this.pathMatchers = mapped } /** * @param value The ID of the project in which the resource belongs. * If it is not provided, the provider project is used. */ @JvmName("nfsyncmdyadddwau") public suspend fun project(`value`: String?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.project = mapped } /** * @param value The Region in which the url map should reside. * If it is not provided, the provider region is used. */ @JvmName("njrbiirypowxgbdf") public suspend fun region(`value`: String?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.region = mapped } /** * @param value The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("hlwuvxqylnvxvaww") public suspend fun tests(`value`: List?) { val toBeMapped = value val mapped = toBeMapped?.let({ args0 -> of(args0) }) this.tests = mapped } /** * @param argument The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("rsupkayacgetigor") public suspend fun tests(argument: List Unit>) { val toBeMapped = argument.toList().map { RegionUrlMapTestArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.tests = mapped } /** * @param argument The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("tjnljpehgiaferdv") public suspend fun tests(vararg argument: suspend RegionUrlMapTestArgsBuilder.() -> Unit) { val toBeMapped = argument.toList().map { RegionUrlMapTestArgsBuilder().applySuspend { it() }.build() } val mapped = of(toBeMapped) this.tests = mapped } /** * @param argument The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("iuhawlysaeskvquu") public suspend fun tests(argument: suspend RegionUrlMapTestArgsBuilder.() -> Unit) { val toBeMapped = listOf(RegionUrlMapTestArgsBuilder().applySuspend { argument() }.build()) val mapped = of(toBeMapped) this.tests = mapped } /** * @param values The list of expected URL mappings. Requests to update this UrlMap will * succeed only if all of the test cases pass. * Structure is documented below. */ @JvmName("auvupivrofpbhnej") public suspend fun tests(vararg values: RegionUrlMapTestArgs) { val toBeMapped = values.toList() val mapped = toBeMapped.let({ args0 -> of(args0) }) this.tests = mapped } internal fun build(): RegionUrlMapArgs = RegionUrlMapArgs( defaultRouteAction = defaultRouteAction, defaultService = defaultService, defaultUrlRedirect = defaultUrlRedirect, description = description, hostRules = hostRules, name = name, pathMatchers = pathMatchers, project = project, region = region, tests = tests, ) }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy