+++ /dev/null
-/*-
- * ============LICENSE_START=======================================================
- * ONAP - SO
- * ================================================================================
- * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * 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.
- * ============LICENSE_END=========================================================
- */
-
-package org.onap.so.bpmn.common.validation;
-
-import java.util.Set;
-
-import org.onap.so.bpmn.common.BuildingBlockExecution;
-
-public interface BuildingBlockValidator {
-
-       
-       /**
-        * Name of the building block to be validated
-        * @return
-        */
-       public Set<String> forBuildingBlock();
-       
-       /**
-        * Determines whether or not the building block should be executed
-        * 
-        * @param execution
-        * @return
-        */
-       public boolean validate(BuildingBlockExecution execution);
-       
-}
 
  *
  */
 @Component
-public class BuildingBlockValidatorRunner {
-
-       private static Logger logger = LoggerFactory.getLogger(BuildingBlockValidatorRunner.class);
-       @Autowired
-       private ApplicationContext context;
-       
-       @Autowired
-       private ExceptionBuilder exceptionBuilder;
-       
-       private List<PreBuildingBlockValidator> preBuildingBlockValidators;
-       private List<PostBuildingBlockValidator> postBuildingBlockValidators;
-
+public class BuildingBlockValidatorRunner extends FlowValidatorRunner<PreBuildingBlockValidator, PostBuildingBlockValidator> {
        
        @PostConstruct
        protected void init() {
                
-               preBuildingBlockValidators = new ArrayList<>(
+               preFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PreBuildingBlockValidator.class)).orElse(new HashMap<>()).values());
-               postBuildingBlockValidators = new ArrayList<>(
+               postFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PostBuildingBlockValidator.class)).orElse(new HashMap<>()).values());
        }
        
-       public boolean preValidate(String bbName, BuildingBlockExecution execution) {
-               return validate(preBuildingBlockValidators, bbName, execution);
-       }
-       
-       
-       public boolean postValidate(String bbName, BuildingBlockExecution execution) {
-               return validate(postBuildingBlockValidators, bbName, execution);
-       }
-       
-       
-       protected boolean validate(List<? extends BuildingBlockValidator> validators, String bbName, BuildingBlockExecution execution) {
-               List<Pair<String, Boolean>> results = runValidations(validators, bbName, execution);
-               
-               if (!results.isEmpty()) {
-                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
-                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
-               }
-               
-               return true;
-               
-       }
-       protected List<Pair<String, Boolean>> runValidations(List<? extends BuildingBlockValidator> validators, String bbName, BuildingBlockExecution execution) {
-               
-               List<BuildingBlockValidator> filtered = filterValidators(validators, bbName);
-               
-               List<Pair<String,Boolean>> results = new ArrayList<>();
-               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
-               
-               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
-       }
-       
-       protected List<BuildingBlockValidator> filterValidators(List<? extends BuildingBlockValidator> validators, String bbName) {
-               return validators.stream()
-                               .filter(item -> {
-                                       return item.forBuildingBlock().contains(bbName);
-                               })
-                               .sorted(Comparator.comparing(item -> {
-                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
-                                               public int value() {
-                                                       return 1000;
-                                               }
-
-                                               @Override
-                                               public Class<? extends Annotation> annotationType() {
-                                                       return Priority.class;
-                                               }
-                                       });
-                                       return p.value();
-                               })).collect(Collectors.toList());
-       }
-       
-       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
-               List<T> result = new ArrayList<>();
-               try {
-                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
-                               result.add(klass.newInstance());
-                       }
-               } catch (InstantiationException | IllegalAccessException e) {
-                       logger.error("failed to build validator list for " + clazz.getName(), e);
-                       throw new RuntimeException(e);
-               }
-               
-               return result;
-       }
-       
-       protected List<PreBuildingBlockValidator> getPreBuildingBlockValidators() {
-               return this.preBuildingBlockValidators;
+       protected List<PreBuildingBlockValidator> getPreFlowValidators() {
+               return this.preFlowValidators;
        }
        
-       protected List<PostBuildingBlockValidator> getPostBuildingBlockValidators() {
-               return this.postBuildingBlockValidators;
+       protected List<PostBuildingBlockValidator> getPostFlowValidators() {
+               return this.postFlowValidators;
        }
        
 }
 
--- /dev/null
+package org.onap.so.bpmn.common.validation;
+
+import java.util.Set;
+
+import org.onap.so.bpmn.common.BuildingBlockExecution;
+
+public interface FlowValidator {
+
+       /**
+        * Names of items to be validated
+        * @return
+        */
+       public Set<String> forItems();
+       
+       /**
+        * Determines whether or not the workflow should be executed
+        * 
+        * @param execution
+        * @return
+        */
+       public boolean validate(BuildingBlockExecution execution);
+       
+}
 
--- /dev/null
+/*-
+ * ============LICENSE_START=======================================================
+ * ONAP - SO
+ * ================================================================================
+ * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * 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.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.onap.so.bpmn.common.validation;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.Comparator;
+import java.util.List;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+import javax.annotation.Priority;
+
+import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.javatuples.Pair;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
+import org.onap.so.bpmn.common.DelegateExecutionImpl;
+import org.onap.so.client.exception.ExceptionBuilder;
+import org.reflections.Reflections;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.ApplicationContext;
+import org.springframework.stereotype.Component;
+
+
+/**
+ * Controls running all pre and post validation for flows.
+ * 
+ * To define a validation you must make it a spring bean and implement either {@link org.onap.so.bpmn.common.validation.PreFlowValidator} or 
+ * {@link org.onap.so.bpmn.common.validation.PostFlowValidator} your validation will automatically be
+ * run by this class.
+ *
+ */
+@Component
+public abstract class FlowValidatorRunner<S extends FlowValidator, E extends FlowValidator> {
+
+       private static Logger logger = LoggerFactory.getLogger(FlowValidatorRunner.class);
+       @Autowired
+       protected ApplicationContext context;
+       
+       @Autowired
+       protected ExceptionBuilder exceptionBuilder;
+       
+       protected List<S> preFlowValidators;
+       protected List<E> postFlowValidators;
+
+       
+
+       /**
+        * Changed to object because JUEL does not support overloaded methods
+        * 
+        * @param bbName
+        * @param execution
+        * @return
+        */
+       public boolean preValidate(String bbName, Object execution) {
+               return validateHelper(bbName, preFlowValidators, execution);
+       }
+       
+       /**
+        * Changed to object because JUEL does not support overloaded methods
+        * 
+        * @param bbName
+        * @param execution
+        * @return
+        */
+       public boolean postValidate(String bbName, Object execution) {
+               return validateHelper(bbName, postFlowValidators, execution);
+       }
+       
+       protected boolean validateHelper(String bbName, List<? extends FlowValidator> validators, Object obj) {
+               
+               if (obj instanceof DelegateExecution) {
+                       return validate(validators, bbName, new DelegateExecutionImpl((DelegateExecution)obj));
+               } else if (obj instanceof BuildingBlockExecution) {
+                       return validate(validators, bbName, (BuildingBlockExecution)obj);
+               } else {
+                       return false;
+               }
+       }
+       
+       protected boolean validate(List<? extends FlowValidator> validators, String bbName, BuildingBlockExecution execution) {
+               List<Pair<String, Boolean>> results = runValidations(validators, bbName, execution);
+               
+               if (!results.isEmpty()) {
+                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
+                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
+               }
+               
+               return true;
+               
+       }
+       protected List<Pair<String, Boolean>> runValidations(List<? extends FlowValidator> validators, String bbName, BuildingBlockExecution execution) {
+               
+               List<FlowValidator> filtered = filterValidators(validators, bbName);
+               
+               List<Pair<String,Boolean>> results = new ArrayList<>();
+               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
+               
+               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
+       }
+       
+       protected List<FlowValidator> filterValidators(List<? extends FlowValidator> validators, String bbName) {
+               return validators.stream()
+                               .filter(item -> {
+                                       return item.forItems().contains(bbName);
+                               })
+                               .sorted(Comparator.comparing(item -> {
+                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
+                                               public int value() {
+                                                       return 1000;
+                                               }
+
+                                               @Override
+                                               public Class<? extends Annotation> annotationType() {
+                                                       return Priority.class;
+                                               }
+                                       });
+                                       return p.value();
+                               })).collect(Collectors.toList());
+       }
+       
+       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
+               List<T> result = new ArrayList<>();
+               try {
+                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
+                               result.add(klass.newInstance());
+                       }
+               } catch (InstantiationException | IllegalAccessException e) {
+                       logger.error("failed to build validator list for " + clazz.getName(), e);
+                       throw new RuntimeException(e);
+               }
+               
+               return result;
+       }
+       
+       protected abstract List<S> getPreFlowValidators();
+       
+       protected abstract List<E> getPostFlowValidators();
+       
+}
 
 package org.onap.so.bpmn.common.validation;
 
 
-public interface PostBuildingBlockValidator extends BuildingBlockValidator {
+public interface PostBuildingBlockValidator extends FlowValidator {
 
 }
 
 
 package org.onap.so.bpmn.common.validation;
 
-public interface PostWorkflowValidator extends WorkflowValidator {
+public interface PostWorkflowValidator extends FlowValidator {
 
 }
 
 
 package org.onap.so.bpmn.common.validation;
 
-public interface PreBuildingBlockValidator extends BuildingBlockValidator {
+public interface PreBuildingBlockValidator extends FlowValidator {
 
 }
 
 
 package org.onap.so.bpmn.common.validation;
 
-public interface PreWorkflowValidator extends WorkflowValidator {
+public interface PreWorkflowValidator extends FlowValidator {
 
 }
 
+++ /dev/null
-/*-
- * ============LICENSE_START=======================================================
- * ONAP - SO
- * ================================================================================
- * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * 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.
- * ============LICENSE_END=========================================================
- */
-
-package org.onap.so.bpmn.common.validation;
-
-import java.util.Set;
-
-import org.camunda.bpm.engine.delegate.DelegateExecution;
-
-public interface WorkflowValidator {
-
-       
-       /**
-        * Name of the workflow action to be validated
-        * @return
-        */
-       public Set<String> forWorkflowAction();
-       
-       /**
-        * Determines whether or not the workflow should be executed
-        * 
-        * @param execution
-        * @return
-        */
-       public boolean validate(DelegateExecution execution);
-       
-}
 
  *
  */
 @Component
-public class WorkflowValidatorRunner {
+public class WorkflowValidatorRunner extends FlowValidatorRunner<PreWorkflowValidator, PostWorkflowValidator> {
 
-       private static Logger logger = LoggerFactory.getLogger(WorkflowValidatorRunner.class);
-       @Autowired
-       private ApplicationContext context;
-       
-       @Autowired
-       private ExceptionBuilder exceptionBuilder;
-       
-       private List<PreWorkflowValidator> preWorkflowValidators;
-       private List<PostWorkflowValidator> postWorkflowValidators;
-
-       
        @PostConstruct
        protected void init() {
                
-               preWorkflowValidators = new ArrayList<>(
+               preFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PreWorkflowValidator.class)).orElse(new HashMap<>()).values());
-               postWorkflowValidators = new ArrayList<>(
+               postFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PostWorkflowValidator.class)).orElse(new HashMap<>()).values());
        }
-       
-       public boolean preValidate(String workflow, DelegateExecution execution) {
-               return validate(preWorkflowValidators, workflow, execution);
-       }
-       
-       
-       public boolean postValidate(String workflow, DelegateExecution execution) {
-               return validate(postWorkflowValidators, workflow, execution);
-       }
-       
-       
-       protected boolean validate(List<? extends WorkflowValidator> validators, String workflow, DelegateExecution execution) {
-               List<Pair<String, Boolean>> results = runValidations(validators, workflow, execution);
-               
-               if (!results.isEmpty()) {
-                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
-                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
-               }
-               
-               return true;
-               
-       }
-       protected List<Pair<String, Boolean>> runValidations(List<? extends WorkflowValidator> validators, String workflow, DelegateExecution execution) {
-               
-               List<WorkflowValidator> filtered = filterValidators(validators, workflow);
-               
-               List<Pair<String,Boolean>> results = new ArrayList<>();
-               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
-               
-               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
-       }
-       
-       protected List<WorkflowValidator> filterValidators(List<? extends WorkflowValidator> validators, String workflow) {
-               return validators.stream()
-                               .filter(item -> {
-                                       return item.forWorkflowAction().contains(workflow);
-                               })
-                               .sorted(Comparator.comparing(item -> {
-                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
-                                               public int value() {
-                                                       return 1000;
-                                               }
 
-                                               @Override
-                                               public Class<? extends Annotation> annotationType() {
-                                                       return Priority.class;
-                                               }
-                                       });
-                                       return p.value();
-                               })).collect(Collectors.toList());
-       }
-       
-       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
-               List<T> result = new ArrayList<>();
-               try {
-                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
-                               result.add(klass.newInstance());
-                       }
-               } catch (InstantiationException | IllegalAccessException e) {
-                       logger.error("failed to build validator list for " + clazz.getName(), e);
-                       throw new RuntimeException(e);
-               }
-               
-               return result;
-       }
-       
-       protected List<PreWorkflowValidator> getPreWorkflowValidators() {
-               return this.preWorkflowValidators;
+       protected List<PreWorkflowValidator> getPreFlowValidators() {
+               return this.preFlowValidators;
        }
        
-       protected List<PostWorkflowValidator> getPostWorkflowValidators() {
-               return this.postWorkflowValidators;
+       protected List<PostWorkflowValidator> getPostFlowValidators() {
+               return this.postFlowValidators;
        }
        
 }
 
                MyPreValidatorOne one = new MyPreValidatorOne();
                MyPreValidatorTwo two = new MyPreValidatorTwo();
                MyPreValidatorThree three = new MyPreValidatorThree();
-               List<BuildingBlockValidator> validators = Arrays.asList(one, two, three);
+               List<FlowValidator> validators = Arrays.asList(one, two, three);
 
-               List<BuildingBlockValidator> result = runner.filterValidators(validators, "test");
+               List<FlowValidator> result = runner.filterValidators(validators, "test");
 
-               List<BuildingBlockValidator> expected = Arrays.asList(two, one);
+               List<FlowValidator> expected = Arrays.asList(two, one);
                
                assertEquals(expected, result);
        }
                        runner.preValidate("test", execution);
                        fail("exception not thrown");
                } catch (BpmnError e) {
-                       WorkflowException workflowException = execution.getVariable("WorkflowException");
+                       WorkflowException workflowException = (WorkflowException)execution.getVariable("WorkflowException");
                        assertEquals("Failed Validations:\norg.onap.so.bpmn.common.validation.MyPreValidatorTwo\norg.onap.so.bpmn.common.validation.MyPreValidatorOne", workflowException.getErrorMessage());
                }
                runner.preValidate("test2", mock(BuildingBlockExecution.class));
 
 public class MyPreValidatorFour implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test2");
        }
 
 
 public class MyPreValidatorOne implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                
                return Collections.singleton("test");
        }
 
 public class MyPreValidatorThree implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test2");
        }
 
 
 public class MyPreValidatorTwo implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test");
        }
 
 
 import java.util.Collections;
 import java.util.Set;
 
