Expression: allow single value for contains/matches

pull/215/head
M66B 9 months ago
parent eae8e33fad
commit f547423b8b

@ -654,14 +654,19 @@ public class EntityRule {
Expression expression, Token functionToken, EvaluationValue... parameterValues) { Expression expression, Token functionToken, EvaluationValue... parameterValues) {
List<String> result = new ArrayList<>(); List<String> result = new ArrayList<>();
try {
if (parameterValues.length == 1) {
String name = parameterValues[0].getStringValue(); String name = parameterValues[0].getStringValue();
if (name != null && headers != null) { if (name != null && headers != null)
for (Header header : headers) for (Header header : headers)
if (name.equalsIgnoreCase(header.getName())) if (name.equalsIgnoreCase(header.getName()))
result.add(header.getValue()); result.add(header.getValue());
Log.i("EXPR " + name + "=" + TextUtils.join(", ", result)); }
} catch (Throwable ex) {
Log.e("EXPR", ex);
} }
Log.i("EXPR header(" + parameterValues[0] + ")=" + TextUtils.join(", ", result));
return new EvaluationValue(result, ExpressionConfiguration.defaultConfiguration()); return new EvaluationValue(result, ExpressionConfiguration.defaultConfiguration());
} }
} }
@ -678,21 +683,23 @@ public class EntityRule {
public EvaluationValue evaluate( public EvaluationValue evaluate(
Expression expression, Token functionToken, EvaluationValue... parameterValues) { Expression expression, Token functionToken, EvaluationValue... parameterValues) {
List<Object> result = new ArrayList<>(); List<Object> result = new ArrayList<>();
String name = parameterValues[0].getStringValue();
if (name != null && message != null)
try { try {
if (parameterValues.length == 1) {
String name = parameterValues[0].getStringValue();
if (name != null && message != null) {
Field field = message.getClass().getField(name); Field field = message.getClass().getField(name);
if (field != null) {
field.setAccessible(true); field.setAccessible(true);
Object value = field.get(message); Object value = field.get(message);
Log.i("EXPR message " + name + "=" + value);
if (value != null) if (value != null)
result.add(value); result.add(value);
} }
}
} catch (Throwable ex) { } catch (Throwable ex) {
Log.e(ex); Log.e("EXPR", ex);
} }
Log.i("EXPR message(" + parameterValues[0] + ")=" + TextUtils.join(", ", result));
return new EvaluationValue(result, ExpressionConfiguration.defaultConfiguration()); return new EvaluationValue(result, ExpressionConfiguration.defaultConfiguration());
} }
} }
@ -708,27 +715,38 @@ public class EntityRule {
@Override @Override
public EvaluationValue evaluate( public EvaluationValue evaluate(
Expression expression, Token operatorToken, EvaluationValue... operands) { Expression expression, Token operatorToken, EvaluationValue... operands) {
Log.i("EXPR " + operands[0] + (regex ? " MATCHES " : " CONTAINS ") + operands[1] + " regex=" + regex); boolean result = false;
try {
if (operands.length == 2) {
List<EvaluationValue> array;
if (operands[1].getDataType() == EvaluationValue.DataType.ARRAY)
array = operands[0].getArrayValue();
else
array = Arrays.asList(operands[0]);
String condition = operands[1].getStringValue(); String condition = operands[1].getStringValue();
List<EvaluationValue> array = operands[0].getArrayValue();
if (TextUtils.isEmpty(condition) || array == null || array.isEmpty())
return expression.convertValue(false);
Pattern p = (regex ? Pattern.compile(condition, Pattern.DOTALL) : null); if (array != null && !array.isEmpty() && !TextUtils.isEmpty(condition))
for (EvaluationValue item : array) { for (EvaluationValue item : array) {
String value = item.getStringValue(); String value = item.getStringValue();
if (!TextUtils.isEmpty(value)) if (!TextUtils.isEmpty(value))
if (p == null) { if (regex
if (value.toLowerCase().contains(condition.toLowerCase())) ? Pattern.compile(condition, Pattern.DOTALL).matcher(value).matches()
return expression.convertValue(true); : value.toLowerCase().contains(condition.toLowerCase())) {
} else { result = true;
if (p.matcher(value).matches()) break;
return expression.convertValue(true);
} }
} }
}
} catch (Throwable ex) {
Log.e("EXPR", ex);
}
Log.i("EXPR " + operands[0] + (regex ? " MATCHES " : " CONTAINS ") + operands[1] +
" regex=" + regex + " result=" + result);
return expression.convertValue(false); return expression.convertValue(result);
} }
} }
@ -806,7 +824,7 @@ public class EntityRule {
} }
} }
} catch (Throwable ex) { } catch (Throwable ex) {
Log.e(ex); Log.e("EXPR", ex);
} }
return false; return false;
} }
@ -817,7 +835,7 @@ public class EntityRule {
if ("text".equalsIgnoreCase(variable)) if ("text".equalsIgnoreCase(variable))
return true; return true;
} catch (Throwable ex) { } catch (Throwable ex) {
Log.e(ex); Log.e("EXPR", ex);
} }
return false; return false;
} }

Loading…
Cancel
Save