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

indi.atlantis.framework.chaconne.dag.Dag Maven / Gradle / Ivy

/**
* Copyright 2017-2021 Fred Feng ([email protected])

* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*    http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package indi.atlantis.framework.chaconne.dag;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import indi.atlantis.framework.chaconne.JobDefinition;
import indi.atlantis.framework.chaconne.JobKey;
import indi.atlantis.framework.chaconne.Trigger;
import indi.atlantis.framework.chaconne.utils.GenericJobDefinition;

/**
 * 
 * Dag
 * 
 * @author Fred Feng
 *
 * @since 2.0.1
 */
public class Dag implements DagDefination {

	public Dag(String clusterName, String groupName, String name) {
		this.builder = GenericJobDefinition.newJob(clusterName, groupName, name, StartDagJob.class);
	}

	private DagFlow startNode;
	private GenericJobDefinition.Builder builder;

	public Dag setDescription(String description) {
		builder.setDescription(description);
		return this;
	}

	public Dag setRetries(int retries) {
		builder.setRetries(retries);
		return this;
	}

	public Dag setWeight(int weight) {
		builder.setWeight(weight);
		return this;
	}

	public Dag setTimeout(long timeout) {
		builder.setTimeout(timeout);
		return this;
	}

	public Dag setEmail(String email) {
		builder.setEmail(email);
		return this;
	}

	public Dag setTrigger(Trigger trigger) {
		builder.setTrigger(trigger);
		return this;
	}

	public DagFlow startWith(String clusterName, String groupName, String jobName, String jobClassName) {
		return (startNode = new DagJob(clusterName, groupName, jobName, jobClassName, this));
	}

	@Override
	public JobKey getJobKey() {
		return builder.getJobKey();
	}

	@Override
	public JobDefinition[] getJobDefinitions() {
		List jobDefinitions = new ArrayList();
		jobDefinitions.add(builder.build());
		jobDefinitions.addAll(Arrays.asList(startNode.getJobDefinitions()));
		return jobDefinitions.toArray(new JobDefinition[0]);
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy