条件表达式扩展
大约 2 分钟
条件表达式扩展
重要
当内置的条件、办理人变量和监听器表达式不满足业务需求时,可进行扩展
1、表达式公共接口
重要
ExpressionStrategy
接口,是表达式策略类接口,抽离公共方法
1、getType()
: 表达式策略类型,也是表达式的前缀
2、isIntercept()
: 执行表达式之前,是否截取表达式前缀,然后在进行执行,默认不截取
3、eval()
: 执行表达式
4、setExpression()
: 设置新增的表达式,方便扩展
/**
* 表达式策略类接口
*
* @author warm
*/
public interface ExpressionStrategy<T> {
/**
* 获取策略类型
*
* @return 类型
*/
String getType();
/**
* 是否截取表达式前缀,然后在进行执行,默认不截取
* 如果截取,比如@@spel@@|#{@user.evalVar()} , 截取@@spel@@|,后再执行#{@user.evalVar()}解析
*
* @return 类型
*/
default Boolean isIntercept() {
return false;
}
/**
* 执行表达式
*
* @param expression 表达式
* @param variable 流程变量
* @return 执行结果
*/
T eval(String expression, Map<String, Object> variable);
/**
* 设置表达式
* @param expressionStrategy 表达式
*/
void setExpression(ExpressionStrategy<T> expressionStrategy);
}
2、注册表达式实现类
- 通过这个方法进行注册ExpressionUtil.setExpression
ExpressionUtil.setExpression(new ExpressionStrategyEq());
3、条件表达式
- 扩展需要实现
ConditionStrategy
接口或者继承ConditionStrategyAbstract
抽象类
3.1、条件表达式接口
/**
* 条件表达式接口
*
* @author warm
*/
public interface ConditionStrategy extends ExpressionStrategy<Boolean> {
/**
* 条件表达式策略实现类map
*/
Map<String, ExpressionStrategy<Boolean>> map = new HashMap<>();
default void setExpression(ExpressionStrategy<Boolean> expressionStrategy) {
map.put(expressionStrategy.getType(), expressionStrategy);
}
static Map<String, ExpressionStrategy<Boolean>> getExpressionMap() {
return map;
}
default Boolean isIntercept() {
return true;
}
}
3.2、条件表达式抽象类
/**
* 条件表达式抽象类,复用部分代码
*
* @author warm
*/
public abstract class ConditionStrategyAbstract implements ConditionStrategy {
/**
* 执行表达式前置方法 合法性校验
*
* @param split 表达式后缀:如flag@@eq@@4
* @param variable 流程变量
*/
public void preEval(String[] split, Map<String, Object> variable) {
AssertUtil.isEmpty(variable, ExceptionCons.NULL_CONDITIONVALUE);
Object o = variable.get(split[0].trim());
AssertUtil.isNull(o, ExceptionCons.NULL_CONDITIONVALUE);
}
/**
* 执行表达式
*
* @param expression 表达式
* @param variable 流程变量
* @return 执行结果
*/
@Override
public Boolean eval(String expression, Map<String, Object> variable) {
String[] split = expression.split(FlowCons.splitAt);
preEval(split, variable);
String variableValue = String.valueOf(variable.get(split[0].trim()));
return afterEval(split, variableValue);
}
/**
* 执行表达式后置方法
*
* @param split 如flag@@eq@@4
* @param value 流程变量值
* @return 执行结果
*/
public abstract Boolean afterEval(String[] split, String value);
}
3.3、条件表达式实现类
/**
* 条件表达式等于 @@eq@@|flag@@eq@@4
*
* @author warm
*/
public class ConditionStrategyEq extends ConditionStrategyAbstract {
@Override
public String getType() {
return FlowCons.splitAt + "eq" + FlowCons.splitAt;
}
@Override
public Boolean afterEval(String[] split, String value) {
if (MathUtil.isNumeric(split[2].trim())) {
return MathUtil.determineSize(value, split[2].trim()) == 0;
} else {
return value.equals(split[2].trim());
}
}
}