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

com.pulumi.gcp.appengine.kotlin.FlexibleAppVersion.kt Maven / Gradle / Ivy

Go to download

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

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

package com.pulumi.gcp.appengine.kotlin

import com.pulumi.core.Output
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionApiConfig
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionAutomaticScaling
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionDeployment
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionEndpointsApiService
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionEntrypoint
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionHandler
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionLivenessCheck
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionManualScaling
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionNetwork
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionReadinessCheck
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionResources
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionVpcAccessConnector
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionApiConfig.Companion.toKotlin as flexibleAppVersionApiConfigToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionAutomaticScaling.Companion.toKotlin as flexibleAppVersionAutomaticScalingToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionDeployment.Companion.toKotlin as flexibleAppVersionDeploymentToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionEndpointsApiService.Companion.toKotlin as flexibleAppVersionEndpointsApiServiceToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionEntrypoint.Companion.toKotlin as flexibleAppVersionEntrypointToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionHandler.Companion.toKotlin as flexibleAppVersionHandlerToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionLivenessCheck.Companion.toKotlin as flexibleAppVersionLivenessCheckToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionManualScaling.Companion.toKotlin as flexibleAppVersionManualScalingToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionNetwork.Companion.toKotlin as flexibleAppVersionNetworkToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionReadinessCheck.Companion.toKotlin as flexibleAppVersionReadinessCheckToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionResources.Companion.toKotlin as flexibleAppVersionResourcesToKotlin
import com.pulumi.gcp.appengine.kotlin.outputs.FlexibleAppVersionVpcAccessConnector.Companion.toKotlin as flexibleAppVersionVpcAccessConnectorToKotlin

/**
 * Builder for [FlexibleAppVersion].
 */
@PulumiTagMarker
public class FlexibleAppVersionResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: FlexibleAppVersionArgs = FlexibleAppVersionArgs()

    public var opts: CustomResourceOptions = CustomResourceOptions()

    /**
     * @param name The _unique_ name of the resulting resource.
     */
    public fun name(`value`: String) {
        this.name = value
    }

    /**
     * @param block The arguments to use to populate this resource's properties.
     */
    public suspend fun args(block: suspend FlexibleAppVersionArgsBuilder.() -> Unit) {
        val builder = FlexibleAppVersionArgsBuilder()
        block(builder)
        this.args = builder.build()
    }

    /**
     * @param block A bag of options that control this resource's behavior.
     */
    public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
        this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
    }

    internal fun build(): FlexibleAppVersion {
        val builtJavaResource = com.pulumi.gcp.appengine.FlexibleAppVersion(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return FlexibleAppVersion(builtJavaResource)
    }
}

/**
 * Flexible App Version resource to create a new version of flexible GAE Application. Based on Google Compute Engine,
 * the App Engine flexible environment automatically scales your app up and down while also balancing the load.
 * Learn about the differences between the standard environment and the flexible environment
 * at https://cloud.google.com/appengine/docs/the-appengine-environments.
 * > **Note:** The App Engine flexible environment service account uses the member ID `service-[YOUR_PROJECT_NUMBER]@gae-api-prod.google.com.iam.gserviceaccount.com`
 * It should have the App Engine Flexible Environment Service Agent role, which will be applied when the `appengineflex.googleapis.com` service is enabled.
 * To get more information about FlexibleAppVersion, see:
 * * [API documentation](https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1/apps.services.versions)
 * * How-to Guides
 *     * [Official Documentation](https://cloud.google.com/appengine/docs/flexible)
 * ## Example Usage
 * ### App Engine Flexible App Version
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const myProject = new gcp.organizations.Project("my_project", {
 *     name: "appeng-flex",
 *     projectId: "appeng-flex",
 *     orgId: "123456789",
 *     billingAccount: "000000-0000000-0000000-000000",
 * });
 * const app = new gcp.appengine.Application("app", {
 *     project: myProject.projectId,
 *     locationId: "us-central",
 * });
 * const service = new gcp.projects.Service("service", {
 *     project: myProject.projectId,
 *     service: "appengineflex.googleapis.com",
 *     disableDependentServices: false,
 * });
 * const customServiceAccount = new gcp.serviceaccount.Account("custom_service_account", {
 *     project: service.project,
 *     accountId: "my-account",
 *     displayName: "Custom Service Account",
 * });
 * const gaeApi = new gcp.projects.IAMMember("gae_api", {
 *     project: service.project,
 *     role: "roles/compute.networkUser",
 *     member: pulumi.interpolate`serviceAccount:${customServiceAccount.email}`,
 * });
 * const logsWriter = new gcp.projects.IAMMember("logs_writer", {
 *     project: service.project,
 *     role: "roles/logging.logWriter",
 *     member: pulumi.interpolate`serviceAccount:${customServiceAccount.email}`,
 * });
 * const storageViewer = new gcp.projects.IAMMember("storage_viewer", {
 *     project: service.project,
 *     role: "roles/storage.objectViewer",
 *     member: pulumi.interpolate`serviceAccount:${customServiceAccount.email}`,
 * });
 * const bucket = new gcp.storage.Bucket("bucket", {
 *     project: myProject.projectId,
 *     name: "appengine-static-content",
 *     location: "US",
 * });
 * const object = new gcp.storage.BucketObject("object", {
 *     name: "hello-world.zip",
 *     bucket: bucket.name,
 *     source: new pulumi.asset.FileAsset("./test-fixtures/hello-world.zip"),
 * });
 * const myappV1 = new gcp.appengine.FlexibleAppVersion("myapp_v1", {
 *     versionId: "v1",
 *     project: gaeApi.project,
 *     service: "default",
 *     runtime: "nodejs",
 *     entrypoint: {
 *         shell: "node ./app.js",
 *     },
 *     deployment: {
 *         zip: {
 *             sourceUrl: pulumi.interpolate`https://storage.googleapis.com/${bucket.name}/${object.name}`,
 *         },
 *     },
 *     livenessCheck: {
 *         path: "/",
 *     },
 *     readinessCheck: {
 *         path: "/",
 *     },
 *     envVariables: {
 *         port: "8080",
 *     },
 *     handlers: [{
 *         urlRegex: ".*\\/my-path\\/*",
 *         securityLevel: "SECURE_ALWAYS",
 *         login: "LOGIN_REQUIRED",
 *         authFailAction: "AUTH_FAIL_ACTION_REDIRECT",
 *         staticFiles: {
 *             path: "my-other-path",
 *             uploadPathRegex: ".*\\/my-path\\/*",
 *         },
 *     }],
 *     automaticScaling: {
 *         coolDownPeriod: "120s",
 *         cpuUtilization: {
 *             targetUtilization: 0.5,
 *         },
 *     },
 *     noopOnDestroy: true,
 *     serviceAccount: customServiceAccount.email,
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * my_project = gcp.organizations.Project("my_project",
 *     name="appeng-flex",
 *     project_id="appeng-flex",
 *     org_id="123456789",
 *     billing_account="000000-0000000-0000000-000000")
 * app = gcp.appengine.Application("app",
 *     project=my_project.project_id,
 *     location_id="us-central")
 * service = gcp.projects.Service("service",
 *     project=my_project.project_id,
 *     service="appengineflex.googleapis.com",
 *     disable_dependent_services=False)
 * custom_service_account = gcp.serviceaccount.Account("custom_service_account",
 *     project=service.project,
 *     account_id="my-account",
 *     display_name="Custom Service Account")
 * gae_api = gcp.projects.IAMMember("gae_api",
 *     project=service.project,
 *     role="roles/compute.networkUser",
 *     member=custom_service_account.email.apply(lambda email: f"serviceAccount:{email}"))
 * logs_writer = gcp.projects.IAMMember("logs_writer",
 *     project=service.project,
 *     role="roles/logging.logWriter",
 *     member=custom_service_account.email.apply(lambda email: f"serviceAccount:{email}"))
 * storage_viewer = gcp.projects.IAMMember("storage_viewer",
 *     project=service.project,
 *     role="roles/storage.objectViewer",
 *     member=custom_service_account.email.apply(lambda email: f"serviceAccount:{email}"))
 * bucket = gcp.storage.Bucket("bucket",
 *     project=my_project.project_id,
 *     name="appengine-static-content",
 *     location="US")
 * object = gcp.storage.BucketObject("object",
 *     name="hello-world.zip",
 *     bucket=bucket.name,
 *     source=pulumi.FileAsset("./test-fixtures/hello-world.zip"))
 * myapp_v1 = gcp.appengine.FlexibleAppVersion("myapp_v1",
 *     version_id="v1",
 *     project=gae_api.project,
 *     service="default",
 *     runtime="nodejs",
 *     entrypoint=gcp.appengine.FlexibleAppVersionEntrypointArgs(
 *         shell="node ./app.js",
 *     ),
 *     deployment=gcp.appengine.FlexibleAppVersionDeploymentArgs(
 *         zip=gcp.appengine.FlexibleAppVersionDeploymentZipArgs(
 *             source_url=pulumi.Output.all(bucket.name, object.name).apply(lambda bucketName, objectName: f"https://storage.googleapis.com/{bucket_name}/{object_name}"),
 *         ),
 *     ),
 *     liveness_check=gcp.appengine.FlexibleAppVersionLivenessCheckArgs(
 *         path="/",
 *     ),
 *     readiness_check=gcp.appengine.FlexibleAppVersionReadinessCheckArgs(
 *         path="/",
 *     ),
 *     env_variables={
 *         "port": "8080",
 *     },
 *     handlers=[gcp.appengine.FlexibleAppVersionHandlerArgs(
 *         url_regex=".*\\/my-path\\/*",
 *         security_level="SECURE_ALWAYS",
 *         login="LOGIN_REQUIRED",
 *         auth_fail_action="AUTH_FAIL_ACTION_REDIRECT",
 *         static_files=gcp.appengine.FlexibleAppVersionHandlerStaticFilesArgs(
 *             path="my-other-path",
 *             upload_path_regex=".*\\/my-path\\/*",
 *         ),
 *     )],
 *     automatic_scaling=gcp.appengine.FlexibleAppVersionAutomaticScalingArgs(
 *         cool_down_period="120s",
 *         cpu_utilization=gcp.appengine.FlexibleAppVersionAutomaticScalingCpuUtilizationArgs(
 *             target_utilization=0.5,
 *         ),
 *     ),
 *     noop_on_destroy=True,
 *     service_account=custom_service_account.email)
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var myProject = new Gcp.Organizations.Project("my_project", new()
 *     {
 *         Name = "appeng-flex",
 *         ProjectId = "appeng-flex",
 *         OrgId = "123456789",
 *         BillingAccount = "000000-0000000-0000000-000000",
 *     });
 *     var app = new Gcp.AppEngine.Application("app", new()
 *     {
 *         Project = myProject.ProjectId,
 *         LocationId = "us-central",
 *     });
 *     var service = new Gcp.Projects.Service("service", new()
 *     {
 *         Project = myProject.ProjectId,
 *         ServiceName = "appengineflex.googleapis.com",
 *         DisableDependentServices = false,
 *     });
 *     var customServiceAccount = new Gcp.ServiceAccount.Account("custom_service_account", new()
 *     {
 *         Project = service.Project,
 *         AccountId = "my-account",
 *         DisplayName = "Custom Service Account",
 *     });
 *     var gaeApi = new Gcp.Projects.IAMMember("gae_api", new()
 *     {
 *         Project = service.Project,
 *         Role = "roles/compute.networkUser",
 *         Member = customServiceAccount.Email.Apply(email => $"serviceAccount:{email}"),
 *     });
 *     var logsWriter = new Gcp.Projects.IAMMember("logs_writer", new()
 *     {
 *         Project = service.Project,
 *         Role = "roles/logging.logWriter",
 *         Member = customServiceAccount.Email.Apply(email => $"serviceAccount:{email}"),
 *     });
 *     var storageViewer = new Gcp.Projects.IAMMember("storage_viewer", new()
 *     {
 *         Project = service.Project,
 *         Role = "roles/storage.objectViewer",
 *         Member = customServiceAccount.Email.Apply(email => $"serviceAccount:{email}"),
 *     });
 *     var bucket = new Gcp.Storage.Bucket("bucket", new()
 *     {
 *         Project = myProject.ProjectId,
 *         Name = "appengine-static-content",
 *         Location = "US",
 *     });
 *     var @object = new Gcp.Storage.BucketObject("object", new()
 *     {
 *         Name = "hello-world.zip",
 *         Bucket = bucket.Name,
 *         Source = new FileAsset("./test-fixtures/hello-world.zip"),
 *     });
 *     var myappV1 = new Gcp.AppEngine.FlexibleAppVersion("myapp_v1", new()
 *     {
 *         VersionId = "v1",
 *         Project = gaeApi.Project,
 *         Service = "default",
 *         Runtime = "nodejs",
 *         Entrypoint = new Gcp.AppEngine.Inputs.FlexibleAppVersionEntrypointArgs
 *         {
 *             Shell = "node ./app.js",
 *         },
 *         Deployment = new Gcp.AppEngine.Inputs.FlexibleAppVersionDeploymentArgs
 *         {
 *             Zip = new Gcp.AppEngine.Inputs.FlexibleAppVersionDeploymentZipArgs
 *             {
 *                 SourceUrl = Output.Tuple(bucket.Name, @object.Name).Apply(values =>
 *                 {
 *                     var bucketName = values.Item1;
 *                     var objectName = values.Item2;
 *                     return $"https://storage.googleapis.com/{bucketName}/{objectName}";
 *                 }),
 *             },
 *         },
 *         LivenessCheck = new Gcp.AppEngine.Inputs.FlexibleAppVersionLivenessCheckArgs
 *         {
 *             Path = "/",
 *         },
 *         ReadinessCheck = new Gcp.AppEngine.Inputs.FlexibleAppVersionReadinessCheckArgs
 *         {
 *             Path = "/",
 *         },
 *         EnvVariables =
 *         {
 *             { "port", "8080" },
 *         },
 *         Handlers = new[]
 *         {
 *             new Gcp.AppEngine.Inputs.FlexibleAppVersionHandlerArgs
 *             {
 *                 UrlRegex = ".*\\/my-path\\/*",
 *                 SecurityLevel = "SECURE_ALWAYS",
 *                 Login = "LOGIN_REQUIRED",
 *                 AuthFailAction = "AUTH_FAIL_ACTION_REDIRECT",
 *                 StaticFiles = new Gcp.AppEngine.Inputs.FlexibleAppVersionHandlerStaticFilesArgs
 *                 {
 *                     Path = "my-other-path",
 *                     UploadPathRegex = ".*\\/my-path\\/*",
 *                 },
 *             },
 *         },
 *         AutomaticScaling = new Gcp.AppEngine.Inputs.FlexibleAppVersionAutomaticScalingArgs
 *         {
 *             CoolDownPeriod = "120s",
 *             CpuUtilization = new Gcp.AppEngine.Inputs.FlexibleAppVersionAutomaticScalingCpuUtilizationArgs
 *             {
 *                 TargetUtilization = 0.5,
 *             },
 *         },
 *         NoopOnDestroy = true,
 *         ServiceAccount = customServiceAccount.Email,
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/appengine"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/organizations"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/projects"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/serviceaccount"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		myProject, err := organizations.NewProject(ctx, "my_project", &organizations.ProjectArgs{
 * 			Name:           pulumi.String("appeng-flex"),
 * 			ProjectId:      pulumi.String("appeng-flex"),
 * 			OrgId:          pulumi.String("123456789"),
 * 			BillingAccount: pulumi.String("000000-0000000-0000000-000000"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = appengine.NewApplication(ctx, "app", &appengine.ApplicationArgs{
 * 			Project:    myProject.ProjectId,
 * 			LocationId: pulumi.String("us-central"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		service, err := projects.NewService(ctx, "service", &projects.ServiceArgs{
 * 			Project:                  myProject.ProjectId,
 * 			Service:                  pulumi.String("appengineflex.googleapis.com"),
 * 			DisableDependentServices: pulumi.Bool(false),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		customServiceAccount, err := serviceaccount.NewAccount(ctx, "custom_service_account", &serviceaccount.AccountArgs{
 * 			Project:     service.Project,
 * 			AccountId:   pulumi.String("my-account"),
 * 			DisplayName: pulumi.String("Custom Service Account"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		gaeApi, err := projects.NewIAMMember(ctx, "gae_api", &projects.IAMMemberArgs{
 * 			Project: service.Project,
 * 			Role:    pulumi.String("roles/compute.networkUser"),
 * 			Member: customServiceAccount.Email.ApplyT(func(email string) (string, error) {
 * 				return fmt.Sprintf("serviceAccount:%v", email), nil
 * 			}).(pulumi.StringOutput),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = projects.NewIAMMember(ctx, "logs_writer", &projects.IAMMemberArgs{
 * 			Project: service.Project,
 * 			Role:    pulumi.String("roles/logging.logWriter"),
 * 			Member: customServiceAccount.Email.ApplyT(func(email string) (string, error) {
 * 				return fmt.Sprintf("serviceAccount:%v", email), nil
 * 			}).(pulumi.StringOutput),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = projects.NewIAMMember(ctx, "storage_viewer", &projects.IAMMemberArgs{
 * 			Project: service.Project,
 * 			Role:    pulumi.String("roles/storage.objectViewer"),
 * 			Member: customServiceAccount.Email.ApplyT(func(email string) (string, error) {
 * 				return fmt.Sprintf("serviceAccount:%v", email), nil
 * 			}).(pulumi.StringOutput),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		bucket, err := storage.NewBucket(ctx, "bucket", &storage.BucketArgs{
 * 			Project:  myProject.ProjectId,
 * 			Name:     pulumi.String("appengine-static-content"),
 * 			Location: pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		object, err := storage.NewBucketObject(ctx, "object", &storage.BucketObjectArgs{
 * 			Name:   pulumi.String("hello-world.zip"),
 * 			Bucket: bucket.Name,
 * 			Source: pulumi.NewFileAsset("./test-fixtures/hello-world.zip"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = appengine.NewFlexibleAppVersion(ctx, "myapp_v1", &appengine.FlexibleAppVersionArgs{
 * 			VersionId: pulumi.String("v1"),
 * 			Project:   gaeApi.Project,
 * 			Service:   pulumi.String("default"),
 * 			Runtime:   pulumi.String("nodejs"),
 * 			Entrypoint: &appengine.FlexibleAppVersionEntrypointArgs{
 * 				Shell: pulumi.String("node ./app.js"),
 * 			},
 * 			Deployment: &appengine.FlexibleAppVersionDeploymentArgs{
 * 				Zip: &appengine.FlexibleAppVersionDeploymentZipArgs{
 * 					SourceUrl: pulumi.All(bucket.Name, object.Name).ApplyT(func(_args []interface{}) (string, error) {
 * 						bucketName := _args[0].(string)
 * 						objectName := _args[1].(string)
 * 						return fmt.Sprintf("https://storage.googleapis.com/%v/%v", bucketName, objectName), nil
 * 					}).(pulumi.StringOutput),
 * 				},
 * 			},
 * 			LivenessCheck: &appengine.FlexibleAppVersionLivenessCheckArgs{
 * 				Path: pulumi.String("/"),
 * 			},
 * 			ReadinessCheck: &appengine.FlexibleAppVersionReadinessCheckArgs{
 * 				Path: pulumi.String("/"),
 * 			},
 * 			EnvVariables: pulumi.StringMap{
 * 				"port": pulumi.String("8080"),
 * 			},
 * 			Handlers: appengine.FlexibleAppVersionHandlerArray{
 * 				&appengine.FlexibleAppVersionHandlerArgs{
 * 					UrlRegex:       pulumi.String(".*\\/my-path\\/*"),
 * 					SecurityLevel:  pulumi.String("SECURE_ALWAYS"),
 * 					Login:          pulumi.String("LOGIN_REQUIRED"),
 * 					AuthFailAction: pulumi.String("AUTH_FAIL_ACTION_REDIRECT"),
 * 					StaticFiles: &appengine.FlexibleAppVersionHandlerStaticFilesArgs{
 * 						Path:            pulumi.String("my-other-path"),
 * 						UploadPathRegex: pulumi.String(".*\\/my-path\\/*"),
 * 					},
 * 				},
 * 			},
 * 			AutomaticScaling: &appengine.FlexibleAppVersionAutomaticScalingArgs{
 * 				CoolDownPeriod: pulumi.String("120s"),
 * 				CpuUtilization: &appengine.FlexibleAppVersionAutomaticScalingCpuUtilizationArgs{
 * 					TargetUtilization: pulumi.Float64(0.5),
 * 				},
 * 			},
 * 			NoopOnDestroy:  pulumi.Bool(true),
 * 			ServiceAccount: customServiceAccount.Email,
 * 		})
 * 		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.organizations.Project;
 * import com.pulumi.gcp.organizations.ProjectArgs;
 * import com.pulumi.gcp.appengine.Application;
 * import com.pulumi.gcp.appengine.ApplicationArgs;
 * import com.pulumi.gcp.projects.Service;
 * import com.pulumi.gcp.projects.ServiceArgs;
 * import com.pulumi.gcp.serviceaccount.Account;
 * import com.pulumi.gcp.serviceaccount.AccountArgs;
 * import com.pulumi.gcp.projects.IAMMember;
 * import com.pulumi.gcp.projects.IAMMemberArgs;
 * import com.pulumi.gcp.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.storage.BucketObject;
 * import com.pulumi.gcp.storage.BucketObjectArgs;
 * import com.pulumi.gcp.appengine.FlexibleAppVersion;
 * import com.pulumi.gcp.appengine.FlexibleAppVersionArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionEntrypointArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionDeploymentArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionDeploymentZipArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionLivenessCheckArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionReadinessCheckArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionHandlerArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionHandlerStaticFilesArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionAutomaticScalingArgs;
 * import com.pulumi.gcp.appengine.inputs.FlexibleAppVersionAutomaticScalingCpuUtilizationArgs;
 * import com.pulumi.asset.FileAsset;
 * 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 myProject = new Project("myProject", ProjectArgs.builder()
 *             .name("appeng-flex")
 *             .projectId("appeng-flex")
 *             .orgId("123456789")
 *             .billingAccount("000000-0000000-0000000-000000")
 *             .build());
 *         var app = new Application("app", ApplicationArgs.builder()
 *             .project(myProject.projectId())
 *             .locationId("us-central")
 *             .build());
 *         var service = new Service("service", ServiceArgs.builder()
 *             .project(myProject.projectId())
 *             .service("appengineflex.googleapis.com")
 *             .disableDependentServices(false)
 *             .build());
 *         var customServiceAccount = new Account("customServiceAccount", AccountArgs.builder()
 *             .project(service.project())
 *             .accountId("my-account")
 *             .displayName("Custom Service Account")
 *             .build());
 *         var gaeApi = new IAMMember("gaeApi", IAMMemberArgs.builder()
 *             .project(service.project())
 *             .role("roles/compute.networkUser")
 *             .member(customServiceAccount.email().applyValue(email -> String.format("serviceAccount:%s", email)))
 *             .build());
 *         var logsWriter = new IAMMember("logsWriter", IAMMemberArgs.builder()
 *             .project(service.project())
 *             .role("roles/logging.logWriter")
 *             .member(customServiceAccount.email().applyValue(email -> String.format("serviceAccount:%s", email)))
 *             .build());
 *         var storageViewer = new IAMMember("storageViewer", IAMMemberArgs.builder()
 *             .project(service.project())
 *             .role("roles/storage.objectViewer")
 *             .member(customServiceAccount.email().applyValue(email -> String.format("serviceAccount:%s", email)))
 *             .build());
 *         var bucket = new Bucket("bucket", BucketArgs.builder()
 *             .project(myProject.projectId())
 *             .name("appengine-static-content")
 *             .location("US")
 *             .build());
 *         var object = new BucketObject("object", BucketObjectArgs.builder()
 *             .name("hello-world.zip")
 *             .bucket(bucket.name())
 *             .source(new FileAsset("./test-fixtures/hello-world.zip"))
 *             .build());
 *         var myappV1 = new FlexibleAppVersion("myappV1", FlexibleAppVersionArgs.builder()
 *             .versionId("v1")
 *             .project(gaeApi.project())
 *             .service("default")
 *             .runtime("nodejs")
 *             .entrypoint(FlexibleAppVersionEntrypointArgs.builder()
 *                 .shell("node ./app.js")
 *                 .build())
 *             .deployment(FlexibleAppVersionDeploymentArgs.builder()
 *                 .zip(FlexibleAppVersionDeploymentZipArgs.builder()
 *                     .sourceUrl(Output.tuple(bucket.name(), object.name()).applyValue(values -> {
 *                         var bucketName = values.t1;
 *                         var objectName = values.t2;
 *                         return String.format("https://storage.googleapis.com/%s/%s", bucketName,objectName);
 *                     }))
 *                     .build())
 *                 .build())
 *             .livenessCheck(FlexibleAppVersionLivenessCheckArgs.builder()
 *                 .path("/")
 *                 .build())
 *             .readinessCheck(FlexibleAppVersionReadinessCheckArgs.builder()
 *                 .path("/")
 *                 .build())
 *             .envVariables(Map.of("port", "8080"))
 *             .handlers(FlexibleAppVersionHandlerArgs.builder()
 *                 .urlRegex(".*\\/my-path\\/*")
 *                 .securityLevel("SECURE_ALWAYS")
 *                 .login("LOGIN_REQUIRED")
 *                 .authFailAction("AUTH_FAIL_ACTION_REDIRECT")
 *                 .staticFiles(FlexibleAppVersionHandlerStaticFilesArgs.builder()
 *                     .path("my-other-path")
 *                     .uploadPathRegex(".*\\/my-path\\/*")
 *                     .build())
 *                 .build())
 *             .automaticScaling(FlexibleAppVersionAutomaticScalingArgs.builder()
 *                 .coolDownPeriod("120s")
 *                 .cpuUtilization(FlexibleAppVersionAutomaticScalingCpuUtilizationArgs.builder()
 *                     .targetUtilization(0.5)
 *                     .build())
 *                 .build())
 *             .noopOnDestroy(true)
 *             .serviceAccount(customServiceAccount.email())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   myProject:
 *     type: gcp:organizations:Project
 *     name: my_project
 *     properties:
 *       name: appeng-flex
 *       projectId: appeng-flex
 *       orgId: '123456789'
 *       billingAccount: 000000-0000000-0000000-000000
 *   app:
 *     type: gcp:appengine:Application
 *     properties:
 *       project: ${myProject.projectId}
 *       locationId: us-central
 *   service:
 *     type: gcp:projects:Service
 *     properties:
 *       project: ${myProject.projectId}
 *       service: appengineflex.googleapis.com
 *       disableDependentServices: false
 *   customServiceAccount:
 *     type: gcp:serviceaccount:Account
 *     name: custom_service_account
 *     properties:
 *       project: ${service.project}
 *       accountId: my-account
 *       displayName: Custom Service Account
 *   gaeApi:
 *     type: gcp:projects:IAMMember
 *     name: gae_api
 *     properties:
 *       project: ${service.project}
 *       role: roles/compute.networkUser
 *       member: serviceAccount:${customServiceAccount.email}
 *   logsWriter:
 *     type: gcp:projects:IAMMember
 *     name: logs_writer
 *     properties:
 *       project: ${service.project}
 *       role: roles/logging.logWriter
 *       member: serviceAccount:${customServiceAccount.email}
 *   storageViewer:
 *     type: gcp:projects:IAMMember
 *     name: storage_viewer
 *     properties:
 *       project: ${service.project}
 *       role: roles/storage.objectViewer
 *       member: serviceAccount:${customServiceAccount.email}
 *   myappV1:
 *     type: gcp:appengine:FlexibleAppVersion
 *     name: myapp_v1
 *     properties:
 *       versionId: v1
 *       project: ${gaeApi.project}
 *       service: default
 *       runtime: nodejs
 *       entrypoint:
 *         shell: node ./app.js
 *       deployment:
 *         zip:
 *           sourceUrl: https://storage.googleapis.com/${bucket.name}/${object.name}
 *       livenessCheck:
 *         path: /
 *       readinessCheck:
 *         path: /
 *       envVariables:
 *         port: '8080'
 *       handlers:
 *         - urlRegex: .*\/my-path\/*
 *           securityLevel: SECURE_ALWAYS
 *           login: LOGIN_REQUIRED
 *           authFailAction: AUTH_FAIL_ACTION_REDIRECT
 *           staticFiles:
 *             path: my-other-path
 *             uploadPathRegex: .*\/my-path\/*
 *       automaticScaling:
 *         coolDownPeriod: 120s
 *         cpuUtilization:
 *           targetUtilization: 0.5
 *       noopOnDestroy: true
 *       serviceAccount: ${customServiceAccount.email}
 *   bucket:
 *     type: gcp:storage:Bucket
 *     properties:
 *       project: ${myProject.projectId}
 *       name: appengine-static-content
 *       location: US
 *   object:
 *     type: gcp:storage:BucketObject
 *     properties:
 *       name: hello-world.zip
 *       bucket: ${bucket.name}
 *       source:
 *         fn::FileAsset: ./test-fixtures/hello-world.zip
 * ```
 * 
 * ## Import
 * FlexibleAppVersion can be imported using any of these accepted formats:
 * * `apps/{{project}}/services/{{service}}/versions/{{version_id}}`
 * * `{{project}}/{{service}}/{{version_id}}`
 * * `{{service}}/{{version_id}}`
 * When using the `pulumi import` command, FlexibleAppVersion can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:appengine/flexibleAppVersion:FlexibleAppVersion default apps/{{project}}/services/{{service}}/versions/{{version_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:appengine/flexibleAppVersion:FlexibleAppVersion default {{project}}/{{service}}/{{version_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:appengine/flexibleAppVersion:FlexibleAppVersion default {{service}}/{{version_id}}
 * ```
 * */*/*/*/*/*/*/*/*/*/*/*/
 */
public class FlexibleAppVersion internal constructor(
    override val javaResource: com.pulumi.gcp.appengine.FlexibleAppVersion,
) : KotlinCustomResource(javaResource, FlexibleAppVersionMapper) {
    /**
     * Serving configuration for Google Cloud Endpoints.
     */
    public val apiConfig: Output?
        get() = javaResource.apiConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionApiConfigToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * Automatic scaling is based on request rate, response latencies, and other application metrics.
     */
    public val automaticScaling: Output?
        get() = javaResource.automaticScaling().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> flexibleAppVersionAutomaticScalingToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * Metadata settings that are supplied to this version to enable beta runtime features.
     */
    public val betaSettings: Output>?
        get() = javaResource.betaSettings().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })

    /**
     * Duration that static files should be cached by web proxies and browsers. Only applicable if the corresponding
     * StaticFilesHandler does not specify its own expiration time.
     */
    public val defaultExpiration: Output?
        get() = javaResource.defaultExpiration().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * If set to 'true', the service will be deleted if it is the last version.
     */
    public val deleteServiceOnDestroy: Output?
        get() = javaResource.deleteServiceOnDestroy().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Code and application artifacts that make up this version.
     */
    public val deployment: Output?
        get() = javaResource.deployment().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionDeploymentToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * Code and application artifacts that make up this version.
     */
    public val endpointsApiService: Output?
        get() = javaResource.endpointsApiService().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> flexibleAppVersionEndpointsApiServiceToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The entrypoint for the application.
     */
    public val entrypoint: Output?
        get() = javaResource.entrypoint().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionEntrypointToKotlin(args0)
                })
            }).orElse(null)
        })

    public val envVariables: Output>?
        get() = javaResource.envVariables().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })

    /**
     * An ordered list of URL-matching patterns that should be applied to incoming requests. The first matching URL handles the
     * request and other request handlers are not attempted.
     */
    public val handlers: Output>
        get() = javaResource.handlers().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionHandlerToKotlin(args0)
                })
            })
        })

    /**
     * A list of the types of messages that this application is able to receive. Possible values: ["INBOUND_SERVICE_MAIL",
     * "INBOUND_SERVICE_MAIL_BOUNCE", "INBOUND_SERVICE_XMPP_ERROR", "INBOUND_SERVICE_XMPP_MESSAGE",
     * "INBOUND_SERVICE_XMPP_SUBSCRIBE", "INBOUND_SERVICE_XMPP_PRESENCE", "INBOUND_SERVICE_CHANNEL_PRESENCE",
     * "INBOUND_SERVICE_WARMUP"]
     */
    public val inboundServices: Output>?
        get() = javaResource.inboundServices().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 -> args0 })
            }).orElse(null)
        })

    /**
     * Instance class that is used to run this version. Valid values are AutomaticScaling: F1, F2, F4, F4_1G ManualScaling: B1,
     * B2, B4, B8, B4_1G Defaults to F1 for AutomaticScaling and B1 for ManualScaling.
     */
    public val instanceClass: Output?
        get() = javaResource.instanceClass().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Health checking configuration for VM instances. Unhealthy instances are killed and replaced with new instances.
     * Structure is documented below.
     */
    public val livenessCheck: Output
        get() = javaResource.livenessCheck().applyValue({ args0 ->
            args0.let({ args0 ->
                flexibleAppVersionLivenessCheckToKotlin(args0)
            })
        })

    /**
     * A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of
     * its memory over time.
     */
    public val manualScaling: Output?
        get() = javaResource.manualScaling().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> flexibleAppVersionManualScalingToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * Full path to the Version resource in the API. Example, "v1".
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * Extra network settings
     */
    public val network: Output?
        get() = javaResource.network().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionNetworkToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * Files that match this pattern will not be built into this version. Only applicable for Go runtimes.
     */
    public val nobuildFilesRegex: Output?
        get() = javaResource.nobuildFilesRegex().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * If set to 'true', the application version will not be deleted.
     */
    public val noopOnDestroy: Output?
        get() = javaResource.noopOnDestroy().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * Configures readiness health checking for instances. Unhealthy instances are not put into the backend traffic rotation.
     * Structure is documented below.
     */
    public val readinessCheck: Output
        get() = javaResource.readinessCheck().applyValue({ args0 ->
            args0.let({ args0 ->
                flexibleAppVersionReadinessCheckToKotlin(args0)
            })
        })

    /**
     * Machine resources for a version.
     */
    public val resources: Output?
        get() = javaResource.resources().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    flexibleAppVersionResourcesToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * Desired runtime. Example python27.
     */
    public val runtime: Output
        get() = javaResource.runtime().applyValue({ args0 -> args0 })

    /**
     * The version of the API in the given runtime environment. Please see the app.yaml reference for valid values at
     * 'https://cloud.google.com/appengine/docs/standard//config/appref'\ Substitute '' with 'python',
     * 'java', 'php', 'ruby', 'go' or 'nodejs'.
     */
    public val runtimeApiVersion: Output
        get() = javaResource.runtimeApiVersion().applyValue({ args0 -> args0 })

    /**
     * The channel of the runtime to use. Only available for some runtimes.
     */
    public val runtimeChannel: Output?
        get() = javaResource.runtimeChannel().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * The path or name of the app's main executable.
     */
    public val runtimeMainExecutablePath: Output?
        get() = javaResource.runtimeMainExecutablePath().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * AppEngine service resource. Can contain numbers, letters, and hyphens.
     */
    public val service: Output
        get() = javaResource.service().applyValue({ args0 -> args0 })

    /**
     * The identity that the deployed version will run as. Admin API will use the App Engine Appspot service account as default
     * if this field is neither provided in app.yaml file nor through CLI flag.
     */
    public val serviceAccount: Output
        get() = javaResource.serviceAccount().applyValue({ args0 -> args0 })

    /**
     * Current serving status of this version. Only the versions with a SERVING status create instances and can be billed.
     * Default value: "SERVING" Possible values: ["SERVING", "STOPPED"]
     */
    public val servingStatus: Output?
        get() = javaResource.servingStatus().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Relative name of the version within the service. For example, 'v1'. Version names can contain only lowercase letters,
     * numbers, or hyphens. Reserved names,"default", "latest", and any name with the prefix "ah-".
     */
    public val versionId: Output?
        get() = javaResource.versionId().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })

    /**
     * Enables VPC connectivity for standard apps.
     */
    public val vpcAccessConnector: Output?
        get() = javaResource.vpcAccessConnector().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> flexibleAppVersionVpcAccessConnectorToKotlin(args0) })
            }).orElse(null)
        })
}

public object FlexibleAppVersionMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.gcp.appengine.FlexibleAppVersion::class == javaResource::class

    override fun map(javaResource: Resource): FlexibleAppVersion = FlexibleAppVersion(
        javaResource as
            com.pulumi.gcp.appengine.FlexibleAppVersion,
    )
}

/**
 * @see [FlexibleAppVersion].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [FlexibleAppVersion].
 */
public suspend fun flexibleAppVersion(
    name: String,
    block: suspend FlexibleAppVersionResourceBuilder.() -> Unit,
): FlexibleAppVersion {
    val builder = FlexibleAppVersionResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [FlexibleAppVersion].
 * @param name The _unique_ name of the resulting resource.
 */
public fun flexibleAppVersion(name: String): FlexibleAppVersion {
    val builder = FlexibleAppVersionResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy