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

ee.telekom.workflow.api.DslBlock Maven / Gradle / Ivy

package ee.telekom.workflow.api;

/**
 * DSL for workflow definitions.
 *
 * @author Erko Hansar
 * @author Christian Klock
 *
 * @see WorkflowDefinition
 */
public interface DslBlock extends DslExpression{

    /**
     * Set an environment variable with the given name. The value comes from the next immediate node (value, call, callAsync, humanTask, waitSignal).
     * 
     * @param name name of the environment variable which is going to be set
     */
    DslVariable variable( String name );

    /**
     * Set environment variable with the given names. The value comes from the next immediate node (value, call, callAsync, humanTask, waitSignal). Used
     * when the value returning node return a Map result and we want to store one or more key-value pairs from this Map directly 
     * into the environment (instead of storing the whole Map under a new variable name and then accessing the key-value pairs as subfields 
     * inside this Map value).
     * 

* If the returned Map contains 3 keys: x, y and z, then the call .variables( "a=x", "b=y" ) should be read as: take * x from method call result map and store it into environment as a, and take y from method call result map and * store it into environment as b, and ignore z. * * @param nameMappings desired mappings of the environment variable: new_environment_variable_name=returned_map_key_name */ DslVariable variables( String... nameMappings ); /** * Creates a new workflow instance based. * * @param id node id * @param workflowName the workflow's name to be created ("STRING_WORKFLOW_NAME" or "${EL_EXPRESSION}") * @param workflowVersion the workflow's version to be created or null for the latest * @param label1 first label ("STRING_LABEL" or "${EL_EXPRESSION}") * @param label2 second label ("STRING_LABEL" or "${EL_EXPRESSION}") */ DslAttribute createInstance( int id, String workflowName, Integer workflowVersion, String label1, String label2 ); /** * Wait until a defined time period has passed. *

* ### WAIT STATE ### * * @param id node id * @param due either a constant Long value of milliseconds or an EL expression which returns the milliseconds ("LONG_VALUE" or "${EL_EXPRESSION}") */ Level waitTimer( int id, String due ); /** * Wait until a defined date has been reached *

* ### WAIT STATE ### * * @param id node id * @param due an EL expression which returns the date ("${EL_EXPRESSION}") */ Level waitUntilDate( int id, String due ); /** * While the given condition is true, execute the block content and then check again. *

* Block start tag. * * @param id node id * @param condition expression language condition ("EL_EXPRESSION") */ DslWhileDoBlock whileDo( int id, String condition ); /** * Start tag for a do-while block. Execution continues into the block content. */ DslDoWhileBlock doWhile(); /** * Start tag for if-elseIf-else-endIf block. If the given condition evaluates to true, then executes the branch content and ignores the other elseIf * and else branches, otherwise evaluates the following elseIf or else condition. *

* The if-elseIf-else-endIf block executes only one of it's branches. * * @param id node id * @param condition expression language condition ("EL_EXPRESSION") */ DslIfBlock if_( int id, String condition ); /** * Start tag for splitting the execution into multiple parallel branches. * * @param id node id */ DslSplit split( int id ); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy