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

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