/*
* Copyright 2015 Red Hat, Inc. and/or its affiliates.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.drools.persistence.infinispan.processinstance;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import org.drools.core.WorkItemHandlerNotFoundException;
import org.drools.core.common.InternalKnowledgeRuntime;
import org.drools.core.impl.InternalKnowledgeBase;
import org.drools.core.process.instance.WorkItem;
import org.drools.core.process.instance.WorkItemManager;
import org.drools.core.process.instance.impl.WorkItemImpl;
import org.drools.persistence.api.PersistenceContext;
import org.drools.persistence.api.PersistenceContextManager;
import org.drools.persistence.api.PersistentWorkItem;
import org.drools.persistence.info.WorkItemInfo;
import org.drools.persistence.jpa.processinstance.JPAWorkItemManager;
import org.kie.api.runtime.Environment;
import org.kie.api.runtime.EnvironmentName;
import org.kie.api.runtime.process.ProcessInstance;
import org.kie.api.runtime.process.WorkItemHandler;
public class InfinispanWorkItemManager extends JPAWorkItemManager implements WorkItemManager {
private InternalKnowledgeRuntime kruntime;
private Map<String, WorkItemHandler> workItemHandlers = new HashMap<String, WorkItemHandler>();
public InfinispanWorkItemManager(InternalKnowledgeRuntime kruntime) {
super(kruntime);
this.kruntime = kruntime;
}
@Override
public void internalExecuteWorkItem(WorkItem workItem) {
Environment env = this.kruntime.getEnvironment();
// EntityManager em = (EntityManager) env.get(EnvironmentName.CMD_SCOPED_ENTITY_MANAGER);
WorkItemInfo workItemInfo = new WorkItemInfo(workItem, env);
// em.persist(workItemInfo);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
context.persist( workItemInfo );
((WorkItemImpl) workItem).setId(workItemInfo.getId());
workItemInfo.transform();
context.merge(workItemInfo);
WorkItemHandler handler = (WorkItemHandler) this.workItemHandlers.get(workItem.getName());
if (handler != null) {
handler.executeWorkItem(workItem, this);
workItemInfo.transform();
context.merge(workItemInfo);
} else {
throwWorkItemNotFoundException( workItem );
}
}
private void throwWorkItemNotFoundException(WorkItem workItem) {
throw new WorkItemHandlerNotFoundException( "Could not find work item handler for " + workItem.getName(),
workItem.getName() );
}
@Override
public WorkItemHandler getWorkItemHandler(String name) {
return this.workItemHandlers.get(name);
}
@Override
public void retryWorkItem(long workItemId) {
WorkItem workItem = getWorkItem(workItemId);
if (workItem != null) {
WorkItemHandler handler = (WorkItemHandler) this.workItemHandlers.get(workItem.getName());
if (handler != null) {
handler.executeWorkItem(workItem, this);
} else {
throwWorkItemNotFoundException( workItem );
}
}
}
@Override
public void retryWorkItemWithParams(long workItemId,Map<String,Object> map) {
Environment env = this.kruntime.getEnvironment();
WorkItem workItem = getWorkItem(workItemId);
if (workItem != null) {
workItem.setParameters( map );
WorkItemInfo workItemInfo = new WorkItemInfo(workItem, env);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
context.merge( workItemInfo );
retryWorkItem(workItemInfo.getId());
}
}
@Override
public void internalAbortWorkItem(long id) {
Environment env = this.kruntime.getEnvironment();
//EntityManager em = (EntityManager) env.get(EnvironmentName.CMD_SCOPED_ENTITY_MANAGER);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
PersistentWorkItem workItemInfo = context.findWorkItem( id );
// work item may have been aborted
if (workItemInfo != null) {
WorkItemImpl workItem = (WorkItemImpl) internalGetWorkItem(workItemInfo);
WorkItemHandler handler = (WorkItemHandler) this.workItemHandlers.get(workItem.getName());
if (handler != null) {
handler.abortWorkItem(workItem, this);
} else {
throwWorkItemNotFoundException( workItem );
}
context.remove(workItemInfo);
}
}
@Override
public void internalAddWorkItem(WorkItem workItem) {
}
@Override
public void completeWorkItem(long id, Map<String, Object> results) {
Environment env = this.kruntime.getEnvironment();
// EntityManager em = (EntityManager) env.get(EnvironmentName.CMD_SCOPED_ENTITY_MANAGER);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
PersistentWorkItem workItemInfo = context.findWorkItem( id );
// work item may have been aborted
if (workItemInfo != null) {
WorkItem workItem = internalGetWorkItem(workItemInfo);
workItem.setResults(results);
ProcessInstance processInstance = kruntime.getProcessInstance(workItem.getProcessInstanceId());
workItem.setState(WorkItem.COMPLETED);
// process instance may have finished already
if (processInstance != null) {
processInstance.signalEvent("workItemCompleted", workItem);
}
context.remove(workItemInfo);
}
}
@Override
public void abortWorkItem(long id) {
Environment env = this.kruntime.getEnvironment();
// EntityManager em = (EntityManager) env.get(EnvironmentName.CMD_SCOPED_ENTITY_MANAGER);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
PersistentWorkItem workItemInfo = context.findWorkItem( id );
// work item may have been aborted
if (workItemInfo != null) {
WorkItem workItem = (WorkItemImpl) internalGetWorkItem(workItemInfo);
ProcessInstance processInstance = kruntime.getProcessInstance(workItem.getProcessInstanceId());
workItem.setState(WorkItem.ABORTED);
// process instance may have finished already
if (processInstance != null) {
processInstance.signalEvent("workItemAborted", workItem);
}
context.remove(workItemInfo);
}
}
@Override
public WorkItem getWorkItem(long id) {
Environment env = this.kruntime.getEnvironment();
// EntityManager em = (EntityManager) env.get(EnvironmentName.CMD_SCOPED_ENTITY_MANAGER);
PersistenceContext context = ((PersistenceContextManager) env.get( EnvironmentName.PERSISTENCE_CONTEXT_MANAGER )).getCommandScopedPersistenceContext();
PersistentWorkItem workItemInfo = null;
if (context != null) {
workItemInfo = context.findWorkItem( id );
}
if (workItemInfo == null) {
return null;
}
return internalGetWorkItem(workItemInfo);
}
private WorkItem internalGetWorkItem(PersistentWorkItem workItemInfo) {
Environment env = kruntime.getEnvironment();
InternalKnowledgeBase ruleBase = (InternalKnowledgeBase) kruntime.getKieBase();
WorkItem workItem = ((WorkItemInfo) workItemInfo).getWorkItem(env, ruleBase);
((WorkItemImpl) workItem).setId(workItemInfo.getId());
return workItem;
}
@Override
public Set<WorkItem> getWorkItems() {
return new HashSet<WorkItem>();
}
@Override
public void registerWorkItemHandler(String workItemName, WorkItemHandler handler) {
super.registerWorkItemHandler(workItemName, handler);
this.workItemHandlers.put(workItemName, handler);
}
@Override
public void clearWorkItems() {
}
@Override
public void clear() {
clearWorkItems();
}
}