com.pulumi.gcp.dataproc.kotlin.WorkflowTemplate.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gcp-kotlin Show documentation
Show all versions of pulumi-gcp-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@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
© 2015 - 2025 Weber Informatics LLC | Privacy Policy