-import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
 import org.springframework.stereotype.Component;
 
 @Component
 public class WorkflowPreValidatorOne implements PreWorkflowValidator {
 
        @Override
-       public Set<String> forWorkflowAction() {
+       public Set<String> forItems() {
                
                return Collections.singleton("test");
        }
 
        @Override
-       public boolean validate(DelegateExecution exeuction) {
+       public boolean validate(BuildingBlockExecution exeuction) {
                return false;
        }
 
 
 
 import javax.annotation.Priority;
 
-import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
 import org.springframework.stereotype.Component;
 
 @Priority(1)
 public class WorkflowPreValidatorTwo implements PreWorkflowValidator {
 
        @Override
-       public Set<String> forWorkflowAction() {
+       public Set<String> forItems() {
                return Collections.singleton("test");
        }
 
        @Override
-       public boolean validate(DelegateExecution execution) {
+       public boolean validate(BuildingBlockExecution execution) {
                return false;
        }
 
 
 import org.junit.rules.ExpectedException;
 import org.junit.runner.RunWith;
 import org.onap.so.bpmn.common.BuildingBlockExecution;
-import org.onap.so.bpmn.common.DelegateExecutionImpl;
 import org.onap.so.bpmn.core.WorkflowException;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.test.context.ContextConfiguration;
                
                WorkflowPreValidatorOne one = new WorkflowPreValidatorOne();
                WorkflowPreValidatorTwo two = new WorkflowPreValidatorTwo();            
-               List<WorkflowValidator> validators = Arrays.asList(one, two);
+               List<FlowValidator> validators = Arrays.asList(one, two);
 
-               List<WorkflowValidator> result = runner.filterValidators(validators, "test");
+               List<FlowValidator> result = runner.filterValidators(validators, "test");
 
-               List<WorkflowValidator> expected = Arrays.asList(two, one);
+               List<FlowValidator> expected = Arrays.asList(two, one);
                
                assertEquals(expected, result);
        }