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

com.github.egatlovs.variablemanager.managers.ExecutionVariableManager Maven / Gradle / Ivy

package com.github.egatlovs.variablemanager.managers;

import org.camunda.bpm.engine.delegate.DelegateExecution;

public interface ExecutionVariableManager {

    /**
     * Sets a Variable to the Execution. 
*
* Note: the variable will be processed as follows: *
    *
  1. The object will be validated using bean validation.
  2. *
  3. The given object will be processed using * {@code ProcessingUnit.class}
  4. *
* If you want more Information of how variables are processed watch out for * {@code ProcessingUnit.class}.
* If you want to manipulate how your variables are processed look for * {@code @ObjectValue}, {@code @FileValue}, {@code @FieldName} and {@code @Ignore}.
*
* * @param value - The value to be set to the Execution */ void setVariable(Object value); /** * Sets a Variable Locally to the Execution.
*
* Note: the variable will be processed as follows: *
    *
  1. The object will be validated using bean validation.
  2. *
  3. The given object will be processed using * {@code ProcessingUnit.class}
  4. *
* If you want more Information of how variables are processed watch out for * {@code ProcessingUnit.class}.
* If you want to manipulate how your variables are processed look for * {@code @ObjectValue}, {@code @FileValue}, {@code @FieldName} and {@code @Ignore}.
*
* * @param value - The value to be set to the Execution */ void setVariableLocal(Object value); /** * Retrieves a Variable from the Execution.
*
* The variables will be read from the given class using * {@code FieldNames.class}. After that each variable will be called out of the * execution.
* Now that each variable is retrieved from the execution, the * {@code ResultObject.class} will be used to build the requested object which * is then returned.
* * @param clazz - The Class which should be gathered * @return - The Object of the requested class */ T getVariable(Class clazz); /** * Retrieves a Variable locally from the Execution.
*
* The variables will be read from the given class using * {@code FieldNames.class}. After that each variable will be called out of the * execution.
* Now that each variable is retrieved from the execution, the * {@code ResultObject.class} will be used to build the requested object which * is then returned.
* * @param clazz - The Class which should be gathered * @return - The Object of the requested class */ T getVariableLocal(Class clazz); /** * Removes a Variable from the Execution.
*
* The variables will be read from the given class using * {@code FieldNames.class}. After that each variable will be removed from the * execution.
* * @param clazz - The Class which should be used to retrieve the fieldnames to be * deleted */ void removeVariables(Class clazz); /** * Removes Variables locally from the Execution.
*
* The variables will be read from the given class using * {@code FieldNames.class}. After that each variable will be removed from the * execution.
* * @param clazz - The Class which should be used to retrieve the fieldnames to be * deleted */ void removeVariablesLocal(Class clazz); /** * Gives access to the wrapped execution. * * @return Returns the wrapped execution */ DelegateExecution getExecutionService(); /** * Manipulate the execution used. * * @param execution - The new execution to be used */ void setExecutionService(DelegateExecution execution); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy