Skip to content

Commit

Permalink
Remove denylisted steps from GetWorkflowStep response
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Widdis <[email protected]>
  • Loading branch information
dbwiddis committed Jul 12, 2024
1 parent c9afaae commit d5e92a3
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,12 @@
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import java.util.stream.Stream;

import static org.opensearch.flowframework.common.CommonValue.ACTIONS_FIELD;
import static org.opensearch.flowframework.common.CommonValue.CONFIGURATIONS;
Expand Down Expand Up @@ -415,13 +416,11 @@ public static List<String> getInputByWorkflowType(String workflowStep) throws Fl
* @return WorkflowValidator
*/
public WorkflowValidator getWorkflowValidator() {
Map<String, WorkflowStepValidator> workflowStepValidators = new HashMap<>();

for (WorkflowSteps mapping : WorkflowSteps.values()) {
workflowStepValidators.put(mapping.getWorkflowStepName(), mapping.getWorkflowStepValidator());
}

return new WorkflowValidator(workflowStepValidators);
return new WorkflowValidator(
Stream.of(WorkflowSteps.values())
.filter(w -> !WorkflowProcessSorter.WORKFLOW_STEP_DENYLIST.contains(w.getWorkflowStepName()))
.collect(Collectors.toMap(WorkflowSteps::getWorkflowStepName, WorkflowSteps::getWorkflowStepValidator))
);
}

/**
Expand All @@ -430,22 +429,20 @@ public WorkflowValidator getWorkflowValidator() {
* @return WorkflowValidator
*/
public WorkflowValidator getWorkflowValidatorByStep(List<String> steps) {
Map<String, WorkflowStepValidator> workflowStepValidators = new HashMap<>();
Set<String> invalidSteps = new HashSet<>(steps);

for (WorkflowSteps mapping : WorkflowSteps.values()) {
String step = mapping.getWorkflowStepName();
if (steps.contains(step)) {
workflowStepValidators.put(mapping.getWorkflowStepName(), mapping.getWorkflowStepValidator());
invalidSteps.remove(step);
}
}

Set<String> validSteps = Stream.of(WorkflowSteps.values())
.map(WorkflowSteps::getWorkflowStepName)
.filter(name -> !WorkflowProcessSorter.WORKFLOW_STEP_DENYLIST.contains(name))
.filter(steps::contains)
.collect(Collectors.toSet());
Set<String> invalidSteps = steps.stream().filter(name -> !validSteps.contains(name)).collect(Collectors.toSet());
if (!invalidSteps.isEmpty()) {
throw new FlowFrameworkException("Invalid step name: " + invalidSteps, RestStatus.BAD_REQUEST);
}

return new WorkflowValidator(workflowStepValidators);
return new WorkflowValidator(
Stream.of(WorkflowSteps.values())
.filter(w -> validSteps.contains(w.getWorkflowStepName()))
.collect(Collectors.toMap(WorkflowSteps::getWorkflowStepName, WorkflowSteps::getWorkflowStepValidator))
);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import org.opensearch.client.Client;
import org.opensearch.flowframework.common.FlowFrameworkSettings;
import org.opensearch.flowframework.indices.FlowFrameworkIndicesHandler;
import org.opensearch.flowframework.workflow.WorkflowProcessSorter;
import org.opensearch.flowframework.workflow.WorkflowStepFactory;
import org.opensearch.flowframework.workflow.WorkflowStepFactory.WorkflowSteps;
import org.opensearch.ml.client.MachineLearningNodeClient;
Expand Down Expand Up @@ -70,6 +71,7 @@ public void testWorkflowStepFactoryHasValidators() throws IOException {

// Get all registered workflow step types in the workflow step factory
List<String> registeredWorkflowStepTypes = new ArrayList<String>(workflowStepFactory.getStepMap().keySet());
registeredWorkflowStepTypes.removeAll(WorkflowProcessSorter.WORKFLOW_STEP_DENYLIST);

// Check if each registered step has a corresponding validator definition
assertTrue(registeredWorkflowStepTypes.containsAll(registeredWorkflowValidatorTypes));
Expand Down

0 comments on commit d5e92a3

Please sign in to comment.