Custom Predicate Judge
Introduction#
- This paper describes how to customize the extension of
org.apache.shenyu.plugin.base.condition.judge.PredicateJudge. - The conditional predicate is the bridge between data and rules in the selector and serves to filter out requests that match the conditions.
- There are already seven conditional predicates including match, =, regex, contains, TimeBefore, TimeAfter, exclude.
- Please refer to judge module, add your own conditional predicates, or submit
prto the official website if you have a good common plugin.
Extension#
- Create a new project and introduce the following dependencies:
<dependencies> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-plugin-base</artifactId> <version>${project.version}</version> </dependency></dependencies>- Create a new class
CustomPredicateJudge, implementsorg.apache.shenyu.plugin.base.condition.judge.PredicateJudge, add annotationorg.apache.shenyu.spi.Join.
/** * custom predicate judge. */@Joinpublic class CustomPredicateJudge implements PredicateJudge {
@Override public Boolean judge(final ConditionData conditionData, final String realData) { // Custom Predicate Judge }}
- In the project's META-INF/services directory, create
org.apache.shenyu.plugin.base.condition.judge.PredicateJudgefile, add key-value as following:
script
${spi name} = ${custom class path}${spi name} represents the name of spi and ${custom class path} represents the fully qualified name of the class. Such as:
script
custom=xxx.xxx.xxx.CustomPredicateJudgePackage the project and copy it to the
liborext-libdirectory of the gateway (bootstrap-bin).In the
Apache ShenYugateway management system --> BasicConfig --> Dictionary, find the dictionary code asOPERATOR, add a new piece of data, pay attention to the dictionary name:${spi name}.

DictionaryType:
operator;DictionaryCode:
OPERATOR;DictionaryName:
${spi name}, input your custom spi name;DictionaryValue: When used, the value of the drop-down box, do not repeat with the existing;
DictionaryDescribe: desc your custom match strategy;
Sort: to sort;
Status: open or close.
- When adding selectors or rules, you can use custom predicate judge:

Example#
- Add
GroovyPredicateJudgeandSpELPredicateJudgeextension.
/** * Groovy predicate judge. */@Joinpublic class GroovyPredicateJudge implements PredicateJudge { @Override public Boolean judge(final ConditionData conditionData, final String realData) { return (Boolean) Eval.me(conditionData.getParamName(), realData, conditionData.getParamValue()); }}/** * SpEL predicate judge. */@Joinpublic class SpELPredicateJudge implements PredicateJudge { private static final ExpressionParser EXPRESSION_PARSER = new SpelExpressionParser(); @Override public Boolean judge(final ConditionData conditionData, final String realData) { Expression expression = EXPRESSION_PARSER.parseExpression(conditionData.getParamValue().replace('#' + conditionData.getParamName(), realData)); return expression.getValue(Boolean.class); }}- Update
org.apache.shenyu.plugin.base.condition.judge.PredicateJudge:
script
Groovy=xxx.xxx.xxx.GroovyPredicateJudgeSpEL=xxx.xxx.xxx.SpELPredicateJudge