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

io.kestra.plugin.gcp.dataproc.batches.SparkSubmit Maven / Gradle / Ivy

package io.kestra.plugin.gcp.dataproc.batches;

import com.google.cloud.dataproc.v1.Batch;
import com.google.cloud.dataproc.v1.SparkBatch;
import io.kestra.core.exceptions.IllegalVariableEvaluationException;
import io.kestra.core.models.annotations.Example;
import io.kestra.core.models.annotations.Plugin;
import io.kestra.core.models.annotations.PluginProperty;
import io.kestra.core.runners.RunContext;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.ToString;
import lombok.experimental.SuperBuilder;

import jakarta.validation.constraints.NotNull;

@SuperBuilder
@ToString
@EqualsAndHashCode
@Getter
@NoArgsConstructor
@Schema(
    title = "Submit an [Apache Spark](https://spark.apache.org/) batch workload."
)
@Plugin(
    examples = @Example(
        full = true,
        code = """
            id: gcp_dataproc_spark_submit
            namespace: company.team
            tasks:
              - id: spark_submit
                type: io.kestra.plugin.gcp.dataproc.batches.SparkSubmit
                jarFileUris: 
                  - 'gs://spark-jobs-kestra/spark-examples.jar'
                mainClass: org.apache.spark.examples.SparkPi
                args:
                  - 1000
                name: test-spark
                region: europe-west3
            """
    )
)
public class SparkSubmit extends AbstractSparkSubmit {
    @Schema(
        title = "The name of the driver main class.",
        description = "The jar file that contains the class must be in the classpath or specified in `jarFileUris`"
    )
    @PluginProperty(dynamic = true)
    @NotNull
    private String mainClass;

    @Override
    protected void buildBatch(Batch.Builder builder, RunContext runContext) throws IllegalVariableEvaluationException {
        SparkBatch.Builder sparkBuilder = SparkBatch.newBuilder();

        if (this.mainClass != null) {
            sparkBuilder.setMainClass(runContext.render(this.mainClass));
        }

        if (this.jarFileUris != null) {
            sparkBuilder.addAllJarFileUris(runContext.render(this.jarFileUris));
        }

        if (this.fileUris != null) {
            sparkBuilder.addAllFileUris(runContext.render(this.fileUris));
        }

        if (this.archiveUris != null) {
            sparkBuilder.addAllArchiveUris(runContext.render(this.archiveUris));
        }

        if (this.args != null) {
            sparkBuilder.addAllArgs(runContext.render(this.args));
        }

        builder.setSparkBatch(sparkBuilder.build());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy