/*
***************************************************************************************
* 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.core.context.mgr;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.client.EventPropertyGetter;
import com.espertech.esper.collection.MultiKeyUntyped;
import com.espertech.esper.core.context.util.AgentInstanceContext;
import com.espertech.esper.core.service.EPServicesContext;
import com.espertech.esper.core.service.EPStatementHandleCallback;
import com.espertech.esper.epl.spec.ContextDetailPartitionItem;
import com.espertech.esper.filter.*;
import java.util.Collection;
public class ContextControllerPartitionedFilterCallback implements FilterHandleCallback {
private final AgentInstanceContext agentInstanceContextCreateContext;
private final EventPropertyGetter[] getters;
private final ContextControllerPartitionedInstanceCreateCallback callback;
private final EPStatementHandleCallback filterHandle;
private final FilterServiceEntry filterServiceEntry;
public ContextControllerPartitionedFilterCallback(EPServicesContext servicesContext, AgentInstanceContext agentInstanceContextCreateContext, ContextDetailPartitionItem partitionItem, ContextControllerPartitionedInstanceCreateCallback callback, ContextInternalFilterAddendum filterAddendum) {
this.agentInstanceContextCreateContext = agentInstanceContextCreateContext;
this.callback = callback;
filterHandle = new EPStatementHandleCallback(agentInstanceContextCreateContext.getEpStatementAgentInstanceHandle(), this);
getters = new EventPropertyGetter[partitionItem.getPropertyNames().size()];
for (int i = 0; i < partitionItem.getPropertyNames().size(); i++) {
String propertyName = partitionItem.getPropertyNames().get(i);
EventPropertyGetter getter = partitionItem.getFilterSpecCompiled().getFilterForEventType().getGetter(propertyName);
getters[i] = getter;
}
FilterValueSetParam[][] addendum = filterAddendum != null ? filterAddendum.getFilterAddendum(partitionItem.getFilterSpecCompiled()) : null;
FilterValueSet filterValueSet = partitionItem.getFilterSpecCompiled().getValueSet(null, null, addendum);
filterServiceEntry = servicesContext.getFilterService().add(filterValueSet, filterHandle);
long filtersVersion = servicesContext.getFilterService().getFiltersVersion();
agentInstanceContextCreateContext.getEpStatementAgentInstanceHandle().getStatementFilterVersion().setStmtFilterVersion(filtersVersion);
}
public void matchFound(EventBean theEvent, Collection<FilterHandleCallback> allStmtMatches) {
Object key;
if (getters.length > 1) {
Object[] keys = new Object[getters.length];
for (int i = 0; i < keys.length; i++) {
keys[i] = getters[i].get(theEvent);
}
key = new MultiKeyUntyped(keys);
} else {
key = getters[0].get(theEvent);
}
callback.create(key, theEvent);
}
public boolean isSubSelect() {
return false;
}
public int getStatementId() {
return agentInstanceContextCreateContext.getStatementContext().getStatementId();
}
public void destroy(FilterService filterService) {
filterService.remove(filterHandle, filterServiceEntry);
long filtersVersion = agentInstanceContextCreateContext.getStatementContext().getFilterService().getFiltersVersion();
agentInstanceContextCreateContext.getEpStatementAgentInstanceHandle().getStatementFilterVersion().setStmtFilterVersion(filtersVersion);
}
public EPStatementHandleCallback getFilterHandle() {
return filterHandle;
}
}