com.espertech.esper.runtime.internal.kernel.service.EPRuntimeStatementSelectionSPI Maven / Gradle / Ivy
The newest version!
/*
***************************************************************************************
* Copyright (C) 2006 EsperTech, Inc. All rights reserved. *
* http://www.espertech.com/esper *
* http://www.espertech.com *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the GPL license *
* a copy of which has been included with this distribution in the license.txt file. *
***************************************************************************************
*/
package com.espertech.esper.runtime.internal.kernel.service;
import com.espertech.esper.common.client.EPException;
import com.espertech.esper.common.client.EventBean;
import com.espertech.esper.common.client.EventType;
import com.espertech.esper.common.client.annotation.*;
import com.espertech.esper.common.client.type.EPType;
import com.espertech.esper.common.client.type.EPTypeClass;
import com.espertech.esper.common.client.util.StatementProperty;
import com.espertech.esper.common.internal.epl.expression.core.ExprEvaluator;
import com.espertech.esper.common.internal.epl.expression.core.ExprNode;
import com.espertech.esper.common.internal.epl.expression.core.ExprNodeUtilityPrint;
import com.espertech.esper.common.internal.event.bean.core.BeanEventBean;
import com.espertech.esper.common.internal.event.bean.core.BeanEventType;
import com.espertech.esper.runtime.client.EPDeployment;
import com.espertech.esper.runtime.client.EPStatement;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.lang.annotation.Annotation;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import java.util.function.BiConsumer;
import static com.espertech.esper.common.internal.util.JavaClassHelper.isTypeBoolean;
public class EPRuntimeStatementSelectionSPI {
private static final Logger log = LoggerFactory.getLogger(EPRuntimeStatementSelectionSPI.class);
// Predefined properties available:
// - name (string)
// - description (string)
// - epl (string)
// - each tag individually (string)
// - priority
// - drop (boolean)
// - hint (string)
private final EPRuntimeSPI runtimeSPI;
private final BeanEventType statementRowType;
public EPRuntimeStatementSelectionSPI(EPRuntimeSPI runtimeSPI) {
this.runtimeSPI = runtimeSPI;
statementRowType = new EPRuntimeBeanAnonymousTypeService().makeBeanEventTypeAnonymous(StatementRow.EPTYPE);
}
public ExprNode compileFilterExpression(String filterExpression) {
try {
return runtimeSPI.getReflectiveCompileSvc().reflectiveCompileExpression(filterExpression, new EventType[]{statementRowType}, new String[]{statementRowType.getName()});
} catch (Throwable t) {
throw new EPException("Failed to compiler filter: " + t.getMessage(), t);
}
}
public void traverseStatementsContains(BiConsumer consumer, String containsIgnoreCase) {
runtimeSPI.traverseStatements((deployment, stmt) -> {
boolean match = false;
String searchString = containsIgnoreCase.toLowerCase(Locale.ENGLISH);
if (stmt.getName().toLowerCase(Locale.ENGLISH).contains(searchString)) {
match = true;
}
if (!match) {
String epl = (String) stmt.getProperty(StatementProperty.EPL);
if ((epl != null) && (epl.toLowerCase(Locale.ENGLISH).contains(searchString))) {
match = true;
}
}
if (!match) {
return;
}
consumer.accept(deployment, stmt);
});
}
public void traverseStatementsFilterExpr(BiConsumer consumer, ExprNode filterExpr) throws EPException {
runtimeSPI.traverseStatements((deployment, stmt) -> {
if (evaluateStatement(filterExpr, stmt)) {
consumer.accept(deployment, stmt);
}
});
}
private static StatementRow getRow(EPStatement statement) {
String description = null;
String hint = null;
String hintDelimiter = "";
int priority = 0;
Map tags = null;
boolean drop = false;
Annotation[] annotations = statement.getAnnotations();
for (Annotation anno : annotations) {
if (anno instanceof Hint) {
if (hint == null) {
hint = "";
}
hint += hintDelimiter + ((Hint) anno).value();
hintDelimiter = ",";
} else if (anno instanceof Tag) {
Tag tag = (Tag) anno;
if (tags == null) {
tags = new HashMap();
}
tags.put(tag.name(), tag.value());
} else if (anno instanceof Priority) {
Priority tag = (Priority) anno;
priority = tag.value();
} else if (anno instanceof Drop) {
drop = true;
} else if (anno instanceof Description) {
description = ((Description) anno).value();
}
}
return new StatementRow(
statement.getDeploymentId(),
statement.getName(),
(String) statement.getProperty(StatementProperty.EPL),
statement.getUserObjectCompileTime(),
statement.getUserObjectRuntime(),
description,
hint,
priority,
drop,
tags
);
}
public boolean evaluateStatement(ExprNode expression, EPStatement stmt) {
if (expression == null) {
return true;
}
EPType returnType = expression.getForge().getEvaluationType();
if (!isTypeBoolean(returnType)) {
throw new EPException("Invalid expression, expected a boolean return type for expression and received '" +
returnType.getTypeName() +
"' for expression '" + ExprNodeUtilityPrint.toExpressionStringMinPrecedenceSafe(expression) + "'");
}
ExprEvaluator evaluator = expression.getForge().getExprEvaluator();
try {
StatementRow row = getRow(stmt);
EventBean rowBean = new BeanEventBean(row, statementRowType);
Boolean pass = (Boolean) evaluator.evaluate(new EventBean[]{rowBean}, true, null);
return !((pass == null) || (!pass));
} catch (Exception ex) {
log.error("Unexpected exception filtering statements by expression, skipping statement: " + ex.getMessage(), ex);
}
return false;
}
public static class StatementRow {
public final static EPTypeClass EPTYPE = new EPTypeClass(StatementRow.class);
private String deploymentId;
private String name;
private String epl;
private Object userObjectCompileTime;
private Object userObjectRuntimeTime;
private String description;
private String hint;
private int priority;
private Boolean drop;
private Map tag;
public StatementRow(String deploymentId, String name, String epl, Object userObjectCompileTime, Object userObjectRuntimeTime, String description, String hint, int priority, Boolean drop, Map tag) {
this.deploymentId = deploymentId;
this.name = name;
this.epl = epl;
this.userObjectCompileTime = userObjectCompileTime;
this.userObjectRuntimeTime = userObjectRuntimeTime;
this.description = description;
this.hint = hint;
this.priority = priority;
this.drop = drop;
this.tag = tag;
}
public String getDeploymentId() {
return deploymentId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEpl() {
return epl;
}
public void setEpl(String epl) {
this.epl = epl;
}
public Object getUserObjectCompileTime() {
return userObjectCompileTime;
}
public void setUserObjectCompileTime(Object userObjectCompileTime) {
this.userObjectCompileTime = userObjectCompileTime;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getHint() {
return hint;
}
public void setHint(String hint) {
this.hint = hint;
}
public int getPriority() {
return priority;
}
public void setPriority(int priority) {
this.priority = priority;
}
public Boolean isDrop() {
return drop;
}
public Boolean getDrop() {
return drop;
}
public void setDrop(Boolean drop) {
this.drop = drop;
}
public Map getTag() {
return tag;
}
public void setTag(Map tag) {
this.tag = tag;
}
public Object getUserObjectRuntimeTime() {
return userObjectRuntimeTime;
}
public void setUserObjectRuntimeTime(Object userObjectRuntimeTime) {
this.userObjectRuntimeTime = userObjectRuntimeTime;
}
public void setDeploymentId(String deploymentId) {
this.deploymentId = deploymentId;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy