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

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

package com.pulumi.gcp.dataproc.kotlin

import com.pulumi.core.Output
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplateJob
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplateParameter
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplatePlacement
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.Any
import kotlin.Boolean
import kotlin.Deprecated
import kotlin.Int
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplateJob.Companion.toKotlin as workflowTemplateJobToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplateParameter.Companion.toKotlin as workflowTemplateParameterToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.WorkflowTemplatePlacement.Companion.toKotlin as workflowTemplatePlacementToKotlin

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

    public var args: WorkflowTemplateArgs = WorkflowTemplateArgs()

    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 WorkflowTemplateArgsBuilder.() -> Unit) {
        val builder = WorkflowTemplateArgsBuilder()
        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(): WorkflowTemplate {
        val builtJavaResource = com.pulumi.gcp.dataproc.WorkflowTemplate(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return WorkflowTemplate(builtJavaResource)
    }
}

/**
 * A Workflow Template is a reusable workflow configuration. It defines a graph of jobs with information on where to run those jobs.
 * ## Example Usage
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const template = new gcp.dataproc.WorkflowTemplate("template", {
 *     name: "template-example",
 *     location: "us-central1",
 *     placement: {
 *         managedCluster: {
 *             clusterName: "my-cluster",
 *             config: {
 *                 gceClusterConfig: {
 *                     zone: "us-central1-a",
 *                     tags: [
 *                         "foo",
 *                         "bar",
 *                     ],
 *                 },
 *                 masterConfig: {
 *                     numInstances: 1,
 *                     machineType: "n1-standard-1",
 *                     diskConfig: {
 *                         bootDiskType: "pd-ssd",
 *                         bootDiskSizeGb: 15,
 *                     },
 *                 },
 *                 workerConfig: {
 *                     numInstances: 3,
 *                     machineType: "n1-standard-2",
 *                     diskConfig: {
 *                         bootDiskSizeGb: 10,
 *                         numLocalSsds: 2,
 *                     },
 *                 },
 *                 secondaryWorkerConfig: {
 *                     numInstances: 2,
 *                 },
 *                 softwareConfig: {
 *                     imageVersion: "2.0.35-debian10",
 *                 },
 *             },
 *         },
 *     },
 *     jobs: [
 *         {
 *             stepId: "someJob",
 *             sparkJob: {
 *                 mainClass: "SomeClass",
 *             },
 *         },
 *         {
 *             stepId: "otherJob",
 *             prerequisiteStepIds: ["someJob"],
 *             prestoJob: {
 *                 queryFileUri: "someuri",
 *             },
 *         },
 *     ],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * template = gcp.dataproc.WorkflowTemplate("template",
 *     name="template-example",
 *     location="us-central1",
 *     placement=gcp.dataproc.WorkflowTemplatePlacementArgs(
 *         managed_cluster=gcp.dataproc.WorkflowTemplatePlacementManagedClusterArgs(
 *             cluster_name="my-cluster",
 *             config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigArgs(
 *                 gce_cluster_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigGceClusterConfigArgs(
 *                     zone="us-central1-a",
 *                     tags=[
 *                         "foo",
 *                         "bar",
 *                     ],
 *                 ),
 *                 master_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigMasterConfigArgs(
 *                     num_instances=1,
 *                     machine_type="n1-standard-1",
 *                     disk_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigMasterConfigDiskConfigArgs(
 *                         boot_disk_type="pd-ssd",
 *                         boot_disk_size_gb=15,
 *                     ),
 *                 ),
 *                 worker_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigArgs(
 *                     num_instances=3,
 *                     machine_type="n1-standard-2",
 *                     disk_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigDiskConfigArgs(
 *                         boot_disk_size_gb=10,
 *                         num_local_ssds=2,
 *                     ),
 *                 ),
 *                 secondary_worker_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigSecondaryWorkerConfigArgs(
 *                     num_instances=2,
 *                 ),
 *                 software_config=gcp.dataproc.WorkflowTemplatePlacementManagedClusterConfigSoftwareConfigArgs(
 *                     image_version="2.0.35-debian10",
 *                 ),
 *             ),
 *         ),
 *     ),
 *     jobs=[
 *         gcp.dataproc.WorkflowTemplateJobArgs(
 *             step_id="someJob",
 *             spark_job=gcp.dataproc.WorkflowTemplateJobSparkJobArgs(
 *                 main_class="SomeClass",
 *             ),
 *         ),
 *         gcp.dataproc.WorkflowTemplateJobArgs(
 *             step_id="otherJob",
 *             prerequisite_step_ids=["someJob"],
 *             presto_job=gcp.dataproc.WorkflowTemplateJobPrestoJobArgs(
 *                 query_file_uri="someuri",
 *             ),
 *         ),
 *     ])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var template = new Gcp.Dataproc.WorkflowTemplate("template", new()
 *     {
 *         Name = "template-example",
 *         Location = "us-central1",
 *         Placement = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementArgs
 *         {
 *             ManagedCluster = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterArgs
 *             {
 *                 ClusterName = "my-cluster",
 *                 Config = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigArgs
 *                 {
 *                     GceClusterConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigGceClusterConfigArgs
 *                     {
 *                         Zone = "us-central1-a",
 *                         Tags = new[]
 *                         {
 *                             "foo",
 *                             "bar",
 *                         },
 *                     },
 *                     MasterConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigMasterConfigArgs
 *                     {
 *                         NumInstances = 1,
 *                         MachineType = "n1-standard-1",
 *                         DiskConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigMasterConfigDiskConfigArgs
 *                         {
 *                             BootDiskType = "pd-ssd",
 *                             BootDiskSizeGb = 15,
 *                         },
 *                     },
 *                     WorkerConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigArgs
 *                     {
 *                         NumInstances = 3,
 *                         MachineType = "n1-standard-2",
 *                         DiskConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigDiskConfigArgs
 *                         {
 *                             BootDiskSizeGb = 10,
 *                             NumLocalSsds = 2,
 *                         },
 *                     },
 *                     SecondaryWorkerConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigSecondaryWorkerConfigArgs
 *                     {
 *                         NumInstances = 2,
 *                     },
 *                     SoftwareConfig = new Gcp.Dataproc.Inputs.WorkflowTemplatePlacementManagedClusterConfigSoftwareConfigArgs
 *                     {
 *                         ImageVersion = "2.0.35-debian10",
 *                     },
 *                 },
 *             },
 *         },
 *         Jobs = new[]
 *         {
 *             new Gcp.Dataproc.Inputs.WorkflowTemplateJobArgs
 *             {
 *                 StepId = "someJob",
 *                 SparkJob = new Gcp.Dataproc.Inputs.WorkflowTemplateJobSparkJobArgs
 *                 {
 *                     MainClass = "SomeClass",
 *                 },
 *             },
 *             new Gcp.Dataproc.Inputs.WorkflowTemplateJobArgs
 *             {
 *                 StepId = "otherJob",
 *                 PrerequisiteStepIds = new[]
 *                 {
 *                     "someJob",
 *                 },
 *                 PrestoJob = new Gcp.Dataproc.Inputs.WorkflowTemplateJobPrestoJobArgs
 *                 {
 *                     QueryFileUri = "someuri",
 *                 },
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := dataproc.NewWorkflowTemplate(ctx, "template", &dataproc.WorkflowTemplateArgs{
 * 			Name:     pulumi.String("template-example"),
 * 			Location: pulumi.String("us-central1"),
 * 			Placement: &dataproc.WorkflowTemplatePlacementArgs{
 * 				ManagedCluster: &dataproc.WorkflowTemplatePlacementManagedClusterArgs{
 * 					ClusterName: pulumi.String("my-cluster"),
 * 					Config: &dataproc.WorkflowTemplatePlacementManagedClusterConfigArgs{
 * 						GceClusterConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigGceClusterConfigArgs{
 * 							Zone: pulumi.String("us-central1-a"),
 * 							Tags: pulumi.StringArray{
 * 								pulumi.String("foo"),
 * 								pulumi.String("bar"),
 * 							},
 * 						},
 * 						MasterConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigMasterConfigArgs{
 * 							NumInstances: pulumi.Int(1),
 * 							MachineType:  pulumi.String("n1-standard-1"),
 * 							DiskConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigMasterConfigDiskConfigArgs{
 * 								BootDiskType:   pulumi.String("pd-ssd"),
 * 								BootDiskSizeGb: pulumi.Int(15),
 * 							},
 * 						},
 * 						WorkerConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigArgs{
 * 							NumInstances: pulumi.Int(3),
 * 							MachineType:  pulumi.String("n1-standard-2"),
 * 							DiskConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigDiskConfigArgs{
 * 								BootDiskSizeGb: pulumi.Int(10),
 * 								NumLocalSsds:   pulumi.Int(2),
 * 							},
 * 						},
 * 						SecondaryWorkerConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigSecondaryWorkerConfigArgs{
 * 							NumInstances: pulumi.Int(2),
 * 						},
 * 						SoftwareConfig: &dataproc.WorkflowTemplatePlacementManagedClusterConfigSoftwareConfigArgs{
 * 							ImageVersion: pulumi.String("2.0.35-debian10"),
 * 						},
 * 					},
 * 				},
 * 			},
 * 			Jobs: dataproc.WorkflowTemplateJobArray{
 * 				&dataproc.WorkflowTemplateJobArgs{
 * 					StepId: pulumi.String("someJob"),
 * 					SparkJob: &dataproc.WorkflowTemplateJobSparkJobArgs{
 * 						MainClass: pulumi.String("SomeClass"),
 * 					},
 * 				},
 * 				&dataproc.WorkflowTemplateJobArgs{
 * 					StepId: pulumi.String("otherJob"),
 * 					PrerequisiteStepIds: pulumi.StringArray{
 * 						pulumi.String("someJob"),
 * 					},
 * 					PrestoJob: &dataproc.WorkflowTemplateJobPrestoJobArgs{
 * 						QueryFileUri: pulumi.String("someuri"),
 * 					},
 * 				},
 * 			},
 * 		})
 * 		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.dataproc.WorkflowTemplate;
 * import com.pulumi.gcp.dataproc.WorkflowTemplateArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigGceClusterConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigMasterConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigMasterConfigDiskConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigWorkerConfigDiskConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigSecondaryWorkerConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplatePlacementManagedClusterConfigSoftwareConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplateJobArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplateJobSparkJobArgs;
 * import com.pulumi.gcp.dataproc.inputs.WorkflowTemplateJobPrestoJobArgs;
 * 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 template = new WorkflowTemplate("template", WorkflowTemplateArgs.builder()
 *             .name("template-example")
 *             .location("us-central1")
 *             .placement(WorkflowTemplatePlacementArgs.builder()
 *                 .managedCluster(WorkflowTemplatePlacementManagedClusterArgs.builder()
 *                     .clusterName("my-cluster")
 *                     .config(WorkflowTemplatePlacementManagedClusterConfigArgs.builder()
 *                         .gceClusterConfig(WorkflowTemplatePlacementManagedClusterConfigGceClusterConfigArgs.builder()
 *                             .zone("us-central1-a")
 *                             .tags(
 *                                 "foo",
 *                                 "bar")
 *                             .build())
 *                         .masterConfig(WorkflowTemplatePlacementManagedClusterConfigMasterConfigArgs.builder()
 *                             .numInstances(1)
 *                             .machineType("n1-standard-1")
 *                             .diskConfig(WorkflowTemplatePlacementManagedClusterConfigMasterConfigDiskConfigArgs.builder()
 *                                 .bootDiskType("pd-ssd")
 *                                 .bootDiskSizeGb(15)
 *                                 .build())
 *                             .build())
 *                         .workerConfig(WorkflowTemplatePlacementManagedClusterConfigWorkerConfigArgs.builder()
 *                             .numInstances(3)
 *                             .machineType("n1-standard-2")
 *                             .diskConfig(WorkflowTemplatePlacementManagedClusterConfigWorkerConfigDiskConfigArgs.builder()
 *                                 .bootDiskSizeGb(10)
 *                                 .numLocalSsds(2)
 *                                 .build())
 *                             .build())
 *                         .secondaryWorkerConfig(WorkflowTemplatePlacementManagedClusterConfigSecondaryWorkerConfigArgs.builder()
 *                             .numInstances(2)
 *                             .build())
 *                         .softwareConfig(WorkflowTemplatePlacementManagedClusterConfigSoftwareConfigArgs.builder()
 *                             .imageVersion("2.0.35-debian10")
 *                             .build())
 *                         .build())
 *                     .build())
 *                 .build())
 *             .jobs(
 *                 WorkflowTemplateJobArgs.builder()
 *                     .stepId("someJob")
 *                     .sparkJob(WorkflowTemplateJobSparkJobArgs.builder()
 *                         .mainClass("SomeClass")
 *                         .build())
 *                     .build(),
 *                 WorkflowTemplateJobArgs.builder()
 *                     .stepId("otherJob")
 *                     .prerequisiteStepIds("someJob")
 *                     .prestoJob(WorkflowTemplateJobPrestoJobArgs.builder()
 *                         .queryFileUri("someuri")
 *                         .build())
 *                     .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   template:
 *     type: gcp:dataproc:WorkflowTemplate
 *     properties:
 *       name: template-example
 *       location: us-central1
 *       placement:
 *         managedCluster:
 *           clusterName: my-cluster
 *           config:
 *             gceClusterConfig:
 *               zone: us-central1-a
 *               tags:
 *                 - foo
 *                 - bar
 *             masterConfig:
 *               numInstances: 1
 *               machineType: n1-standard-1
 *               diskConfig:
 *                 bootDiskType: pd-ssd
 *                 bootDiskSizeGb: 15
 *             workerConfig:
 *               numInstances: 3
 *               machineType: n1-standard-2
 *               diskConfig:
 *                 bootDiskSizeGb: 10
 *                 numLocalSsds: 2
 *             secondaryWorkerConfig:
 *               numInstances: 2
 *             softwareConfig:
 *               imageVersion: 2.0.35-debian10
 *       jobs:
 *         - stepId: someJob
 *           sparkJob:
 *             mainClass: SomeClass
 *         - stepId: otherJob
 *           prerequisiteStepIds:
 *             - someJob
 *           prestoJob:
 *             queryFileUri: someuri
 * ```
 * 
 * ## Import
 * WorkflowTemplate can be imported using any of these accepted formats:
 * * `projects/{{project}}/locations/{{location}}/workflowTemplates/{{name}}`
 * * `{{project}}/{{location}}/{{name}}`
 * * `{{location}}/{{name}}`
 * When using the `pulumi import` command, WorkflowTemplate can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:dataproc/workflowTemplate:WorkflowTemplate default projects/{{project}}/locations/{{location}}/workflowTemplates/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:dataproc/workflowTemplate:WorkflowTemplate default {{project}}/{{location}}/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:dataproc/workflowTemplate:WorkflowTemplate default {{location}}/{{name}}
 * ```
 */
public class WorkflowTemplate internal constructor(
    override val javaResource: com.pulumi.gcp.dataproc.WorkflowTemplate,
) : KotlinCustomResource(javaResource, WorkflowTemplateMapper) {
    /**
     * Output only. The time template was created.
     */
    public val createTime: Output
        get() = javaResource.createTime().applyValue({ args0 -> args0 })

    /**
     * Optional. Timeout duration for the DAG of jobs, expressed in seconds (see [JSON representation of
   * duration](https://developers.google.com/protocol-buffers/docs/proto3#json)). The timeout duration must be from 10
     * minutes ("600s") to 24 hours ("86400s"). The timer begins when the first job is submitted. If the workflow is running at
     * the end of the timeout period, any remaining jobs are cancelled, the workflow is ended, and if the workflow was running
     * on a [managed
   * cluster](https://www.terraform.io/dataproc/docs/concepts/workflows/using-workflows#configuring_or_selecting_a_cluster),
     * the cluster is deleted.
     */
    public val dagTimeout: Output?
        get() = javaResource.dagTimeout().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

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

    /**
     * Required. The Directed Acyclic Graph of Jobs to submit.
     */
    public val jobs: Output>
        get() = javaResource.jobs().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    workflowTemplateJobToKotlin(args0)
                })
            })
        })

    /**
     * Optional. The labels to associate with this template. These labels will be propagated to all jobs and clusters created
     * by the workflow instance. Label **keys** must contain 1 to 63 characters, and must conform to [RFC
   * 1035](https://www.ietf.org/rfc/rfc1035.txt). Label **values** may be empty, but, if present, must contain 1 to 63
     * characters, and must conform to [RFC 1035](https://www.ietf.org/rfc/rfc1035.txt). No more than 32 labels can be
     * associated with a template. **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.
     */
    public val labels: Output>?
        get() = javaResource.labels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })

    /**
     * The location for the resource
     */
    public val location: Output
        get() = javaResource.location().applyValue({ args0 -> args0 })

    /**
     * Output only. The resource name of the workflow template, as described in https://cloud.google.com/apis/design/resource_names. * For `projects.regions.workflowTemplates`, the resource name of the template has the following format: `projects/{project_id}/regions/{region}/workflowTemplates/{template_id}` * For `projects.locations.workflowTemplates`, the resource name of the template has the following format: `projects/{project_id}/locations/{location}/workflowTemplates/{template_id}`
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * Optional. Template parameters whose values are substituted into the template. Values for parameters must be provided
     * when the template is instantiated.
     */
    public val parameters: Output>?
        get() = javaResource.parameters().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 -> workflowTemplateParameterToKotlin(args0) })
                })
            }).orElse(null)
        })

    /**
     * Required. WorkflowTemplate scheduling information.
     */
    public val placement: Output
        get() = javaResource.placement().applyValue({ args0 ->
            args0.let({ args0 ->
                workflowTemplatePlacementToKotlin(args0)
            })
        })

    /**
     * The project for the resource
     */
    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * The combination of labels configured directly on the resource and default labels configured on the provider.
     */
    public val pulumiLabels: Output>
        get() = javaResource.pulumiLabels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * Output only. The time template was last updated.
     */
    public val updateTime: Output
        get() = javaResource.updateTime().applyValue({ args0 -> args0 })

    /**
     * Output only. The current version of this workflow template.
     */
    @Deprecated(
        message = """
  version is not useful as a configurable field, and will be removed in the future.
  """,
    )
    public val version: Output
        get() = javaResource.version().applyValue({ args0 -> args0 })
}

public object WorkflowTemplateMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.gcp.dataproc.WorkflowTemplate::class == javaResource::class

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

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

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




© 2015 - 2025 Weber Informatics LLC | Privacy Policy