
io.kestra.plugin.gcp.vertexai.models.Scheduling Maven / Gradle / Ivy
package io.kestra.plugin.gcp.vertexai.models;
import io.kestra.core.exceptions.IllegalVariableEvaluationException;
import io.kestra.core.models.annotations.PluginProperty;
import io.kestra.core.runners.RunContext;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Builder;
import lombok.Getter;
import lombok.extern.jackson.Jacksonized;
import java.time.Duration;
import jakarta.validation.constraints.NotNull;
@Getter
@Builder
@Jacksonized
public class Scheduling {
@Schema(
title = "The maximum job running time. The default is 7 days."
)
@PluginProperty(dynamic = false)
@NotNull
private Duration timeOut;
@Schema(
title = "Restarts the entire CustomJob if a worker gets restarted.",
description = "This feature can be used by distributed training jobs that are not resilient to workers leaving and joining a job."
)
@PluginProperty(dynamic = false)
@NotNull
private Boolean restartJobOnWorkerRestart;
public com.google.cloud.aiplatform.v1.Scheduling to(RunContext runContext) throws IllegalVariableEvaluationException {
com.google.cloud.aiplatform.v1.Scheduling.Builder builder = com.google.cloud.aiplatform.v1.Scheduling.newBuilder();
if (this.getTimeOut() != null) {
builder.setTimeout(com.google.protobuf.Duration.newBuilder().setSeconds(this.getTimeOut().getSeconds()).setNanos(this.getTimeOut().getNano()).build());
}
if (this.getRestartJobOnWorkerRestart() != null) {
builder.setRestartJobOnWorkerRestart(this.getRestartJobOnWorkerRestart());
}
return builder.build();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy