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:
*
* - The object will be validated using bean validation.
* - The given object will be processed using
* {@code ProcessingUnit.class}
*
* 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:
*
* - The object will be validated using bean validation.
* - The given object will be processed using
* {@code ProcessingUnit.class}
*
* 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