org.flyte.jflyte.utils.WorkflowNodeVisitor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jflyte-utils Show documentation
Show all versions of jflyte-utils Show documentation
Primarily used by jflyte, but can also be used to extend or build a jflyte alternative
/*
* Copyright 2021-2023 Flyte Authors.
*
* 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 org.flyte.jflyte.utils;
import static org.flyte.jflyte.utils.MoreCollectors.toUnmodifiableList;
import java.util.List;
import org.flyte.api.v1.BranchNode;
import org.flyte.api.v1.IfBlock;
import org.flyte.api.v1.IfElseBlock;
import org.flyte.api.v1.Node;
import org.flyte.api.v1.PartialLaunchPlanIdentifier;
import org.flyte.api.v1.PartialTaskIdentifier;
import org.flyte.api.v1.PartialWorkflowIdentifier;
import org.flyte.api.v1.TaskNode;
import org.flyte.api.v1.WorkflowNode;
import org.flyte.api.v1.WorkflowTemplate;
/** Utility to navigate through the workflow nodes. */
public class WorkflowNodeVisitor {
public WorkflowTemplate visitWorkflowTemplate(WorkflowTemplate template) {
List newNodes =
template.nodes().stream().map(this::visitNode).collect(toUnmodifiableList());
return template.toBuilder().nodes(newNodes).build();
}
public Node visitNode(Node node) {
return node.toBuilder()
.branchNode(node.branchNode() != null ? visitBranchNode(node.branchNode()) : null)
.taskNode(node.taskNode() != null ? visitTaskNode(node.taskNode()) : null)
.workflowNode(node.workflowNode() != null ? visitWorkflowNode(node.workflowNode()) : null)
.build();
}
TaskNode visitTaskNode(TaskNode taskNode) {
return TaskNode.builder().referenceId(visitTaskIdentifier(taskNode.referenceId())).build();
}
WorkflowNode visitWorkflowNode(WorkflowNode workflowNode) {
return workflowNode.toBuilder()
.reference(visitWorkflowNodeReference(workflowNode.reference()))
.build();
}
BranchNode visitBranchNode(BranchNode branchNode) {
return branchNode.toBuilder().ifElse(visitIfElseBlock(branchNode.ifElse())).build();
}
IfElseBlock visitIfElseBlock(IfElseBlock ifElse) {
return ifElse.toBuilder()
.case_(visitIfBlock(ifElse.case_()))
.other(ifElse.other().stream().map(this::visitIfBlock).collect(toUnmodifiableList()))
.elseNode(ifElse.elseNode() != null ? visitNode(ifElse.elseNode()) : null)
.build();
}
IfBlock visitIfBlock(IfBlock ifBlock) {
return ifBlock.toBuilder().thenNode(visitNode(ifBlock.thenNode())).build();
}
WorkflowNode.Reference visitWorkflowNodeReference(WorkflowNode.Reference reference) {
switch (reference.kind()) {
case LAUNCH_PLAN_REF:
return WorkflowNode.Reference.ofLaunchPlanRef(
visitLaunchPlanIdentifier(reference.launchPlanRef()));
case SUB_WORKFLOW_REF:
return WorkflowNode.Reference.ofSubWorkflowRef(
visitWorkflowIdentifier(reference.subWorkflowRef()));
}
throw new AssertionError("Unexpected WorkflowNode.Reference.Kind: " + reference.kind());
}
protected PartialTaskIdentifier visitTaskIdentifier(PartialTaskIdentifier value) {
return value;
}
protected PartialWorkflowIdentifier visitWorkflowIdentifier(PartialWorkflowIdentifier value) {
return value;
}
protected PartialLaunchPlanIdentifier visitLaunchPlanIdentifier(
PartialLaunchPlanIdentifier value) {
return value;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy