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

com.databricks.sdk.service.jobs.CreateJob Maven / Gradle / Ivy

The newest version!
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.

package com.databricks.sdk.service.jobs;

import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.ToStringer;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.util.Collection;
import java.util.Map;
import java.util.Objects;

@Generated
public class CreateJob {
  /** List of permissions to set on the job. */
  @JsonProperty("access_control_list")
  private Collection accessControlList;

  /**
   * The id of the user specified budget policy to use for this job. If not specified, a default
   * budget policy may be applied when creating or modifying the job. See
   * `effective_budget_policy_id` for the budget policy used by this workload.
   */
  @JsonProperty("budget_policy_id")
  private String budgetPolicyId;

  /**
   * An optional continuous property for this job. The continuous property will ensure that there is
   * always one run executing. Only one of `schedule` and `continuous` can be used.
   */
  @JsonProperty("continuous")
  private Continuous continuous;

  /** Deployment information for jobs managed by external sources. */
  @JsonProperty("deployment")
  private JobDeployment deployment;

  /**
   * An optional description for the job. The maximum length is 27700 characters in UTF-8 encoding.
   */
  @JsonProperty("description")
  private String description;

  /**
   * Edit mode of the job.
   *
   * 

* `UI_LOCKED`: The job is in a locked UI state and cannot be modified. * `EDITABLE`: The job * is in an editable state and can be modified. */ @JsonProperty("edit_mode") private JobEditMode editMode; /** * An optional set of email addresses that is notified when runs of this job begin or complete as * well as when this job is deleted. */ @JsonProperty("email_notifications") private JobEmailNotifications emailNotifications; /** * A list of task execution environment specifications that can be referenced by serverless tasks * of this job. An environment is required to be present for serverless tasks. For serverless * notebook tasks, the environment is accessible in the notebook environment panel. For other * serverless tasks, the task environment is required to be specified using environment_key in the * task settings. */ @JsonProperty("environments") private Collection environments; /** * Used to tell what is the format of the job. This field is ignored in Create/Update/Reset calls. * When using the Jobs API 2.1 this value is always set to `"MULTI_TASK"`. */ @JsonProperty("format") private Format format; /** * An optional specification for a remote Git repository containing the source code used by tasks. * Version-controlled source code is supported by notebook, dbt, Python script, and SQL File * tasks. * *

If `git_source` is set, these tasks retrieve the file from the remote repository by default. * However, this behavior can be overridden by setting `source` to `WORKSPACE` on the task. * *

Note: dbt and SQL File tasks support only version-controlled sources. If dbt or SQL File * tasks are used, `git_source` must be defined on the job. */ @JsonProperty("git_source") private GitSource gitSource; /** An optional set of health rules that can be defined for this job. */ @JsonProperty("health") private JobsHealthRules health; /** * A list of job cluster specifications that can be shared and reused by tasks of this job. * Libraries cannot be declared in a shared job cluster. You must declare dependent libraries in * task settings. */ @JsonProperty("job_clusters") private Collection jobClusters; /** * An optional maximum allowed number of concurrent runs of the job. Set this value if you want to * be able to execute multiple runs of the same job concurrently. This is useful for example if * you trigger your job on a frequent schedule and want to allow consecutive runs to overlap with * each other, or if you want to trigger multiple runs which differ by their input parameters. * This setting affects only new runs. For example, suppose the job’s concurrency is 4 and there * are 4 concurrent active runs. Then setting the concurrency to 3 won’t kill any of the active * runs. However, from then on, new runs are skipped unless there are fewer than 3 active runs. * This value cannot exceed 1000. Setting this value to `0` causes all new runs to be skipped. */ @JsonProperty("max_concurrent_runs") private Long maxConcurrentRuns; /** An optional name for the job. The maximum length is 4096 bytes in UTF-8 encoding. */ @JsonProperty("name") private String name; /** * Optional notification settings that are used when sending notifications to each of the * `email_notifications` and `webhook_notifications` for this job. */ @JsonProperty("notification_settings") private JobNotificationSettings notificationSettings; /** Job-level parameter definitions */ @JsonProperty("parameters") private Collection parameters; /** The queue settings of the job. */ @JsonProperty("queue") private QueueSettings queue; /** * Write-only setting. Specifies the user or service principal that the job runs as. If not * specified, the job runs as the user who created the job. * *

Either `user_name` or `service_principal_name` should be specified. If not, an error is * thrown. */ @JsonProperty("run_as") private JobRunAs runAs; /** * An optional periodic schedule for this job. The default behavior is that the job only runs when * triggered by clicking “Run Now” in the Jobs UI or sending an API request to `runNow`. */ @JsonProperty("schedule") private CronSchedule schedule; /** * A map of tags associated with the job. These are forwarded to the cluster as cluster tags for * jobs clusters, and are subject to the same limitations as cluster tags. A maximum of 25 tags * can be added to the job. */ @JsonProperty("tags") private Map tags; /** A list of task specifications to be executed by this job. */ @JsonProperty("tasks") private Collection tasks; /** An optional timeout applied to each run of this job. A value of `0` means no timeout. */ @JsonProperty("timeout_seconds") private Long timeoutSeconds; /** * A configuration to trigger a run when certain conditions are met. The default behavior is that * the job runs only when triggered by clicking “Run Now” in the Jobs UI or sending an API request * to `runNow`. */ @JsonProperty("trigger") private TriggerSettings trigger; /** A collection of system notification IDs to notify when runs of this job begin or complete. */ @JsonProperty("webhook_notifications") private WebhookNotifications webhookNotifications; public CreateJob setAccessControlList(Collection accessControlList) { this.accessControlList = accessControlList; return this; } public Collection getAccessControlList() { return accessControlList; } public CreateJob setBudgetPolicyId(String budgetPolicyId) { this.budgetPolicyId = budgetPolicyId; return this; } public String getBudgetPolicyId() { return budgetPolicyId; } public CreateJob setContinuous(Continuous continuous) { this.continuous = continuous; return this; } public Continuous getContinuous() { return continuous; } public CreateJob setDeployment(JobDeployment deployment) { this.deployment = deployment; return this; } public JobDeployment getDeployment() { return deployment; } public CreateJob setDescription(String description) { this.description = description; return this; } public String getDescription() { return description; } public CreateJob setEditMode(JobEditMode editMode) { this.editMode = editMode; return this; } public JobEditMode getEditMode() { return editMode; } public CreateJob setEmailNotifications(JobEmailNotifications emailNotifications) { this.emailNotifications = emailNotifications; return this; } public JobEmailNotifications getEmailNotifications() { return emailNotifications; } public CreateJob setEnvironments(Collection environments) { this.environments = environments; return this; } public Collection getEnvironments() { return environments; } public CreateJob setFormat(Format format) { this.format = format; return this; } public Format getFormat() { return format; } public CreateJob setGitSource(GitSource gitSource) { this.gitSource = gitSource; return this; } public GitSource getGitSource() { return gitSource; } public CreateJob setHealth(JobsHealthRules health) { this.health = health; return this; } public JobsHealthRules getHealth() { return health; } public CreateJob setJobClusters(Collection jobClusters) { this.jobClusters = jobClusters; return this; } public Collection getJobClusters() { return jobClusters; } public CreateJob setMaxConcurrentRuns(Long maxConcurrentRuns) { this.maxConcurrentRuns = maxConcurrentRuns; return this; } public Long getMaxConcurrentRuns() { return maxConcurrentRuns; } public CreateJob setName(String name) { this.name = name; return this; } public String getName() { return name; } public CreateJob setNotificationSettings(JobNotificationSettings notificationSettings) { this.notificationSettings = notificationSettings; return this; } public JobNotificationSettings getNotificationSettings() { return notificationSettings; } public CreateJob setParameters(Collection parameters) { this.parameters = parameters; return this; } public Collection getParameters() { return parameters; } public CreateJob setQueue(QueueSettings queue) { this.queue = queue; return this; } public QueueSettings getQueue() { return queue; } public CreateJob setRunAs(JobRunAs runAs) { this.runAs = runAs; return this; } public JobRunAs getRunAs() { return runAs; } public CreateJob setSchedule(CronSchedule schedule) { this.schedule = schedule; return this; } public CronSchedule getSchedule() { return schedule; } public CreateJob setTags(Map tags) { this.tags = tags; return this; } public Map getTags() { return tags; } public CreateJob setTasks(Collection tasks) { this.tasks = tasks; return this; } public Collection getTasks() { return tasks; } public CreateJob setTimeoutSeconds(Long timeoutSeconds) { this.timeoutSeconds = timeoutSeconds; return this; } public Long getTimeoutSeconds() { return timeoutSeconds; } public CreateJob setTrigger(TriggerSettings trigger) { this.trigger = trigger; return this; } public TriggerSettings getTrigger() { return trigger; } public CreateJob setWebhookNotifications(WebhookNotifications webhookNotifications) { this.webhookNotifications = webhookNotifications; return this; } public WebhookNotifications getWebhookNotifications() { return webhookNotifications; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; CreateJob that = (CreateJob) o; return Objects.equals(accessControlList, that.accessControlList) && Objects.equals(budgetPolicyId, that.budgetPolicyId) && Objects.equals(continuous, that.continuous) && Objects.equals(deployment, that.deployment) && Objects.equals(description, that.description) && Objects.equals(editMode, that.editMode) && Objects.equals(emailNotifications, that.emailNotifications) && Objects.equals(environments, that.environments) && Objects.equals(format, that.format) && Objects.equals(gitSource, that.gitSource) && Objects.equals(health, that.health) && Objects.equals(jobClusters, that.jobClusters) && Objects.equals(maxConcurrentRuns, that.maxConcurrentRuns) && Objects.equals(name, that.name) && Objects.equals(notificationSettings, that.notificationSettings) && Objects.equals(parameters, that.parameters) && Objects.equals(queue, that.queue) && Objects.equals(runAs, that.runAs) && Objects.equals(schedule, that.schedule) && Objects.equals(tags, that.tags) && Objects.equals(tasks, that.tasks) && Objects.equals(timeoutSeconds, that.timeoutSeconds) && Objects.equals(trigger, that.trigger) && Objects.equals(webhookNotifications, that.webhookNotifications); } @Override public int hashCode() { return Objects.hash( accessControlList, budgetPolicyId, continuous, deployment, description, editMode, emailNotifications, environments, format, gitSource, health, jobClusters, maxConcurrentRuns, name, notificationSettings, parameters, queue, runAs, schedule, tags, tasks, timeoutSeconds, trigger, webhookNotifications); } @Override public String toString() { return new ToStringer(CreateJob.class) .add("accessControlList", accessControlList) .add("budgetPolicyId", budgetPolicyId) .add("continuous", continuous) .add("deployment", deployment) .add("description", description) .add("editMode", editMode) .add("emailNotifications", emailNotifications) .add("environments", environments) .add("format", format) .add("gitSource", gitSource) .add("health", health) .add("jobClusters", jobClusters) .add("maxConcurrentRuns", maxConcurrentRuns) .add("name", name) .add("notificationSettings", notificationSettings) .add("parameters", parameters) .add("queue", queue) .add("runAs", runAs) .add("schedule", schedule) .add("tags", tags) .add("tasks", tasks) .add("timeoutSeconds", timeoutSeconds) .add("trigger", trigger) .add("webhookNotifications", webhookNotifications) .toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy