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

com.pulumi.gcp.networkservices.kotlin.EdgeCacheServiceArgs.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.13.1.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.networkservices.kotlin

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.networkservices.EdgeCacheServiceArgs.builder
import com.pulumi.gcp.networkservices.kotlin.inputs.EdgeCacheServiceLogConfigArgs
import com.pulumi.gcp.networkservices.kotlin.inputs.EdgeCacheServiceLogConfigArgsBuilder
import com.pulumi.gcp.networkservices.kotlin.inputs.EdgeCacheServiceRoutingArgs
import com.pulumi.gcp.networkservices.kotlin.inputs.EdgeCacheServiceRoutingArgsBuilder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Boolean
import kotlin.Pair
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import kotlin.jvm.JvmName

/**
 * EdgeCacheService defines the IP addresses, protocols, security policies, cache policies and routing configuration.
 * > **Warning:** These resources require allow-listing to use, and are not openly available to all Cloud customers. Engage with your Cloud account team to discuss how to onboard.
 * ## Example Usage
 * ### Network Services Edge Cache Service Basic
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const dest = new gcp.storage.Bucket("dest", {
 *     name: "my-bucket",
 *     location: "US",
 *     forceDestroy: true,
 * });
 * const instance = new gcp.networkservices.EdgeCacheOrigin("instance", {
 *     name: "my-origin",
 *     originAddress: dest.url,
 *     description: "The default bucket for media edge test",
 *     maxAttempts: 2,
 *     timeout: {
 *         connectTimeout: "10s",
 *     },
 * });
 * const instanceEdgeCacheService = new gcp.networkservices.EdgeCacheService("instance", {
 *     name: "my-service",
 *     description: "some description",
 *     routing: {
 *         hostRules: [{
 *             description: "host rule description",
 *             hosts: ["sslcert.tf-test.club"],
 *             pathMatcher: "routes",
 *         }],
 *         pathMatchers: [{
 *             name: "routes",
 *             routeRules: [{
 *                 description: "a route rule to match against",
 *                 priority: "1",
 *                 matchRules: [{
 *                     prefixMatch: "/",
 *                 }],
 *                 origin: instance.name,
 *                 routeAction: {
 *                     cdnPolicy: {
 *                         cacheMode: "CACHE_ALL_STATIC",
 *                         defaultTtl: "3600s",
 *                     },
 *                 },
 *                 headerAction: {
 *                     responseHeaderToAdds: [{
 *                         headerName: "x-cache-status",
 *                         headerValue: "{cdn_cache_status}",
 *                     }],
 *                 },
 *             }],
 *         }],
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * dest = gcp.storage.Bucket("dest",
 *     name="my-bucket",
 *     location="US",
 *     force_destroy=True)
 * instance = gcp.networkservices.EdgeCacheOrigin("instance",
 *     name="my-origin",
 *     origin_address=dest.url,
 *     description="The default bucket for media edge test",
 *     max_attempts=2,
 *     timeout={
 *         "connect_timeout": "10s",
 *     })
 * instance_edge_cache_service = gcp.networkservices.EdgeCacheService("instance",
 *     name="my-service",
 *     description="some description",
 *     routing={
 *         "host_rules": [{
 *             "description": "host rule description",
 *             "hosts": ["sslcert.tf-test.club"],
 *             "path_matcher": "routes",
 *         }],
 *         "path_matchers": [{
 *             "name": "routes",
 *             "route_rules": [{
 *                 "description": "a route rule to match against",
 *                 "priority": "1",
 *                 "match_rules": [{
 *                     "prefix_match": "/",
 *                 }],
 *                 "origin": instance.name,
 *                 "route_action": {
 *                     "cdn_policy": {
 *                         "cache_mode": "CACHE_ALL_STATIC",
 *                         "default_ttl": "3600s",
 *                     },
 *                 },
 *                 "header_action": {
 *                     "response_header_to_adds": [{
 *                         "header_name": "x-cache-status",
 *                         "header_value": "{cdn_cache_status}",
 *                     }],
 *                 },
 *             }],
 *         }],
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var dest = new Gcp.Storage.Bucket("dest", new()
 *     {
 *         Name = "my-bucket",
 *         Location = "US",
 *         ForceDestroy = true,
 *     });
 *     var instance = new Gcp.NetworkServices.EdgeCacheOrigin("instance", new()
 *     {
 *         Name = "my-origin",
 *         OriginAddress = dest.Url,
 *         Description = "The default bucket for media edge test",
 *         MaxAttempts = 2,
 *         Timeout = new Gcp.NetworkServices.Inputs.EdgeCacheOriginTimeoutArgs
 *         {
 *             ConnectTimeout = "10s",
 *         },
 *     });
 *     var instanceEdgeCacheService = new Gcp.NetworkServices.EdgeCacheService("instance", new()
 *     {
 *         Name = "my-service",
 *         Description = "some description",
 *         Routing = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingArgs
 *         {
 *             HostRules = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingHostRuleArgs
 *                 {
 *                     Description = "host rule description",
 *                     Hosts = new[]
 *                     {
 *                         "sslcert.tf-test.club",
 *                     },
 *                     PathMatcher = "routes",
 *                 },
 *             },
 *             PathMatchers = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherArgs
 *                 {
 *                     Name = "routes",
 *                     RouteRules = new[]
 *                     {
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a route rule to match against",
 *                             Priority = "1",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PrefixMatch = "/",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     CacheMode = "CACHE_ALL_STATIC",
 *                                     DefaultTtl = "3600s",
 *                                 },
 *                             },
 *                             HeaderAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs
 *                             {
 *                                 ResponseHeaderToAdds = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs
 *                                     {
 *                                         HeaderName = "x-cache-status",
 *                                         HeaderValue = "{cdn_cache_status}",
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/networkservices"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		dest, err := storage.NewBucket(ctx, "dest", &storage.BucketArgs{
 * 			Name:         pulumi.String("my-bucket"),
 * 			Location:     pulumi.String("US"),
 * 			ForceDestroy: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		instance, err := networkservices.NewEdgeCacheOrigin(ctx, "instance", &networkservices.EdgeCacheOriginArgs{
 * 			Name:          pulumi.String("my-origin"),
 * 			OriginAddress: dest.Url,
 * 			Description:   pulumi.String("The default bucket for media edge test"),
 * 			MaxAttempts:   pulumi.Int(2),
 * 			Timeout: &networkservices.EdgeCacheOriginTimeoutArgs{
 * 				ConnectTimeout: pulumi.String("10s"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = networkservices.NewEdgeCacheService(ctx, "instance", &networkservices.EdgeCacheServiceArgs{
 * 			Name:        pulumi.String("my-service"),
 * 			Description: pulumi.String("some description"),
 * 			Routing: &networkservices.EdgeCacheServiceRoutingArgs{
 * 				HostRules: networkservices.EdgeCacheServiceRoutingHostRuleArray{
 * 					&networkservices.EdgeCacheServiceRoutingHostRuleArgs{
 * 						Description: pulumi.String("host rule description"),
 * 						Hosts: pulumi.StringArray{
 * 							pulumi.String("sslcert.tf-test.club"),
 * 						},
 * 						PathMatcher: pulumi.String("routes"),
 * 					},
 * 				},
 * 				PathMatchers: networkservices.EdgeCacheServiceRoutingPathMatcherArray{
 * 					&networkservices.EdgeCacheServiceRoutingPathMatcherArgs{
 * 						Name: pulumi.String("routes"),
 * 						RouteRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArray{
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a route rule to match against"),
 * 								Priority:    pulumi.String("1"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PrefixMatch: pulumi.String("/"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										CacheMode:  pulumi.String("CACHE_ALL_STATIC"),
 * 										DefaultTtl: pulumi.String("3600s"),
 * 									},
 * 								},
 * 								HeaderAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs{
 * 									ResponseHeaderToAdds: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs{
 * 											HeaderName:  pulumi.String("x-cache-status"),
 * 											HeaderValue: pulumi.String("{cdn_cache_status}"),
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 		})
 * 		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.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheOrigin;
 * import com.pulumi.gcp.networkservices.EdgeCacheOriginArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheOriginTimeoutArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheService;
 * import com.pulumi.gcp.networkservices.EdgeCacheServiceArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheServiceRoutingArgs;
 * 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 dest = new Bucket("dest", BucketArgs.builder()
 *             .name("my-bucket")
 *             .location("US")
 *             .forceDestroy(true)
 *             .build());
 *         var instance = new EdgeCacheOrigin("instance", EdgeCacheOriginArgs.builder()
 *             .name("my-origin")
 *             .originAddress(dest.url())
 *             .description("The default bucket for media edge test")
 *             .maxAttempts(2)
 *             .timeout(EdgeCacheOriginTimeoutArgs.builder()
 *                 .connectTimeout("10s")
 *                 .build())
 *             .build());
 *         var instanceEdgeCacheService = new EdgeCacheService("instanceEdgeCacheService", EdgeCacheServiceArgs.builder()
 *             .name("my-service")
 *             .description("some description")
 *             .routing(EdgeCacheServiceRoutingArgs.builder()
 *                 .hostRules(EdgeCacheServiceRoutingHostRuleArgs.builder()
 *                     .description("host rule description")
 *                     .hosts("sslcert.tf-test.club")
 *                     .pathMatcher("routes")
 *                     .build())
 *                 .pathMatchers(EdgeCacheServiceRoutingPathMatcherArgs.builder()
 *                     .name("routes")
 *                     .routeRules(EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                         .description("a route rule to match against")
 *                         .priority(1)
 *                         .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                             .prefixMatch("/")
 *                             .build())
 *                         .origin(instance.name())
 *                         .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                             .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                 .cacheMode("CACHE_ALL_STATIC")
 *                                 .defaultTtl("3600s")
 *                                 .build())
 *                             .build())
 *                         .headerAction(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs.builder()
 *                             .responseHeaderToAdds(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs.builder()
 *                                 .headerName("x-cache-status")
 *                                 .headerValue("{cdn_cache_status}")
 *                                 .build())
 *                             .build())
 *                         .build())
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   dest:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: my-bucket
 *       location: US
 *       forceDestroy: true
 *   instance:
 *     type: gcp:networkservices:EdgeCacheOrigin
 *     properties:
 *       name: my-origin
 *       originAddress: ${dest.url}
 *       description: The default bucket for media edge test
 *       maxAttempts: 2
 *       timeout:
 *         connectTimeout: 10s
 *   instanceEdgeCacheService:
 *     type: gcp:networkservices:EdgeCacheService
 *     name: instance
 *     properties:
 *       name: my-service
 *       description: some description
 *       routing:
 *         hostRules:
 *           - description: host rule description
 *             hosts:
 *               - sslcert.tf-test.club
 *             pathMatcher: routes
 *         pathMatchers:
 *           - name: routes
 *             routeRules:
 *               - description: a route rule to match against
 *                 priority: 1
 *                 matchRules:
 *                   - prefixMatch: /
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     cacheMode: CACHE_ALL_STATIC
 *                     defaultTtl: 3600s
 *                 headerAction:
 *                   responseHeaderToAdds:
 *                     - headerName: x-cache-status
 *                       headerValue: '{cdn_cache_status}'
 * ```
 * 
 * ### Network Services Edge Cache Service Advanced
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const dest = new gcp.storage.Bucket("dest", {
 *     name: "my-bucket",
 *     location: "US",
 *     forceDestroy: true,
 * });
 * const google = new gcp.networkservices.EdgeCacheOrigin("google", {
 *     name: "origin-google",
 *     originAddress: "google.com",
 *     description: "The default bucket for media edge test",
 *     maxAttempts: 2,
 *     timeout: {
 *         connectTimeout: "10s",
 *     },
 * });
 * const instance = new gcp.networkservices.EdgeCacheOrigin("instance", {
 *     name: "my-origin",
 *     originAddress: dest.url,
 *     description: "The default bucket for media edge test",
 *     maxAttempts: 2,
 *     timeout: {
 *         connectTimeout: "10s",
 *     },
 * });
 * const instanceEdgeCacheService = new gcp.networkservices.EdgeCacheService("instance", {
 *     name: "my-service",
 *     description: "some description",
 *     disableQuic: true,
 *     disableHttp2: true,
 *     labels: {
 *         a: "b",
 *     },
 *     routing: {
 *         hostRules: [
 *             {
 *                 description: "host rule description",
 *                 hosts: ["sslcert.tf-test.club"],
 *                 pathMatcher: "routes",
 *             },
 *             {
 *                 description: "host rule2",
 *                 hosts: ["sslcert.tf-test2.club"],
 *                 pathMatcher: "routes",
 *             },
 *             {
 *                 description: "host rule3",
 *                 hosts: ["sslcert.tf-test3.club"],
 *                 pathMatcher: "routesAdvanced",
 *             },
 *         ],
 *         pathMatchers: [
 *             {
 *                 name: "routes",
 *                 routeRules: [{
 *                     description: "a route rule to match against",
 *                     priority: "1",
 *                     matchRules: [{
 *                         prefixMatch: "/",
 *                     }],
 *                     origin: instance.name,
 *                     routeAction: {
 *                         cdnPolicy: {
 *                             cacheMode: "CACHE_ALL_STATIC",
 *                             defaultTtl: "3600s",
 *                         },
 *                     },
 *                     headerAction: {
 *                         responseHeaderToAdds: [{
 *                             headerName: "x-cache-status",
 *                             headerValue: "{cdn_cache_status}",
 *                         }],
 *                     },
 *                 }],
 *             },
 *             {
 *                 name: "routesAdvanced",
 *                 description: "an advanced ruleset",
 *                 routeRules: [
 *                     {
 *                         description: "an advanced route rule to match against",
 *                         priority: "1",
 *                         matchRules: [
 *                             {
 *                                 prefixMatch: "/potato/",
 *                                 queryParameterMatches: [
 *                                     {
 *                                         name: "debug",
 *                                         presentMatch: true,
 *                                     },
 *                                     {
 *                                         name: "state",
 *                                         exactMatch: "debug",
 *                                     },
 *                                 ],
 *                             },
 *                             {
 *                                 fullPathMatch: "/apple",
 *                             },
 *                         ],
 *                         headerAction: {
 *                             requestHeaderToAdds: [
 *                                 {
 *                                     headerName: "debug",
 *                                     headerValue: "true",
 *                                     replace: true,
 *                                 },
 *                                 {
 *                                     headerName: "potato",
 *                                     headerValue: "plant",
 *                                 },
 *                             ],
 *                             responseHeaderToAdds: [{
 *                                 headerName: "potato",
 *                                 headerValue: "plant",
 *                                 replace: true,
 *                             }],
 *                             requestHeaderToRemoves: [{
 *                                 headerName: "prod",
 *                             }],
 *                             responseHeaderToRemoves: [{
 *                                 headerName: "prod",
 *                             }],
 *                         },
 *                         origin: instance.name,
 *                         routeAction: {
 *                             cdnPolicy: {
 *                                 cacheMode: "CACHE_ALL_STATIC",
 *                                 defaultTtl: "3800s",
 *                                 clientTtl: "3600s",
 *                                 maxTtl: "9000s",
 *                                 cacheKeyPolicy: {
 *                                     includeProtocol: true,
 *                                     excludeHost: true,
 *                                     includedQueryParameters: [
 *                                         "apple",
 *                                         "dev",
 *                                         "santa",
 *                                         "claus",
 *                                     ],
 *                                     includedHeaderNames: ["banana"],
 *                                     includedCookieNames: ["orange"],
 *                                 },
 *                                 negativeCaching: true,
 *                                 signedRequestMode: "DISABLED",
 *                                 negativeCachingPolicy: {
 *                                     "500": "3000s",
 *                                 },
 *                             },
 *                             urlRewrite: {
 *                                 pathPrefixRewrite: "/dev",
 *                                 hostRewrite: "dev.club",
 *                             },
 *                             corsPolicy: {
 *                                 maxAge: "2500s",
 *                                 allowCredentials: true,
 *                                 allowOrigins: ["*"],
 *                                 allowMethods: ["GET"],
 *                                 allowHeaders: ["dev"],
 *                                 exposeHeaders: ["prod"],
 *                             },
 *                         },
 *                     },
 *                     {
 *                         description: "a second route rule to match against",
 *                         priority: "2",
 *                         matchRules: [{
 *                             fullPathMatch: "/yay",
 *                         }],
 *                         origin: instance.name,
 *                         routeAction: {
 *                             cdnPolicy: {
 *                                 cacheMode: "CACHE_ALL_STATIC",
 *                                 defaultTtl: "3600s",
 *                                 cacheKeyPolicy: {
 *                                     excludedQueryParameters: ["dev"],
 *                                 },
 *                             },
 *                             corsPolicy: {
 *                                 maxAge: "3000s",
 *                                 allowHeaders: ["dev"],
 *                                 disabled: true,
 *                             },
 *                         },
 *                     },
 *                 ],
 *             },
 *         ],
 *     },
 *     logConfig: {
 *         enable: true,
 *         sampleRate: 0.01,
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * dest = gcp.storage.Bucket("dest",
 *     name="my-bucket",
 *     location="US",
 *     force_destroy=True)
 * google = gcp.networkservices.EdgeCacheOrigin("google",
 *     name="origin-google",
 *     origin_address="google.com",
 *     description="The default bucket for media edge test",
 *     max_attempts=2,
 *     timeout={
 *         "connect_timeout": "10s",
 *     })
 * instance = gcp.networkservices.EdgeCacheOrigin("instance",
 *     name="my-origin",
 *     origin_address=dest.url,
 *     description="The default bucket for media edge test",
 *     max_attempts=2,
 *     timeout={
 *         "connect_timeout": "10s",
 *     })
 * instance_edge_cache_service = gcp.networkservices.EdgeCacheService("instance",
 *     name="my-service",
 *     description="some description",
 *     disable_quic=True,
 *     disable_http2=True,
 *     labels={
 *         "a": "b",
 *     },
 *     routing={
 *         "host_rules": [
 *             {
 *                 "description": "host rule description",
 *                 "hosts": ["sslcert.tf-test.club"],
 *                 "path_matcher": "routes",
 *             },
 *             {
 *                 "description": "host rule2",
 *                 "hosts": ["sslcert.tf-test2.club"],
 *                 "path_matcher": "routes",
 *             },
 *             {
 *                 "description": "host rule3",
 *                 "hosts": ["sslcert.tf-test3.club"],
 *                 "path_matcher": "routesAdvanced",
 *             },
 *         ],
 *         "path_matchers": [
 *             {
 *                 "name": "routes",
 *                 "route_rules": [{
 *                     "description": "a route rule to match against",
 *                     "priority": "1",
 *                     "match_rules": [{
 *                         "prefix_match": "/",
 *                     }],
 *                     "origin": instance.name,
 *                     "route_action": {
 *                         "cdn_policy": {
 *                             "cache_mode": "CACHE_ALL_STATIC",
 *                             "default_ttl": "3600s",
 *                         },
 *                     },
 *                     "header_action": {
 *                         "response_header_to_adds": [{
 *                             "header_name": "x-cache-status",
 *                             "header_value": "{cdn_cache_status}",
 *                         }],
 *                     },
 *                 }],
 *             },
 *             {
 *                 "name": "routesAdvanced",
 *                 "description": "an advanced ruleset",
 *                 "route_rules": [
 *                     {
 *                         "description": "an advanced route rule to match against",
 *                         "priority": "1",
 *                         "match_rules": [
 *                             {
 *                                 "prefix_match": "/potato/",
 *                                 "query_parameter_matches": [
 *                                     {
 *                                         "name": "debug",
 *                                         "present_match": True,
 *                                     },
 *                                     {
 *                                         "name": "state",
 *                                         "exact_match": "debug",
 *                                     },
 *                                 ],
 *                             },
 *                             {
 *                                 "full_path_match": "/apple",
 *                             },
 *                         ],
 *                         "header_action": {
 *                             "request_header_to_adds": [
 *                                 {
 *                                     "header_name": "debug",
 *                                     "header_value": "true",
 *                                     "replace": True,
 *                                 },
 *                                 {
 *                                     "header_name": "potato",
 *                                     "header_value": "plant",
 *                                 },
 *                             ],
 *                             "response_header_to_adds": [{
 *                                 "header_name": "potato",
 *                                 "header_value": "plant",
 *                                 "replace": True,
 *                             }],
 *                             "request_header_to_removes": [{
 *                                 "header_name": "prod",
 *                             }],
 *                             "response_header_to_removes": [{
 *                                 "header_name": "prod",
 *                             }],
 *                         },
 *                         "origin": instance.name,
 *                         "route_action": {
 *                             "cdn_policy": {
 *                                 "cache_mode": "CACHE_ALL_STATIC",
 *                                 "default_ttl": "3800s",
 *                                 "client_ttl": "3600s",
 *                                 "max_ttl": "9000s",
 *                                 "cache_key_policy": {
 *                                     "include_protocol": True,
 *                                     "exclude_host": True,
 *                                     "included_query_parameters": [
 *                                         "apple",
 *                                         "dev",
 *                                         "santa",
 *                                         "claus",
 *                                     ],
 *                                     "included_header_names": ["banana"],
 *                                     "included_cookie_names": ["orange"],
 *                                 },
 *                                 "negative_caching": True,
 *                                 "signed_request_mode": "DISABLED",
 *                                 "negative_caching_policy": {
 *                                     "500": "3000s",
 *                                 },
 *                             },
 *                             "url_rewrite": {
 *                                 "path_prefix_rewrite": "/dev",
 *                                 "host_rewrite": "dev.club",
 *                             },
 *                             "cors_policy": {
 *                                 "max_age": "2500s",
 *                                 "allow_credentials": True,
 *                                 "allow_origins": ["*"],
 *                                 "allow_methods": ["GET"],
 *                                 "allow_headers": ["dev"],
 *                                 "expose_headers": ["prod"],
 *                             },
 *                         },
 *                     },
 *                     {
 *                         "description": "a second route rule to match against",
 *                         "priority": "2",
 *                         "match_rules": [{
 *                             "full_path_match": "/yay",
 *                         }],
 *                         "origin": instance.name,
 *                         "route_action": {
 *                             "cdn_policy": {
 *                                 "cache_mode": "CACHE_ALL_STATIC",
 *                                 "default_ttl": "3600s",
 *                                 "cache_key_policy": {
 *                                     "excluded_query_parameters": ["dev"],
 *                                 },
 *                             },
 *                             "cors_policy": {
 *                                 "max_age": "3000s",
 *                                 "allow_headers": ["dev"],
 *                                 "disabled": True,
 *                             },
 *                         },
 *                     },
 *                 ],
 *             },
 *         ],
 *     },
 *     log_config={
 *         "enable": True,
 *         "sample_rate": 0.01,
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var dest = new Gcp.Storage.Bucket("dest", new()
 *     {
 *         Name = "my-bucket",
 *         Location = "US",
 *         ForceDestroy = true,
 *     });
 *     var google = new Gcp.NetworkServices.EdgeCacheOrigin("google", new()
 *     {
 *         Name = "origin-google",
 *         OriginAddress = "google.com",
 *         Description = "The default bucket for media edge test",
 *         MaxAttempts = 2,
 *         Timeout = new Gcp.NetworkServices.Inputs.EdgeCacheOriginTimeoutArgs
 *         {
 *             ConnectTimeout = "10s",
 *         },
 *     });
 *     var instance = new Gcp.NetworkServices.EdgeCacheOrigin("instance", new()
 *     {
 *         Name = "my-origin",
 *         OriginAddress = dest.Url,
 *         Description = "The default bucket for media edge test",
 *         MaxAttempts = 2,
 *         Timeout = new Gcp.NetworkServices.Inputs.EdgeCacheOriginTimeoutArgs
 *         {
 *             ConnectTimeout = "10s",
 *         },
 *     });
 *     var instanceEdgeCacheService = new Gcp.NetworkServices.EdgeCacheService("instance", new()
 *     {
 *         Name = "my-service",
 *         Description = "some description",
 *         DisableQuic = true,
 *         DisableHttp2 = true,
 *         Labels =
 *         {
 *             { "a", "b" },
 *         },
 *         Routing = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingArgs
 *         {
 *             HostRules = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingHostRuleArgs
 *                 {
 *                     Description = "host rule description",
 *                     Hosts = new[]
 *                     {
 *                         "sslcert.tf-test.club",
 *                     },
 *                     PathMatcher = "routes",
 *                 },
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingHostRuleArgs
 *                 {
 *                     Description = "host rule2",
 *                     Hosts = new[]
 *                     {
 *                         "sslcert.tf-test2.club",
 *                     },
 *                     PathMatcher = "routes",
 *                 },
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingHostRuleArgs
 *                 {
 *                     Description = "host rule3",
 *                     Hosts = new[]
 *                     {
 *                         "sslcert.tf-test3.club",
 *                     },
 *                     PathMatcher = "routesAdvanced",
 *                 },
 *             },
 *             PathMatchers = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherArgs
 *                 {
 *                     Name = "routes",
 *                     RouteRules = new[]
 *                     {
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a route rule to match against",
 *                             Priority = "1",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PrefixMatch = "/",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     CacheMode = "CACHE_ALL_STATIC",
 *                                     DefaultTtl = "3600s",
 *                                 },
 *                             },
 *                             HeaderAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs
 *                             {
 *                                 ResponseHeaderToAdds = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs
 *                                     {
 *                                         HeaderName = "x-cache-status",
 *                                         HeaderValue = "{cdn_cache_status}",
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherArgs
 *                 {
 *                     Name = "routesAdvanced",
 *                     Description = "an advanced ruleset",
 *                     RouteRules = new[]
 *                     {
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "an advanced route rule to match against",
 *                             Priority = "1",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PrefixMatch = "/potato/",
 *                                     QueryParameterMatches = new[]
 *                                     {
 *                                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs
 *                                         {
 *                                             Name = "debug",
 *                                             PresentMatch = true,
 *                                         },
 *                                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs
 *                                         {
 *                                             Name = "state",
 *                                             ExactMatch = "debug",
 *                                         },
 *                                     },
 *                                 },
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     FullPathMatch = "/apple",
 *                                 },
 *                             },
 *                             HeaderAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs
 *                             {
 *                                 RequestHeaderToAdds = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs
 *                                     {
 *                                         HeaderName = "debug",
 *                                         HeaderValue = "true",
 *                                         Replace = true,
 *                                     },
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs
 *                                     {
 *                                         HeaderName = "potato",
 *                                         HeaderValue = "plant",
 *                                     },
 *                                 },
 *                                 ResponseHeaderToAdds = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs
 *                                     {
 *                                         HeaderName = "potato",
 *                                         HeaderValue = "plant",
 *                                         Replace = true,
 *                                     },
 *                                 },
 *                                 RequestHeaderToRemoves = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToRemoveArgs
 *                                     {
 *                                         HeaderName = "prod",
 *                                     },
 *                                 },
 *                                 ResponseHeaderToRemoves = new[]
 *                                 {
 *                                     new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToRemoveArgs
 *                                     {
 *                                         HeaderName = "prod",
 *                                     },
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     CacheMode = "CACHE_ALL_STATIC",
 *                                     DefaultTtl = "3800s",
 *                                     ClientTtl = "3600s",
 *                                     MaxTtl = "9000s",
 *                                     CacheKeyPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs
 *                                     {
 *                                         IncludeProtocol = true,
 *                                         ExcludeHost = true,
 *                                         IncludedQueryParameters = new[]
 *                                         {
 *                                             "apple",
 *                                             "dev",
 *                                             "santa",
 *                                             "claus",
 *                                         },
 *                                         IncludedHeaderNames = new[]
 *                                         {
 *                                             "banana",
 *                                         },
 *                                         IncludedCookieNames = new[]
 *                                         {
 *                                             "orange",
 *                                         },
 *                                     },
 *                                     NegativeCaching = true,
 *                                     SignedRequestMode = "DISABLED",
 *                                     NegativeCachingPolicy =
 *                                     {
 *                                         { "500", "3000s" },
 *                                     },
 *                                 },
 *                                 UrlRewrite = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionUrlRewriteArgs
 *                                 {
 *                                     PathPrefixRewrite = "/dev",
 *                                     HostRewrite = "dev.club",
 *                                 },
 *                                 CorsPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs
 *                                 {
 *                                     MaxAge = "2500s",
 *                                     AllowCredentials = true,
 *                                     AllowOrigins = new[]
 *                                     {
 *                                         "*",
 *                                     },
 *                                     AllowMethods = new[]
 *                                     {
 *                                         "GET",
 *                                     },
 *                                     AllowHeaders = new[]
 *                                     {
 *                                         "dev",
 *                                     },
 *                                     ExposeHeaders = new[]
 *                                     {
 *                                         "prod",
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a second route rule to match against",
 *                             Priority = "2",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     FullPathMatch = "/yay",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     CacheMode = "CACHE_ALL_STATIC",
 *                                     DefaultTtl = "3600s",
 *                                     CacheKeyPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs
 *                                     {
 *                                         ExcludedQueryParameters = new[]
 *                                         {
 *                                             "dev",
 *                                         },
 *                                     },
 *                                 },
 *                                 CorsPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs
 *                                 {
 *                                     MaxAge = "3000s",
 *                                     AllowHeaders = new[]
 *                                     {
 *                                         "dev",
 *                                     },
 *                                     Disabled = true,
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *         LogConfig = new Gcp.NetworkServices.Inputs.EdgeCacheServiceLogConfigArgs
 *         {
 *             Enable = true,
 *             SampleRate = 0.01,
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/networkservices"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		dest, err := storage.NewBucket(ctx, "dest", &storage.BucketArgs{
 * 			Name:         pulumi.String("my-bucket"),
 * 			Location:     pulumi.String("US"),
 * 			ForceDestroy: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = networkservices.NewEdgeCacheOrigin(ctx, "google", &networkservices.EdgeCacheOriginArgs{
 * 			Name:          pulumi.String("origin-google"),
 * 			OriginAddress: pulumi.String("google.com"),
 * 			Description:   pulumi.String("The default bucket for media edge test"),
 * 			MaxAttempts:   pulumi.Int(2),
 * 			Timeout: &networkservices.EdgeCacheOriginTimeoutArgs{
 * 				ConnectTimeout: pulumi.String("10s"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		instance, err := networkservices.NewEdgeCacheOrigin(ctx, "instance", &networkservices.EdgeCacheOriginArgs{
 * 			Name:          pulumi.String("my-origin"),
 * 			OriginAddress: dest.Url,
 * 			Description:   pulumi.String("The default bucket for media edge test"),
 * 			MaxAttempts:   pulumi.Int(2),
 * 			Timeout: &networkservices.EdgeCacheOriginTimeoutArgs{
 * 				ConnectTimeout: pulumi.String("10s"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = networkservices.NewEdgeCacheService(ctx, "instance", &networkservices.EdgeCacheServiceArgs{
 * 			Name:         pulumi.String("my-service"),
 * 			Description:  pulumi.String("some description"),
 * 			DisableQuic:  pulumi.Bool(true),
 * 			DisableHttp2: pulumi.Bool(true),
 * 			Labels: pulumi.StringMap{
 * 				"a": pulumi.String("b"),
 * 			},
 * 			Routing: &networkservices.EdgeCacheServiceRoutingArgs{
 * 				HostRules: networkservices.EdgeCacheServiceRoutingHostRuleArray{
 * 					&networkservices.EdgeCacheServiceRoutingHostRuleArgs{
 * 						Description: pulumi.String("host rule description"),
 * 						Hosts: pulumi.StringArray{
 * 							pulumi.String("sslcert.tf-test.club"),
 * 						},
 * 						PathMatcher: pulumi.String("routes"),
 * 					},
 * 					&networkservices.EdgeCacheServiceRoutingHostRuleArgs{
 * 						Description: pulumi.String("host rule2"),
 * 						Hosts: pulumi.StringArray{
 * 							pulumi.String("sslcert.tf-test2.club"),
 * 						},
 * 						PathMatcher: pulumi.String("routes"),
 * 					},
 * 					&networkservices.EdgeCacheServiceRoutingHostRuleArgs{
 * 						Description: pulumi.String("host rule3"),
 * 						Hosts: pulumi.StringArray{
 * 							pulumi.String("sslcert.tf-test3.club"),
 * 						},
 * 						PathMatcher: pulumi.String("routesAdvanced"),
 * 					},
 * 				},
 * 				PathMatchers: networkservices.EdgeCacheServiceRoutingPathMatcherArray{
 * 					&networkservices.EdgeCacheServiceRoutingPathMatcherArgs{
 * 						Name: pulumi.String("routes"),
 * 						RouteRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArray{
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a route rule to match against"),
 * 								Priority:    pulumi.String("1"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PrefixMatch: pulumi.String("/"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										CacheMode:  pulumi.String("CACHE_ALL_STATIC"),
 * 										DefaultTtl: pulumi.String("3600s"),
 * 									},
 * 								},
 * 								HeaderAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs{
 * 									ResponseHeaderToAdds: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs{
 * 											HeaderName:  pulumi.String("x-cache-status"),
 * 											HeaderValue: pulumi.String("{cdn_cache_status}"),
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 					&networkservices.EdgeCacheServiceRoutingPathMatcherArgs{
 * 						Name:        pulumi.String("routesAdvanced"),
 * 						Description: pulumi.String("an advanced ruleset"),
 * 						RouteRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArray{
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("an advanced route rule to match against"),
 * 								Priority:    pulumi.String("1"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PrefixMatch: pulumi.String("/potato/"),
 * 										QueryParameterMatches: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArray{
 * 											&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs{
 * 												Name:         pulumi.String("debug"),
 * 												PresentMatch: pulumi.Bool(true),
 * 											},
 * 											&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs{
 * 												Name:       pulumi.String("state"),
 * 												ExactMatch: pulumi.String("debug"),
 * 											},
 * 										},
 * 									},
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										FullPathMatch: pulumi.String("/apple"),
 * 									},
 * 								},
 * 								HeaderAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs{
 * 									RequestHeaderToAdds: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs{
 * 											HeaderName:  pulumi.String("debug"),
 * 											HeaderValue: pulumi.String("true"),
 * 											Replace:     pulumi.Bool(true),
 * 										},
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs{
 * 											HeaderName:  pulumi.String("potato"),
 * 											HeaderValue: pulumi.String("plant"),
 * 										},
 * 									},
 * 									ResponseHeaderToAdds: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs{
 * 											HeaderName:  pulumi.String("potato"),
 * 											HeaderValue: pulumi.String("plant"),
 * 											Replace:     pulumi.Bool(true),
 * 										},
 * 									},
 * 									RequestHeaderToRemoves: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToRemoveArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToRemoveArgs{
 * 											HeaderName: pulumi.String("prod"),
 * 										},
 * 									},
 * 									ResponseHeaderToRemoves: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToRemoveArray{
 * 										&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToRemoveArgs{
 * 											HeaderName: pulumi.String("prod"),
 * 										},
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										CacheMode:  pulumi.String("CACHE_ALL_STATIC"),
 * 										DefaultTtl: pulumi.String("3800s"),
 * 										ClientTtl:  pulumi.String("3600s"),
 * 										MaxTtl:     pulumi.String("9000s"),
 * 										CacheKeyPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs{
 * 											IncludeProtocol: pulumi.Bool(true),
 * 											ExcludeHost:     pulumi.Bool(true),
 * 											IncludedQueryParameters: pulumi.StringArray{
 * 												pulumi.String("apple"),
 * 												pulumi.String("dev"),
 * 												pulumi.String("santa"),
 * 												pulumi.String("claus"),
 * 											},
 * 											IncludedHeaderNames: pulumi.StringArray{
 * 												pulumi.String("banana"),
 * 											},
 * 											IncludedCookieNames: pulumi.StringArray{
 * 												pulumi.String("orange"),
 * 											},
 * 										},
 * 										NegativeCaching:   pulumi.Bool(true),
 * 										SignedRequestMode: pulumi.String("DISABLED"),
 * 										NegativeCachingPolicy: pulumi.StringMap{
 * 											"500": pulumi.String("3000s"),
 * 										},
 * 									},
 * 									UrlRewrite: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionUrlRewriteArgs{
 * 										PathPrefixRewrite: pulumi.String("/dev"),
 * 										HostRewrite:       pulumi.String("dev.club"),
 * 									},
 * 									CorsPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs{
 * 										MaxAge:           pulumi.String("2500s"),
 * 										AllowCredentials: pulumi.Bool(true),
 * 										AllowOrigins: pulumi.StringArray{
 * 											pulumi.String("*"),
 * 										},
 * 										AllowMethods: pulumi.StringArray{
 * 											pulumi.String("GET"),
 * 										},
 * 										AllowHeaders: pulumi.StringArray{
 * 											pulumi.String("dev"),
 * 										},
 * 										ExposeHeaders: pulumi.StringArray{
 * 											pulumi.String("prod"),
 * 										},
 * 									},
 * 								},
 * 							},
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a second route rule to match against"),
 * 								Priority:    pulumi.String("2"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										FullPathMatch: pulumi.String("/yay"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										CacheMode:  pulumi.String("CACHE_ALL_STATIC"),
 * 										DefaultTtl: pulumi.String("3600s"),
 * 										CacheKeyPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs{
 * 											ExcludedQueryParameters: pulumi.StringArray{
 * 												pulumi.String("dev"),
 * 											},
 * 										},
 * 									},
 * 									CorsPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs{
 * 										MaxAge: pulumi.String("3000s"),
 * 										AllowHeaders: pulumi.StringArray{
 * 											pulumi.String("dev"),
 * 										},
 * 										Disabled: pulumi.Bool(true),
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 			LogConfig: &networkservices.EdgeCacheServiceLogConfigArgs{
 * 				Enable:     pulumi.Bool(true),
 * 				SampleRate: pulumi.Float64(0.01),
 * 			},
 * 		})
 * 		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.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheOrigin;
 * import com.pulumi.gcp.networkservices.EdgeCacheOriginArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheOriginTimeoutArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheService;
 * import com.pulumi.gcp.networkservices.EdgeCacheServiceArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheServiceRoutingArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheServiceLogConfigArgs;
 * 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 dest = new Bucket("dest", BucketArgs.builder()
 *             .name("my-bucket")
 *             .location("US")
 *             .forceDestroy(true)
 *             .build());
 *         var google = new EdgeCacheOrigin("google", EdgeCacheOriginArgs.builder()
 *             .name("origin-google")
 *             .originAddress("google.com")
 *             .description("The default bucket for media edge test")
 *             .maxAttempts(2)
 *             .timeout(EdgeCacheOriginTimeoutArgs.builder()
 *                 .connectTimeout("10s")
 *                 .build())
 *             .build());
 *         var instance = new EdgeCacheOrigin("instance", EdgeCacheOriginArgs.builder()
 *             .name("my-origin")
 *             .originAddress(dest.url())
 *             .description("The default bucket for media edge test")
 *             .maxAttempts(2)
 *             .timeout(EdgeCacheOriginTimeoutArgs.builder()
 *                 .connectTimeout("10s")
 *                 .build())
 *             .build());
 *         var instanceEdgeCacheService = new EdgeCacheService("instanceEdgeCacheService", EdgeCacheServiceArgs.builder()
 *             .name("my-service")
 *             .description("some description")
 *             .disableQuic(true)
 *             .disableHttp2(true)
 *             .labels(Map.of("a", "b"))
 *             .routing(EdgeCacheServiceRoutingArgs.builder()
 *                 .hostRules(
 *                     EdgeCacheServiceRoutingHostRuleArgs.builder()
 *                         .description("host rule description")
 *                         .hosts("sslcert.tf-test.club")
 *                         .pathMatcher("routes")
 *                         .build(),
 *                     EdgeCacheServiceRoutingHostRuleArgs.builder()
 *                         .description("host rule2")
 *                         .hosts("sslcert.tf-test2.club")
 *                         .pathMatcher("routes")
 *                         .build(),
 *                     EdgeCacheServiceRoutingHostRuleArgs.builder()
 *                         .description("host rule3")
 *                         .hosts("sslcert.tf-test3.club")
 *                         .pathMatcher("routesAdvanced")
 *                         .build())
 *                 .pathMatchers(
 *                     EdgeCacheServiceRoutingPathMatcherArgs.builder()
 *                         .name("routes")
 *                         .routeRules(EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                             .description("a route rule to match against")
 *                             .priority(1)
 *                             .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                 .prefixMatch("/")
 *                                 .build())
 *                             .origin(instance.name())
 *                             .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                 .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                     .cacheMode("CACHE_ALL_STATIC")
 *                                     .defaultTtl("3600s")
 *                                     .build())
 *                                 .build())
 *                             .headerAction(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs.builder()
 *                                 .responseHeaderToAdds(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs.builder()
 *                                     .headerName("x-cache-status")
 *                                     .headerValue("{cdn_cache_status}")
 *                                     .build())
 *                                 .build())
 *                             .build())
 *                         .build(),
 *                     EdgeCacheServiceRoutingPathMatcherArgs.builder()
 *                         .name("routesAdvanced")
 *                         .description("an advanced ruleset")
 *                         .routeRules(
 *                             EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                                 .description("an advanced route rule to match against")
 *                                 .priority(1)
 *                                 .matchRules(
 *                                     EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                         .prefixMatch("/potato/")
 *                                         .queryParameterMatches(
 *                                             EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs.builder()
 *                                                 .name("debug")
 *                                                 .presentMatch(true)
 *                                                 .build(),
 *                                             EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleQueryParameterMatchArgs.builder()
 *                                                 .name("state")
 *                                                 .exactMatch("debug")
 *                                                 .build())
 *                                         .build(),
 *                                     EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                         .fullPathMatch("/apple")
 *                                         .build())
 *                                 .headerAction(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionArgs.builder()
 *                                     .requestHeaderToAdds(
 *                                         EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs.builder()
 *                                             .headerName("debug")
 *                                             .headerValue("true")
 *                                             .replace(true)
 *                                             .build(),
 *                                         EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToAddArgs.builder()
 *                                             .headerName("potato")
 *                                             .headerValue("plant")
 *                                             .build())
 *                                     .responseHeaderToAdds(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToAddArgs.builder()
 *                                         .headerName("potato")
 *                                         .headerValue("plant")
 *                                         .replace(true)
 *                                         .build())
 *                                     .requestHeaderToRemoves(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionRequestHeaderToRemoveArgs.builder()
 *                                         .headerName("prod")
 *                                         .build())
 *                                     .responseHeaderToRemoves(EdgeCacheServiceRoutingPathMatcherRouteRuleHeaderActionResponseHeaderToRemoveArgs.builder()
 *                                         .headerName("prod")
 *                                         .build())
 *                                     .build())
 *                                 .origin(instance.name())
 *                                 .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                     .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                         .cacheMode("CACHE_ALL_STATIC")
 *                                         .defaultTtl("3800s")
 *                                         .clientTtl("3600s")
 *                                         .maxTtl("9000s")
 *                                         .cacheKeyPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs.builder()
 *                                             .includeProtocol(true)
 *                                             .excludeHost(true)
 *                                             .includedQueryParameters(
 *                                                 "apple",
 *                                                 "dev",
 *                                                 "santa",
 *                                                 "claus")
 *                                             .includedHeaderNames("banana")
 *                                             .includedCookieNames("orange")
 *                                             .build())
 *                                         .negativeCaching(true)
 *                                         .signedRequestMode("DISABLED")
 *                                         .negativeCachingPolicy(Map.of("500", "3000s"))
 *                                         .build())
 *                                     .urlRewrite(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionUrlRewriteArgs.builder()
 *                                         .pathPrefixRewrite("/dev")
 *                                         .hostRewrite("dev.club")
 *                                         .build())
 *                                     .corsPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs.builder()
 *                                         .maxAge("2500s")
 *                                         .allowCredentials(true)
 *                                         .allowOrigins("*")
 *                                         .allowMethods("GET")
 *                                         .allowHeaders("dev")
 *                                         .exposeHeaders("prod")
 *                                         .build())
 *                                     .build())
 *                                 .build(),
 *                             EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                                 .description("a second route rule to match against")
 *                                 .priority(2)
 *                                 .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                     .fullPathMatch("/yay")
 *                                     .build())
 *                                 .origin(instance.name())
 *                                 .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                     .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                         .cacheMode("CACHE_ALL_STATIC")
 *                                         .defaultTtl("3600s")
 *                                         .cacheKeyPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyCacheKeyPolicyArgs.builder()
 *                                             .excludedQueryParameters("dev")
 *                                             .build())
 *                                         .build())
 *                                     .corsPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCorsPolicyArgs.builder()
 *                                         .maxAge("3000s")
 *                                         .allowHeaders("dev")
 *                                         .disabled(true)
 *                                         .build())
 *                                     .build())
 *                                 .build())
 *                         .build())
 *                 .build())
 *             .logConfig(EdgeCacheServiceLogConfigArgs.builder()
 *                 .enable(true)
 *                 .sampleRate(0.01)
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   dest:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: my-bucket
 *       location: US
 *       forceDestroy: true
 *   google:
 *     type: gcp:networkservices:EdgeCacheOrigin
 *     properties:
 *       name: origin-google
 *       originAddress: google.com
 *       description: The default bucket for media edge test
 *       maxAttempts: 2
 *       timeout:
 *         connectTimeout: 10s
 *   instance:
 *     type: gcp:networkservices:EdgeCacheOrigin
 *     properties:
 *       name: my-origin
 *       originAddress: ${dest.url}
 *       description: The default bucket for media edge test
 *       maxAttempts: 2
 *       timeout:
 *         connectTimeout: 10s
 *   instanceEdgeCacheService:
 *     type: gcp:networkservices:EdgeCacheService
 *     name: instance
 *     properties:
 *       name: my-service
 *       description: some description
 *       disableQuic: true
 *       disableHttp2: true
 *       labels:
 *         a: b
 *       routing:
 *         hostRules:
 *           - description: host rule description
 *             hosts:
 *               - sslcert.tf-test.club
 *             pathMatcher: routes
 *           - description: host rule2
 *             hosts:
 *               - sslcert.tf-test2.club
 *             pathMatcher: routes
 *           - description: host rule3
 *             hosts:
 *               - sslcert.tf-test3.club
 *             pathMatcher: routesAdvanced
 *         pathMatchers:
 *           - name: routes
 *             routeRules:
 *               - description: a route rule to match against
 *                 priority: 1
 *                 matchRules:
 *                   - prefixMatch: /
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     cacheMode: CACHE_ALL_STATIC
 *                     defaultTtl: 3600s
 *                 headerAction:
 *                   responseHeaderToAdds:
 *                     - headerName: x-cache-status
 *                       headerValue: '{cdn_cache_status}'
 *           - name: routesAdvanced
 *             description: an advanced ruleset
 *             routeRules:
 *               - description: an advanced route rule to match against
 *                 priority: 1
 *                 matchRules:
 *                   - prefixMatch: /potato/
 *                     queryParameterMatches:
 *                       - name: debug
 *                         presentMatch: true
 *                       - name: state
 *                         exactMatch: debug
 *                   - fullPathMatch: /apple
 *                 headerAction:
 *                   requestHeaderToAdds:
 *                     - headerName: debug
 *                       headerValue: 'true'
 *                       replace: true
 *                     - headerName: potato
 *                       headerValue: plant
 *                   responseHeaderToAdds:
 *                     - headerName: potato
 *                       headerValue: plant
 *                       replace: true
 *                   requestHeaderToRemoves:
 *                     - headerName: prod
 *                   responseHeaderToRemoves:
 *                     - headerName: prod
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     cacheMode: CACHE_ALL_STATIC
 *                     defaultTtl: 3800s
 *                     clientTtl: 3600s
 *                     maxTtl: 9000s
 *                     cacheKeyPolicy:
 *                       includeProtocol: true
 *                       excludeHost: true
 *                       includedQueryParameters:
 *                         - apple
 *                         - dev
 *                         - santa
 *                         - claus
 *                       includedHeaderNames:
 *                         - banana
 *                       includedCookieNames:
 *                         - orange
 *                     negativeCaching: true
 *                     signedRequestMode: DISABLED
 *                     negativeCachingPolicy:
 *                       '500': 3000s
 *                   urlRewrite:
 *                     pathPrefixRewrite: /dev
 *                     hostRewrite: dev.club
 *                   corsPolicy:
 *                     maxAge: 2500s
 *                     allowCredentials: true
 *                     allowOrigins:
 *                       - '*'
 *                     allowMethods:
 *                       - GET
 *                     allowHeaders:
 *                       - dev
 *                     exposeHeaders:
 *                       - prod
 *               - description: a second route rule to match against
 *                 priority: 2
 *                 matchRules:
 *                   - fullPathMatch: /yay
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     cacheMode: CACHE_ALL_STATIC
 *                     defaultTtl: 3600s
 *                     cacheKeyPolicy:
 *                       excludedQueryParameters:
 *                         - dev
 *                   corsPolicy:
 *                     maxAge: 3000s
 *                     allowHeaders:
 *                       - dev
 *                     disabled: true
 *       logConfig:
 *         enable: true
 *         sampleRate: 0.01
 * ```
 * 
 * ### Network Services Edge Cache Service Dual Token
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const secret_basic = new gcp.secretmanager.Secret("secret-basic", {
 *     secretId: "secret-name",
 *     replication: {
 *         auto: {},
 *     },
 * });
 * const secret_version_basic = new gcp.secretmanager.SecretVersion("secret-version-basic", {
 *     secret: secret_basic.id,
 *     secretData: "secret-data",
 * });
 * const keyset = new gcp.networkservices.EdgeCacheKeyset("keyset", {
 *     name: "keyset-name",
 *     description: "The default keyset",
 *     publicKeys: [{
 *         id: "my-public-key",
 *         managed: true,
 *     }],
 *     validationSharedKeys: [{
 *         secretVersion: secret_version_basic.id,
 *     }],
 * });
 * const instance = new gcp.networkservices.EdgeCacheOrigin("instance", {
 *     name: "my-origin",
 *     originAddress: "gs://media-edge-default",
 *     description: "The default bucket for media edge test",
 * });
 * const instanceEdgeCacheService = new gcp.networkservices.EdgeCacheService("instance", {
 *     name: "my-service",
 *     description: "some description",
 *     routing: {
 *         hostRules: [{
 *             description: "host rule description",
 *             hosts: ["sslcert.tf-test.club"],
 *             pathMatcher: "routes",
 *         }],
 *         pathMatchers: [{
 *             name: "routes",
 *             routeRules: [
 *                 {
 *                     description: "a route rule to match against master playlist",
 *                     priority: "1",
 *                     matchRules: [{
 *                         pathTemplateMatch: "/master.m3u8",
 *                     }],
 *                     origin: instance.name,
 *                     routeAction: {
 *                         cdnPolicy: {
 *                             signedRequestMode: "REQUIRE_TOKENS",
 *                             signedRequestKeyset: keyset.id,
 *                             signedTokenOptions: {
 *                                 tokenQueryParameter: "edge-cache-token",
 *                             },
 *                             signedRequestMaximumExpirationTtl: "600s",
 *                             addSignatures: {
 *                                 actions: "GENERATE_COOKIE",
 *                                 keyset: keyset.id,
 *                                 copiedParameters: [
 *                                     "PathGlobs",
 *                                     "SessionID",
 *                                 ],
 *                             },
 *                         },
 *                     },
 *                 },
 *                 {
 *                     description: "a route rule to match against all playlists",
 *                     priority: "2",
 *                     matchRules: [{
 *                         pathTemplateMatch: "/*.m3u8",
 *                     }],
 *                     origin: instance.name,
 *                     routeAction: {
 *                         cdnPolicy: {
 *                             signedRequestMode: "REQUIRE_TOKENS",
 *                             signedRequestKeyset: keyset.id,
 *                             signedTokenOptions: {
 *                                 tokenQueryParameter: "hdnts",
 *                                 allowedSignatureAlgorithms: [
 *                                     "ED25519",
 *                                     "HMAC_SHA_256",
 *                                     "HMAC_SHA1",
 *                                 ],
 *                             },
 *                             addSignatures: {
 *                                 actions: "GENERATE_TOKEN_HLS_COOKIELESS",
 *                                 keyset: keyset.id,
 *                                 tokenTtl: "1200s",
 *                                 tokenQueryParameter: "hdntl",
 *                                 copiedParameters: ["URLPrefix"],
 *                             },
 *                         },
 *                     },
 *                 },
 *                 {
 *                     description: "a route rule to match against",
 *                     priority: "3",
 *                     matchRules: [{
 *                         pathTemplateMatch: "/**.m3u8",
 *                     }],
 *                     origin: instance.name,
 *                     routeAction: {
 *                         cdnPolicy: {
 *                             signedRequestMode: "REQUIRE_TOKENS",
 *                             signedRequestKeyset: keyset.id,
 *                             signedTokenOptions: {
 *                                 tokenQueryParameter: "hdntl",
 *                             },
 *                             addSignatures: {
 *                                 actions: "PROPAGATE_TOKEN_HLS_COOKIELESS",
 *                                 tokenQueryParameter: "hdntl",
 *                             },
 *                         },
 *                     },
 *                 },
 *             ],
 *         }],
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * secret_basic = gcp.secretmanager.Secret("secret-basic",
 *     secret_id="secret-name",
 *     replication={
 *         "auto": {},
 *     })
 * secret_version_basic = gcp.secretmanager.SecretVersion("secret-version-basic",
 *     secret=secret_basic.id,
 *     secret_data="secret-data")
 * keyset = gcp.networkservices.EdgeCacheKeyset("keyset",
 *     name="keyset-name",
 *     description="The default keyset",
 *     public_keys=[{
 *         "id": "my-public-key",
 *         "managed": True,
 *     }],
 *     validation_shared_keys=[{
 *         "secret_version": secret_version_basic.id,
 *     }])
 * instance = gcp.networkservices.EdgeCacheOrigin("instance",
 *     name="my-origin",
 *     origin_address="gs://media-edge-default",
 *     description="The default bucket for media edge test")
 * instance_edge_cache_service = gcp.networkservices.EdgeCacheService("instance",
 *     name="my-service",
 *     description="some description",
 *     routing={
 *         "host_rules": [{
 *             "description": "host rule description",
 *             "hosts": ["sslcert.tf-test.club"],
 *             "path_matcher": "routes",
 *         }],
 *         "path_matchers": [{
 *             "name": "routes",
 *             "route_rules": [
 *                 {
 *                     "description": "a route rule to match against master playlist",
 *                     "priority": "1",
 *                     "match_rules": [{
 *                         "path_template_match": "/master.m3u8",
 *                     }],
 *                     "origin": instance.name,
 *                     "route_action": {
 *                         "cdn_policy": {
 *                             "signed_request_mode": "REQUIRE_TOKENS",
 *                             "signed_request_keyset": keyset.id,
 *                             "signed_token_options": {
 *                                 "token_query_parameter": "edge-cache-token",
 *                             },
 *                             "signed_request_maximum_expiration_ttl": "600s",
 *                             "add_signatures": {
 *                                 "actions": "GENERATE_COOKIE",
 *                                 "keyset": keyset.id,
 *                                 "copied_parameters": [
 *                                     "PathGlobs",
 *                                     "SessionID",
 *                                 ],
 *                             },
 *                         },
 *                     },
 *                 },
 *                 {
 *                     "description": "a route rule to match against all playlists",
 *                     "priority": "2",
 *                     "match_rules": [{
 *                         "path_template_match": "/*.m3u8",
 *                     }],
 *                     "origin": instance.name,
 *                     "route_action": {
 *                         "cdn_policy": {
 *                             "signed_request_mode": "REQUIRE_TOKENS",
 *                             "signed_request_keyset": keyset.id,
 *                             "signed_token_options": {
 *                                 "token_query_parameter": "hdnts",
 *                                 "allowed_signature_algorithms": [
 *                                     "ED25519",
 *                                     "HMAC_SHA_256",
 *                                     "HMAC_SHA1",
 *                                 ],
 *                             },
 *                             "add_signatures": {
 *                                 "actions": "GENERATE_TOKEN_HLS_COOKIELESS",
 *                                 "keyset": keyset.id,
 *                                 "token_ttl": "1200s",
 *                                 "token_query_parameter": "hdntl",
 *                                 "copied_parameters": ["URLPrefix"],
 *                             },
 *                         },
 *                     },
 *                 },
 *                 {
 *                     "description": "a route rule to match against",
 *                     "priority": "3",
 *                     "match_rules": [{
 *                         "path_template_match": "/**.m3u8",
 *                     }],
 *                     "origin": instance.name,
 *                     "route_action": {
 *                         "cdn_policy": {
 *                             "signed_request_mode": "REQUIRE_TOKENS",
 *                             "signed_request_keyset": keyset.id,
 *                             "signed_token_options": {
 *                                 "token_query_parameter": "hdntl",
 *                             },
 *                             "add_signatures": {
 *                                 "actions": "PROPAGATE_TOKEN_HLS_COOKIELESS",
 *                                 "token_query_parameter": "hdntl",
 *                             },
 *                         },
 *                     },
 *                 },
 *             ],
 *         }],
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var secret_basic = new Gcp.SecretManager.Secret("secret-basic", new()
 *     {
 *         SecretId = "secret-name",
 *         Replication = new Gcp.SecretManager.Inputs.SecretReplicationArgs
 *         {
 *             Auto = null,
 *         },
 *     });
 *     var secret_version_basic = new Gcp.SecretManager.SecretVersion("secret-version-basic", new()
 *     {
 *         Secret = secret_basic.Id,
 *         SecretData = "secret-data",
 *     });
 *     var keyset = new Gcp.NetworkServices.EdgeCacheKeyset("keyset", new()
 *     {
 *         Name = "keyset-name",
 *         Description = "The default keyset",
 *         PublicKeys = new[]
 *         {
 *             new Gcp.NetworkServices.Inputs.EdgeCacheKeysetPublicKeyArgs
 *             {
 *                 Id = "my-public-key",
 *                 Managed = true,
 *             },
 *         },
 *         ValidationSharedKeys = new[]
 *         {
 *             new Gcp.NetworkServices.Inputs.EdgeCacheKeysetValidationSharedKeyArgs
 *             {
 *                 SecretVersion = secret_version_basic.Id,
 *             },
 *         },
 *     });
 *     var instance = new Gcp.NetworkServices.EdgeCacheOrigin("instance", new()
 *     {
 *         Name = "my-origin",
 *         OriginAddress = "gs://media-edge-default",
 *         Description = "The default bucket for media edge test",
 *     });
 *     var instanceEdgeCacheService = new Gcp.NetworkServices.EdgeCacheService("instance", new()
 *     {
 *         Name = "my-service",
 *         Description = "some description",
 *         Routing = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingArgs
 *         {
 *             HostRules = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingHostRuleArgs
 *                 {
 *                     Description = "host rule description",
 *                     Hosts = new[]
 *                     {
 *                         "sslcert.tf-test.club",
 *                     },
 *                     PathMatcher = "routes",
 *                 },
 *             },
 *             PathMatchers = new[]
 *             {
 *                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherArgs
 *                 {
 *                     Name = "routes",
 *                     RouteRules = new[]
 *                     {
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a route rule to match against master playlist",
 *                             Priority = "1",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PathTemplateMatch = "/master.m3u8",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     SignedRequestMode = "REQUIRE_TOKENS",
 *                                     SignedRequestKeyset = keyset.Id,
 *                                     SignedTokenOptions = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs
 *                                     {
 *                                         TokenQueryParameter = "edge-cache-token",
 *                                     },
 *                                     SignedRequestMaximumExpirationTtl = "600s",
 *                                     AddSignatures = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs
 *                                     {
 *                                         Actions = "GENERATE_COOKIE",
 *                                         Keyset = keyset.Id,
 *                                         CopiedParameters = new[]
 *                                         {
 *                                             "PathGlobs",
 *                                             "SessionID",
 *                                         },
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a route rule to match against all playlists",
 *                             Priority = "2",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PathTemplateMatch = "/*.m3u8",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     SignedRequestMode = "REQUIRE_TOKENS",
 *                                     SignedRequestKeyset = keyset.Id,
 *                                     SignedTokenOptions = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs
 *                                     {
 *                                         TokenQueryParameter = "hdnts",
 *                                         AllowedSignatureAlgorithms = new[]
 *                                         {
 *                                             "ED25519",
 *                                             "HMAC_SHA_256",
 *                                             "HMAC_SHA1",
 *                                         },
 *                                     },
 *                                     AddSignatures = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs
 *                                     {
 *                                         Actions = "GENERATE_TOKEN_HLS_COOKIELESS",
 *                                         Keyset = keyset.Id,
 *                                         TokenTtl = "1200s",
 *                                         TokenQueryParameter = "hdntl",
 *                                         CopiedParameters = new[]
 *                                         {
 *                                             "URLPrefix",
 *                                         },
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                         new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs
 *                         {
 *                             Description = "a route rule to match against",
 *                             Priority = "3",
 *                             MatchRules = new[]
 *                             {
 *                                 new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs
 *                                 {
 *                                     PathTemplateMatch = "/**.m3u8",
 *                                 },
 *                             },
 *                             Origin = instance.Name,
 *                             RouteAction = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs
 *                             {
 *                                 CdnPolicy = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs
 *                                 {
 *                                     SignedRequestMode = "REQUIRE_TOKENS",
 *                                     SignedRequestKeyset = keyset.Id,
 *                                     SignedTokenOptions = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs
 *                                     {
 *                                         TokenQueryParameter = "hdntl",
 *                                     },
 *                                     AddSignatures = new Gcp.NetworkServices.Inputs.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs
 *                                     {
 *                                         Actions = "PROPAGATE_TOKEN_HLS_COOKIELESS",
 *                                         TokenQueryParameter = "hdntl",
 *                                     },
 *                                 },
 *                             },
 *                         },
 *                     },
 *                 },
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/networkservices"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/secretmanager"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := secretmanager.NewSecret(ctx, "secret-basic", &secretmanager.SecretArgs{
 * 			SecretId: pulumi.String("secret-name"),
 * 			Replication: &secretmanager.SecretReplicationArgs{
 * 				Auto: &secretmanager.SecretReplicationAutoArgs{},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = secretmanager.NewSecretVersion(ctx, "secret-version-basic", &secretmanager.SecretVersionArgs{
 * 			Secret:     secret_basic.ID(),
 * 			SecretData: pulumi.String("secret-data"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		keyset, err := networkservices.NewEdgeCacheKeyset(ctx, "keyset", &networkservices.EdgeCacheKeysetArgs{
 * 			Name:        pulumi.String("keyset-name"),
 * 			Description: pulumi.String("The default keyset"),
 * 			PublicKeys: networkservices.EdgeCacheKeysetPublicKeyArray{
 * 				&networkservices.EdgeCacheKeysetPublicKeyArgs{
 * 					Id:      pulumi.String("my-public-key"),
 * 					Managed: pulumi.Bool(true),
 * 				},
 * 			},
 * 			ValidationSharedKeys: networkservices.EdgeCacheKeysetValidationSharedKeyArray{
 * 				&networkservices.EdgeCacheKeysetValidationSharedKeyArgs{
 * 					SecretVersion: secret_version_basic.ID(),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		instance, err := networkservices.NewEdgeCacheOrigin(ctx, "instance", &networkservices.EdgeCacheOriginArgs{
 * 			Name:          pulumi.String("my-origin"),
 * 			OriginAddress: pulumi.String("gs://media-edge-default"),
 * 			Description:   pulumi.String("The default bucket for media edge test"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = networkservices.NewEdgeCacheService(ctx, "instance", &networkservices.EdgeCacheServiceArgs{
 * 			Name:        pulumi.String("my-service"),
 * 			Description: pulumi.String("some description"),
 * 			Routing: &networkservices.EdgeCacheServiceRoutingArgs{
 * 				HostRules: networkservices.EdgeCacheServiceRoutingHostRuleArray{
 * 					&networkservices.EdgeCacheServiceRoutingHostRuleArgs{
 * 						Description: pulumi.String("host rule description"),
 * 						Hosts: pulumi.StringArray{
 * 							pulumi.String("sslcert.tf-test.club"),
 * 						},
 * 						PathMatcher: pulumi.String("routes"),
 * 					},
 * 				},
 * 				PathMatchers: networkservices.EdgeCacheServiceRoutingPathMatcherArray{
 * 					&networkservices.EdgeCacheServiceRoutingPathMatcherArgs{
 * 						Name: pulumi.String("routes"),
 * 						RouteRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArray{
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a route rule to match against master playlist"),
 * 								Priority:    pulumi.String("1"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PathTemplateMatch: pulumi.String("/master.m3u8"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										SignedRequestMode:   pulumi.String("REQUIRE_TOKENS"),
 * 										SignedRequestKeyset: keyset.ID(),
 * 										SignedTokenOptions: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs{
 * 											TokenQueryParameter: pulumi.String("edge-cache-token"),
 * 										},
 * 										SignedRequestMaximumExpirationTtl: pulumi.String("600s"),
 * 										AddSignatures: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs{
 * 											Actions: pulumi.String("GENERATE_COOKIE"),
 * 											Keyset:  keyset.ID(),
 * 											CopiedParameters: pulumi.StringArray{
 * 												pulumi.String("PathGlobs"),
 * 												pulumi.String("SessionID"),
 * 											},
 * 										},
 * 									},
 * 								},
 * 							},
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a route rule to match against all playlists"),
 * 								Priority:    pulumi.String("2"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PathTemplateMatch: pulumi.String("/*.m3u8"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										SignedRequestMode:   pulumi.String("REQUIRE_TOKENS"),
 * 										SignedRequestKeyset: keyset.ID(),
 * 										SignedTokenOptions: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs{
 * 											TokenQueryParameter: pulumi.String("hdnts"),
 * 											AllowedSignatureAlgorithms: pulumi.StringArray{
 * 												pulumi.String("ED25519"),
 * 												pulumi.String("HMAC_SHA_256"),
 * 												pulumi.String("HMAC_SHA1"),
 * 											},
 * 										},
 * 										AddSignatures: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs{
 * 											Actions:             pulumi.String("GENERATE_TOKEN_HLS_COOKIELESS"),
 * 											Keyset:              keyset.ID(),
 * 											TokenTtl:            pulumi.String("1200s"),
 * 											TokenQueryParameter: pulumi.String("hdntl"),
 * 											CopiedParameters: pulumi.StringArray{
 * 												pulumi.String("URLPrefix"),
 * 											},
 * 										},
 * 									},
 * 								},
 * 							},
 * 							&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleArgs{
 * 								Description: pulumi.String("a route rule to match against"),
 * 								Priority:    pulumi.String("3"),
 * 								MatchRules: networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArray{
 * 									&networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs{
 * 										PathTemplateMatch: pulumi.String("/**.m3u8"),
 * 									},
 * 								},
 * 								Origin: instance.Name,
 * 								RouteAction: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs{
 * 									CdnPolicy: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs{
 * 										SignedRequestMode:   pulumi.String("REQUIRE_TOKENS"),
 * 										SignedRequestKeyset: keyset.ID(),
 * 										SignedTokenOptions: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs{
 * 											TokenQueryParameter: pulumi.String("hdntl"),
 * 										},
 * 										AddSignatures: &networkservices.EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs{
 * 											Actions:             pulumi.String("PROPAGATE_TOKEN_HLS_COOKIELESS"),
 * 											TokenQueryParameter: pulumi.String("hdntl"),
 * 										},
 * 									},
 * 								},
 * 							},
 * 						},
 * 					},
 * 				},
 * 			},
 * 		})
 * 		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.secretmanager.Secret;
 * import com.pulumi.gcp.secretmanager.SecretArgs;
 * import com.pulumi.gcp.secretmanager.inputs.SecretReplicationArgs;
 * import com.pulumi.gcp.secretmanager.inputs.SecretReplicationAutoArgs;
 * import com.pulumi.gcp.secretmanager.SecretVersion;
 * import com.pulumi.gcp.secretmanager.SecretVersionArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheKeyset;
 * import com.pulumi.gcp.networkservices.EdgeCacheKeysetArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheKeysetPublicKeyArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheKeysetValidationSharedKeyArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheOrigin;
 * import com.pulumi.gcp.networkservices.EdgeCacheOriginArgs;
 * import com.pulumi.gcp.networkservices.EdgeCacheService;
 * import com.pulumi.gcp.networkservices.EdgeCacheServiceArgs;
 * import com.pulumi.gcp.networkservices.inputs.EdgeCacheServiceRoutingArgs;
 * 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 secret_basic = new Secret("secret-basic", SecretArgs.builder()
 *             .secretId("secret-name")
 *             .replication(SecretReplicationArgs.builder()
 *                 .auto()
 *                 .build())
 *             .build());
 *         var secret_version_basic = new SecretVersion("secret-version-basic", SecretVersionArgs.builder()
 *             .secret(secret_basic.id())
 *             .secretData("secret-data")
 *             .build());
 *         var keyset = new EdgeCacheKeyset("keyset", EdgeCacheKeysetArgs.builder()
 *             .name("keyset-name")
 *             .description("The default keyset")
 *             .publicKeys(EdgeCacheKeysetPublicKeyArgs.builder()
 *                 .id("my-public-key")
 *                 .managed(true)
 *                 .build())
 *             .validationSharedKeys(EdgeCacheKeysetValidationSharedKeyArgs.builder()
 *                 .secretVersion(secret_version_basic.id())
 *                 .build())
 *             .build());
 *         var instance = new EdgeCacheOrigin("instance", EdgeCacheOriginArgs.builder()
 *             .name("my-origin")
 *             .originAddress("gs://media-edge-default")
 *             .description("The default bucket for media edge test")
 *             .build());
 *         var instanceEdgeCacheService = new EdgeCacheService("instanceEdgeCacheService", EdgeCacheServiceArgs.builder()
 *             .name("my-service")
 *             .description("some description")
 *             .routing(EdgeCacheServiceRoutingArgs.builder()
 *                 .hostRules(EdgeCacheServiceRoutingHostRuleArgs.builder()
 *                     .description("host rule description")
 *                     .hosts("sslcert.tf-test.club")
 *                     .pathMatcher("routes")
 *                     .build())
 *                 .pathMatchers(EdgeCacheServiceRoutingPathMatcherArgs.builder()
 *                     .name("routes")
 *                     .routeRules(
 *                         EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                             .description("a route rule to match against master playlist")
 *                             .priority(1)
 *                             .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                 .pathTemplateMatch("/master.m3u8")
 *                                 .build())
 *                             .origin(instance.name())
 *                             .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                 .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                     .signedRequestMode("REQUIRE_TOKENS")
 *                                     .signedRequestKeyset(keyset.id())
 *                                     .signedTokenOptions(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs.builder()
 *                                         .tokenQueryParameter("edge-cache-token")
 *                                         .build())
 *                                     .signedRequestMaximumExpirationTtl("600s")
 *                                     .addSignatures(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs.builder()
 *                                         .actions("GENERATE_COOKIE")
 *                                         .keyset(keyset.id())
 *                                         .copiedParameters(
 *                                             "PathGlobs",
 *                                             "SessionID")
 *                                         .build())
 *                                     .build())
 *                                 .build())
 *                             .build(),
 *                         EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                             .description("a route rule to match against all playlists")
 *                             .priority(2)
 *                             .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                 .pathTemplateMatch("/*.m3u8")
 *                                 .build())
 *                             .origin(instance.name())
 *                             .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                 .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                     .signedRequestMode("REQUIRE_TOKENS")
 *                                     .signedRequestKeyset(keyset.id())
 *                                     .signedTokenOptions(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs.builder()
 *                                         .tokenQueryParameter("hdnts")
 *                                         .allowedSignatureAlgorithms(
 *                                             "ED25519",
 *                                             "HMAC_SHA_256",
 *                                             "HMAC_SHA1")
 *                                         .build())
 *                                     .addSignatures(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs.builder()
 *                                         .actions("GENERATE_TOKEN_HLS_COOKIELESS")
 *                                         .keyset(keyset.id())
 *                                         .tokenTtl("1200s")
 *                                         .tokenQueryParameter("hdntl")
 *                                         .copiedParameters("URLPrefix")
 *                                         .build())
 *                                     .build())
 *                                 .build())
 *                             .build(),
 *                         EdgeCacheServiceRoutingPathMatcherRouteRuleArgs.builder()
 *                             .description("a route rule to match against")
 *                             .priority(3)
 *                             .matchRules(EdgeCacheServiceRoutingPathMatcherRouteRuleMatchRuleArgs.builder()
 *                                 .pathTemplateMatch("/**.m3u8")
 *                                 .build())
 *                             .origin(instance.name())
 *                             .routeAction(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionArgs.builder()
 *                                 .cdnPolicy(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyArgs.builder()
 *                                     .signedRequestMode("REQUIRE_TOKENS")
 *                                     .signedRequestKeyset(keyset.id())
 *                                     .signedTokenOptions(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicySignedTokenOptionsArgs.builder()
 *                                         .tokenQueryParameter("hdntl")
 *                                         .build())
 *                                     .addSignatures(EdgeCacheServiceRoutingPathMatcherRouteRuleRouteActionCdnPolicyAddSignaturesArgs.builder()
 *                                         .actions("PROPAGATE_TOKEN_HLS_COOKIELESS")
 *                                         .tokenQueryParameter("hdntl")
 *                                         .build())
 *                                     .build())
 *                                 .build())
 *                             .build())
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   secret-basic:
 *     type: gcp:secretmanager:Secret
 *     properties:
 *       secretId: secret-name
 *       replication:
 *         auto: {}
 *   secret-version-basic:
 *     type: gcp:secretmanager:SecretVersion
 *     properties:
 *       secret: ${["secret-basic"].id}
 *       secretData: secret-data
 *   keyset:
 *     type: gcp:networkservices:EdgeCacheKeyset
 *     properties:
 *       name: keyset-name
 *       description: The default keyset
 *       publicKeys:
 *         - id: my-public-key
 *           managed: true
 *       validationSharedKeys:
 *         - secretVersion: ${["secret-version-basic"].id}
 *   instance:
 *     type: gcp:networkservices:EdgeCacheOrigin
 *     properties:
 *       name: my-origin
 *       originAddress: gs://media-edge-default
 *       description: The default bucket for media edge test
 *   instanceEdgeCacheService:
 *     type: gcp:networkservices:EdgeCacheService
 *     name: instance
 *     properties:
 *       name: my-service
 *       description: some description
 *       routing:
 *         hostRules:
 *           - description: host rule description
 *             hosts:
 *               - sslcert.tf-test.club
 *             pathMatcher: routes
 *         pathMatchers:
 *           - name: routes
 *             routeRules:
 *               - description: a route rule to match against master playlist
 *                 priority: 1
 *                 matchRules:
 *                   - pathTemplateMatch: /master.m3u8
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     signedRequestMode: REQUIRE_TOKENS
 *                     signedRequestKeyset: ${keyset.id}
 *                     signedTokenOptions:
 *                       tokenQueryParameter: edge-cache-token
 *                     signedRequestMaximumExpirationTtl: 600s
 *                     addSignatures:
 *                       actions: GENERATE_COOKIE
 *                       keyset: ${keyset.id}
 *                       copiedParameters:
 *                         - PathGlobs
 *                         - SessionID
 *               - description: a route rule to match against all playlists
 *                 priority: 2
 *                 matchRules:
 *                   - pathTemplateMatch: /*.m3u8
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     signedRequestMode: REQUIRE_TOKENS
 *                     signedRequestKeyset: ${keyset.id}
 *                     signedTokenOptions:
 *                       tokenQueryParameter: hdnts
 *                       allowedSignatureAlgorithms:
 *                         - ED25519
 *                         - HMAC_SHA_256
 *                         - HMAC_SHA1
 *                     addSignatures:
 *                       actions: GENERATE_TOKEN_HLS_COOKIELESS
 *                       keyset: ${keyset.id}
 *                       tokenTtl: 1200s
 *                       tokenQueryParameter: hdntl
 *                       copiedParameters:
 *                         - URLPrefix
 *               - description: a route rule to match against
 *                 priority: 3
 *                 matchRules:
 *                   - pathTemplateMatch: /**.m3u8
 *                 origin: ${instance.name}
 *                 routeAction:
 *                   cdnPolicy:
 *                     signedRequestMode: REQUIRE_TOKENS
 *                     signedRequestKeyset: ${keyset.id}
 *                     signedTokenOptions:
 *                       tokenQueryParameter: hdntl
 *                     addSignatures:
 *                       actions: PROPAGATE_TOKEN_HLS_COOKIELESS
 *                       tokenQueryParameter: hdntl
 * ```
 * 
 * ## Import
 * EdgeCacheService can be imported using any of these accepted formats:
 * * `projects/{{project}}/locations/global/edgeCacheServices/{{name}}`
 * * `{{project}}/{{name}}`
 * * `{{name}}`
 * When using the `pulumi import` command, EdgeCacheService can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:networkservices/edgeCacheService:EdgeCacheService default projects/{{project}}/locations/global/edgeCacheServices/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:networkservices/edgeCacheService:EdgeCacheService default {{project}}/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:networkservices/edgeCacheService:EdgeCacheService default {{name}}
 * ```
 * @property description A human-readable description of the resource.
 * @property disableHttp2 Disables HTTP/2. HTTP/2 (h2) is enabled by default and recommended for performance. HTTP/2 improves connection re-use
 * and reduces connection setup overhead by sending multiple streams over the same connection. Some legacy HTTP clients may
 * have issues with HTTP/2 connections due to broken HTTP/2 implementations. Setting this to true will prevent HTTP/2 from
 * being advertised and negotiated.
 * @property disableQuic HTTP/3 (IETF QUIC) and Google QUIC are enabled by default.
 * @property edgeSecurityPolicy Resource URL that points at the Cloud Armor edge security policy that is applied on each request against the
 * EdgeCacheService.
 * @property edgeSslCertificates URLs to sslCertificate resources that are used to authenticate connections between users and the EdgeCacheService. Note
 * that only "global" certificates with a "scope" of "EDGE_CACHE" can be attached to an EdgeCacheService.
 * @property labels Set of label tags associated with the EdgeCache resource. **Note**: This field is non-authoritative, and will only
 * manage the labels present in your configuration. Please refer to the field 'effective_labels' for all of the labels
 * present on the resource.
 * @property logConfig Specifies the logging options for the traffic served by this service. If logging is enabled, logs will be exported to
 * Cloud Logging.
 * @property name Name of the resource; provided by the client when the resource is created.
 * The name must be 1-64 characters long, and match the regular expression [a-zA-Z][a-zA-Z0-9_-]* which means the first character must be a letter,
 * and all following characters must be a dash, underscore, letter or digit.
 * @property project
 * @property requireTls Require TLS (HTTPS) for all clients connecting to this service. Clients who connect over HTTP (port 80) will receive a
 * HTTP 301 to the same URL over HTTPS (port 443). You must have at least one (1) edgeSslCertificate specified to enable
 * this.
 * @property routing Defines how requests are routed, modified, cached and/or which origin content is filled from.
 * Structure is documented below.
 * @property sslPolicy URL of the SslPolicy resource that will be associated with the EdgeCacheService. If not set, the EdgeCacheService has no
 * SSL policy configured, and will default to the "COMPATIBLE" policy.
 * */*/*/*/*/*/*/*/*/*/*/*/
 */
public data class EdgeCacheServiceArgs(
    public val description: Output? = null,
    public val disableHttp2: Output? = null,
    public val disableQuic: Output? = null,
    public val edgeSecurityPolicy: Output? = null,
    public val edgeSslCertificates: Output>? = null,
    public val labels: Output>? = null,
    public val logConfig: Output? = null,
    public val name: Output? = null,
    public val project: Output? = null,
    public val requireTls: Output? = null,
    public val routing: Output? = null,
    public val sslPolicy: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.gcp.networkservices.EdgeCacheServiceArgs =
        com.pulumi.gcp.networkservices.EdgeCacheServiceArgs.builder()
            .description(description?.applyValue({ args0 -> args0 }))
            .disableHttp2(disableHttp2?.applyValue({ args0 -> args0 }))
            .disableQuic(disableQuic?.applyValue({ args0 -> args0 }))
            .edgeSecurityPolicy(edgeSecurityPolicy?.applyValue({ args0 -> args0 }))
            .edgeSslCertificates(edgeSslCertificates?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
            .labels(labels?.applyValue({ args0 -> args0.map({ args0 -> args0.key.to(args0.value) }).toMap() }))
            .logConfig(logConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .name(name?.applyValue({ args0 -> args0 }))
            .project(project?.applyValue({ args0 -> args0 }))
            .requireTls(requireTls?.applyValue({ args0 -> args0 }))
            .routing(routing?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .sslPolicy(sslPolicy?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [EdgeCacheServiceArgs].
 */
@PulumiTagMarker
public class EdgeCacheServiceArgsBuilder internal constructor() {
    private var description: Output? = null

    private var disableHttp2: Output? = null

    private var disableQuic: Output? = null

    private var edgeSecurityPolicy: Output? = null

    private var edgeSslCertificates: Output>? = null

    private var labels: Output>? = null

    private var logConfig: Output? = null

    private var name: Output? = null

    private var project: Output? = null

    private var requireTls: Output? = null

    private var routing: Output? = null

    private var sslPolicy: Output? = null

    /**
     * @param value A human-readable description of the resource.
     */
    @JvmName("nejbtjqdwoctsmuc")
    public suspend fun description(`value`: Output) {
        this.description = value
    }

    /**
     * @param value Disables HTTP/2. HTTP/2 (h2) is enabled by default and recommended for performance. HTTP/2 improves connection re-use
     * and reduces connection setup overhead by sending multiple streams over the same connection. Some legacy HTTP clients may
     * have issues with HTTP/2 connections due to broken HTTP/2 implementations. Setting this to true will prevent HTTP/2 from
     * being advertised and negotiated.
     */
    @JvmName("mynkfmepspthiirs")
    public suspend fun disableHttp2(`value`: Output) {
        this.disableHttp2 = value
    }

    /**
     * @param value HTTP/3 (IETF QUIC) and Google QUIC are enabled by default.
     */
    @JvmName("bpargvwunwggtocj")
    public suspend fun disableQuic(`value`: Output) {
        this.disableQuic = value
    }

    /**
     * @param value Resource URL that points at the Cloud Armor edge security policy that is applied on each request against the
     * EdgeCacheService.
     */
    @JvmName("umplicwwitaxmjli")
    public suspend fun edgeSecurityPolicy(`value`: Output) {
        this.edgeSecurityPolicy = value
    }

    /**
     * @param value URLs to sslCertificate resources that are used to authenticate connections between users and the EdgeCacheService. Note
     * that only "global" certificates with a "scope" of "EDGE_CACHE" can be attached to an EdgeCacheService.
     */
    @JvmName("ibaynyqtaqlutamk")
    public suspend fun edgeSslCertificates(`value`: Output>) {
        this.edgeSslCertificates = value
    }

    @JvmName("wwaovlcfmxjaiqtv")
    public suspend fun edgeSslCertificates(vararg values: Output) {
        this.edgeSslCertificates = Output.all(values.asList())
    }

    /**
     * @param values URLs to sslCertificate resources that are used to authenticate connections between users and the EdgeCacheService. Note
     * that only "global" certificates with a "scope" of "EDGE_CACHE" can be attached to an EdgeCacheService.
     */
    @JvmName("apyngcvnfabybypl")
    public suspend fun edgeSslCertificates(values: List>) {
        this.edgeSslCertificates = Output.all(values)
    }

    /**
     * @param value Set of label tags associated with the EdgeCache resource. **Note**: This field is non-authoritative, and will only
     * manage the labels present in your configuration. Please refer to the field 'effective_labels' for all of the labels
     * present on the resource.
     */
    @JvmName("mrvokjkclwmgxujs")
    public suspend fun labels(`value`: Output>) {
        this.labels = value
    }

    /**
     * @param value Specifies the logging options for the traffic served by this service. If logging is enabled, logs will be exported to
     * Cloud Logging.
     */
    @JvmName("vshnaouxyhtlndmg")
    public suspend fun logConfig(`value`: Output) {
        this.logConfig = value
    }

    /**
     * @param value Name of the resource; provided by the client when the resource is created.
     * The name must be 1-64 characters long, and match the regular expression [a-zA-Z][a-zA-Z0-9_-]* which means the first character must be a letter,
     * and all following characters must be a dash, underscore, letter or digit.
     */
    @JvmName("iatcsxxuioenfstl")
    public suspend fun name(`value`: Output) {
        this.name = value
    }

    /**
     * @param value
     */
    @JvmName("bntuteilmxauadfx")
    public suspend fun project(`value`: Output) {
        this.project = value
    }

    /**
     * @param value Require TLS (HTTPS) for all clients connecting to this service. Clients who connect over HTTP (port 80) will receive a
     * HTTP 301 to the same URL over HTTPS (port 443). You must have at least one (1) edgeSslCertificate specified to enable
     * this.
     */
    @JvmName("puoyrdcrhphnjbkp")
    public suspend fun requireTls(`value`: Output) {
        this.requireTls = value
    }

    /**
     * @param value Defines how requests are routed, modified, cached and/or which origin content is filled from.
     * Structure is documented below.
     */
    @JvmName("vpqieeytdhrqmvnu")
    public suspend fun routing(`value`: Output) {
        this.routing = value
    }

    /**
     * @param value URL of the SslPolicy resource that will be associated with the EdgeCacheService. If not set, the EdgeCacheService has no
     * SSL policy configured, and will default to the "COMPATIBLE" policy.
     */
    @JvmName("aautxaqlcawbtudy")
    public suspend fun sslPolicy(`value`: Output) {
        this.sslPolicy = value
    }

    /**
     * @param value A human-readable description of the resource.
     */
    @JvmName("tpocugrjygwafgmm")
    public suspend fun description(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.description = mapped
    }

    /**
     * @param value Disables HTTP/2. HTTP/2 (h2) is enabled by default and recommended for performance. HTTP/2 improves connection re-use
     * and reduces connection setup overhead by sending multiple streams over the same connection. Some legacy HTTP clients may
     * have issues with HTTP/2 connections due to broken HTTP/2 implementations. Setting this to true will prevent HTTP/2 from
     * being advertised and negotiated.
     */
    @JvmName("ktvcidrdurmastfy")
    public suspend fun disableHttp2(`value`: Boolean?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.disableHttp2 = mapped
    }

    /**
     * @param value HTTP/3 (IETF QUIC) and Google QUIC are enabled by default.
     */
    @JvmName("nrfdwvoxwsbjprkk")
    public suspend fun disableQuic(`value`: Boolean?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.disableQuic = mapped
    }

    /**
     * @param value Resource URL that points at the Cloud Armor edge security policy that is applied on each request against the
     * EdgeCacheService.
     */
    @JvmName("pbryoyavycrwppdq")
    public suspend fun edgeSecurityPolicy(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.edgeSecurityPolicy = mapped
    }

    /**
     * @param value URLs to sslCertificate resources that are used to authenticate connections between users and the EdgeCacheService. Note
     * that only "global" certificates with a "scope" of "EDGE_CACHE" can be attached to an EdgeCacheService.
     */
    @JvmName("swiokvoxerbjjewv")
    public suspend fun edgeSslCertificates(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.edgeSslCertificates = mapped
    }

    /**
     * @param values URLs to sslCertificate resources that are used to authenticate connections between users and the EdgeCacheService. Note
     * that only "global" certificates with a "scope" of "EDGE_CACHE" can be attached to an EdgeCacheService.
     */
    @JvmName("tmpjciclllekibuw")
    public suspend fun edgeSslCertificates(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.edgeSslCertificates = mapped
    }

    /**
     * @param value Set of label tags associated with the EdgeCache resource. **Note**: This field is non-authoritative, and will only
     * manage the labels present in your configuration. Please refer to the field 'effective_labels' for all of the labels
     * present on the resource.
     */
    @JvmName("bpdqnugvbiewhqoj")
    public suspend fun labels(`value`: Map?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.labels = mapped
    }

    /**
     * @param values Set of label tags associated with the EdgeCache resource. **Note**: This field is non-authoritative, and will only
     * manage the labels present in your configuration. Please refer to the field 'effective_labels' for all of the labels
     * present on the resource.
     */
    @JvmName("lepibiitfehpeixj")
    public fun labels(vararg values: Pair) {
        val toBeMapped = values.toMap()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.labels = mapped
    }

    /**
     * @param value Specifies the logging options for the traffic served by this service. If logging is enabled, logs will be exported to
     * Cloud Logging.
     */
    @JvmName("jmuclwpqyxcvyadc")
    public suspend fun logConfig(`value`: EdgeCacheServiceLogConfigArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.logConfig = mapped
    }

    /**
     * @param argument Specifies the logging options for the traffic served by this service. If logging is enabled, logs will be exported to
     * Cloud Logging.
     */
    @JvmName("lfcownmhtucocoiy")
    public suspend fun logConfig(argument: suspend EdgeCacheServiceLogConfigArgsBuilder.() -> Unit) {
        val toBeMapped = EdgeCacheServiceLogConfigArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.logConfig = mapped
    }

    /**
     * @param value Name of the resource; provided by the client when the resource is created.
     * The name must be 1-64 characters long, and match the regular expression [a-zA-Z][a-zA-Z0-9_-]* which means the first character must be a letter,
     * and all following characters must be a dash, underscore, letter or digit.
     */
    @JvmName("ivcxuxysfhhigady")
    public suspend fun name(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.name = mapped
    }

    /**
     * @param value
     */
    @JvmName("uubkrfijmeujqqrs")
    public suspend fun project(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.project = mapped
    }

    /**
     * @param value Require TLS (HTTPS) for all clients connecting to this service. Clients who connect over HTTP (port 80) will receive a
     * HTTP 301 to the same URL over HTTPS (port 443). You must have at least one (1) edgeSslCertificate specified to enable
     * this.
     */
    @JvmName("uvoktsohqrweqxxa")
    public suspend fun requireTls(`value`: Boolean?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.requireTls = mapped
    }

    /**
     * @param value Defines how requests are routed, modified, cached and/or which origin content is filled from.
     * Structure is documented below.
     */
    @JvmName("rqjbhxdbjvsanpao")
    public suspend fun routing(`value`: EdgeCacheServiceRoutingArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.routing = mapped
    }

    /**
     * @param argument Defines how requests are routed, modified, cached and/or which origin content is filled from.
     * Structure is documented below.
     */
    @JvmName("yuehyytedwmbasvv")
    public suspend fun routing(argument: suspend EdgeCacheServiceRoutingArgsBuilder.() -> Unit) {
        val toBeMapped = EdgeCacheServiceRoutingArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.routing = mapped
    }

    /**
     * @param value URL of the SslPolicy resource that will be associated with the EdgeCacheService. If not set, the EdgeCacheService has no
     * SSL policy configured, and will default to the "COMPATIBLE" policy.
     */
    @JvmName("cisluoueyornubug")
    public suspend fun sslPolicy(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.sslPolicy = mapped
    }

    internal fun build(): EdgeCacheServiceArgs = EdgeCacheServiceArgs(
        description = description,
        disableHttp2 = disableHttp2,
        disableQuic = disableQuic,
        edgeSecurityPolicy = edgeSecurityPolicy,
        edgeSslCertificates = edgeSslCertificates,
        labels = labels,
        logConfig = logConfig,
        name = name,
        project = project,
        requireTls = requireTls,
        routing = routing,
        sslPolicy = sslPolicy,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy