/* * To change this template, choose Tools | Templates * and open the template in the editor. */ package com.wordpress.salaboy.services; import com.wordpress.salaboy.acc.HospitalDistanceCalculator; import com.wordpress.salaboy.model.Procedure; import com.wordpress.salaboy.model.events.EmergencyEndsEvent; import com.wordpress.salaboy.model.events.VehicleHitsHospitalEvent; import com.wordpress.salaboy.model.events.VehicleHitsEmergencyEvent; import com.wordpress.salaboy.services.workitemhandlers.ProcedureReportWorkItemHandler; import com.wordpress.salaboy.workitemhandlers.DispatchVehicleWorkItemHandler; import com.wordpress.salaboy.workitemhandlers.NotifyEndOfProcedureWorkItemHandler; import java.io.IOException; import java.net.InetSocketAddress; import java.util.HashMap; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.logging.Level; import java.util.logging.Logger; import org.apache.commons.io.IOUtils; import org.drools.KnowledgeBase; import org.drools.KnowledgeBaseConfiguration; import org.drools.KnowledgeBaseFactory; import org.drools.KnowledgeBaseFactoryService; import org.drools.builder.KnowledgeBuilder; import org.drools.builder.KnowledgeBuilderConfiguration; import org.drools.builder.KnowledgeBuilderError; import org.drools.builder.KnowledgeBuilderErrors; import org.drools.builder.KnowledgeBuilderFactory; import org.drools.builder.KnowledgeBuilderFactoryService; import org.drools.builder.ResourceType; import org.drools.builder.conf.AccumulateFunctionOption; import org.drools.conf.EventProcessingOption; import org.drools.grid.ConnectionFactoryService; import org.drools.grid.GridConnection; import org.drools.grid.GridNode; import org.drools.grid.GridServiceDescription; import org.drools.grid.conf.GridPeerServiceConfiguration; import org.drools.grid.conf.impl.GridPeerConfiguration; import org.drools.grid.impl.GridImpl; import org.drools.grid.service.directory.Address; import org.drools.grid.service.directory.WhitePages; import org.drools.grid.service.directory.impl.CoreServicesLookupConfiguration; import org.drools.grid.service.directory.impl.GridServiceDescriptionImpl; import org.drools.grid.service.directory.impl.WhitePagesRemoteConfiguration; import org.drools.io.impl.ByteArrayResource; import org.drools.io.impl.ClassPathResource; import org.drools.runtime.StatefulKnowledgeSession; import org.drools.runtime.process.ProcessInstance; import org.jbpm.task.service.hornetq.CommandBasedHornetQWSHumanTaskHandler; /** * * @author salaboy */ public class DefaultHeartAttackProcedureImpl implements DefaultHeartAttackProcedure { private String emergencyId; private StatefulKnowledgeSession internalSession; private String procedureName; private boolean useLocalKSession; private boolean logInFile; public DefaultHeartAttackProcedureImpl() { this.procedureName = "com.wordpress.salaboy.bpmn2.DefaultHeartAttackProcedure"; } private StatefulKnowledgeSession createDefaultHeartAttackProcedureSession(String emergencyId) throws IOException { System.out.println(">>>> I'm creating the "+"DefaultHeartAttackProcedure"+" procedure for emergencyId = "+emergencyId); GridNode remoteN1 = null; KnowledgeBuilder kbuilder = null; KnowledgeBase kbase = null; if (useLocalKSession) { KnowledgeBuilderConfiguration kbuilderConf = KnowledgeBuilderFactory.newKnowledgeBuilderConfiguration(); kbuilderConf.setOption(AccumulateFunctionOption.get("hospitalDistanceCalculator", new HospitalDistanceCalculator())); kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder(kbuilderConf); KnowledgeBaseConfiguration kbaseConf = KnowledgeBaseFactory.newKnowledgeBaseConfiguration(); kbaseConf.setOption(EventProcessingOption.STREAM); kbase = KnowledgeBaseFactory.newKnowledgeBase(kbaseConf); }else{ Map<String, GridServiceDescription> coreServicesMap = new HashMap<String, GridServiceDescription>(); GridServiceDescriptionImpl gsd = new GridServiceDescriptionImpl(WhitePages.class.getName()); Address addr = gsd.addAddress("socket"); addr.setObject(new InetSocketAddress[]{new InetSocketAddress("localhost", 8000)}); coreServicesMap.put(WhitePages.class.getCanonicalName(), gsd); GridImpl grid = new GridImpl(new ConcurrentHashMap<String, Object>()); GridPeerConfiguration conf = new GridPeerConfiguration(); GridPeerServiceConfiguration coreSeviceConf = new CoreServicesLookupConfiguration(coreServicesMap); conf.addConfiguration(coreSeviceConf); GridPeerServiceConfiguration wprConf = new WhitePagesRemoteConfiguration(); conf.addConfiguration(wprConf); conf.configure(grid); GridServiceDescription<GridNode> n1Gsd = grid.get(WhitePages.class).lookup("n1"); GridConnection<GridNode> conn = grid.get(ConnectionFactoryService.class).createConnection(n1Gsd); remoteN1 = conn.connect(); KnowledgeBuilderConfiguration kbuilderConf = remoteN1.get(KnowledgeBuilderFactoryService.class).newKnowledgeBuilderConfiguration(); kbuilderConf.setOption(AccumulateFunctionOption.get("hospitalDistanceCalculator", new HospitalDistanceCalculator())); kbuilder = remoteN1.get(KnowledgeBuilderFactoryService.class).newKnowledgeBuilder(kbuilderConf); KnowledgeBaseConfiguration kbaseConf = remoteN1.get(KnowledgeBaseFactoryService.class).newKnowledgeBaseConfiguration(); kbaseConf.setOption(EventProcessingOption.STREAM); kbase = remoteN1.get(KnowledgeBaseFactoryService.class).newKnowledgeBase(kbaseConf); } kbuilder.add(new ByteArrayResource(IOUtils.toByteArray(new ClassPathResource("processes/procedures/MultiVehicleProcedure.bpmn").getInputStream())), ResourceType.BPMN2); kbuilder.add(new ByteArrayResource(IOUtils.toByteArray(new ClassPathResource("processes/procedures/DefaultHeartAttackProcedure.bpmn").getInputStream())), ResourceType.BPMN2); kbuilder.add(new ByteArrayResource(IOUtils.toByteArray(new ClassPathResource("rules/select_hospital.drl").getInputStream())), ResourceType.DRL); kbuilder.add(new ByteArrayResource(IOUtils.toByteArray(new ClassPathResource("rules/defaultHeartAttackProcedureEventHandling.drl").getInputStream())), ResourceType.DRL); KnowledgeBuilderErrors errors = kbuilder.getErrors(); if (errors != null && errors.size() > 0) { for (KnowledgeBuilderError error : errors) { System.out.println(">>>>>>> Error: " + error.getMessage()); } throw new IllegalStateException("Failed to parse knowledge!"); } kbase.addKnowledgePackages(kbuilder.getKnowledgePackages()); StatefulKnowledgeSession session = kbase.newStatefulKnowledgeSession(); if (!useLocalKSession){ remoteN1.set("DefaultHeartAttackProcedureSession" + emergencyId, session); } return session; } private void setWorkItemHandlers(StatefulKnowledgeSession session) { session.getWorkItemManager().registerWorkItemHandler("Report", new ProcedureReportWorkItemHandler()); session.getWorkItemManager().registerWorkItemHandler("DispatchSelectedVehicle", new DispatchVehicleWorkItemHandler()); session.getWorkItemManager().registerWorkItemHandler("NotifyEndOfProcedure", new NotifyEndOfProcedureWorkItemHandler()); session.getWorkItemManager().registerWorkItemHandler("Human Task", new CommandBasedHornetQWSHumanTaskHandler(session)); } @Override public void patientAtHospitalNotification(VehicleHitsHospitalEvent event) { internalSession.signalEvent("com.wordpress.salaboy.model.events.PatientAtHospitalEvent", event); } @Override public void patientPickUpNotification(VehicleHitsEmergencyEvent event) { internalSession.insert(event); } @Override public void procedureEndsNotification(EmergencyEndsEvent event) { } @Override public void configure( String emergencyId, Procedure procedure, Map<String, Object> parameters) { this.emergencyId = emergencyId; try { internalSession = createDefaultHeartAttackProcedureSession(this.emergencyId); } catch (IOException ex) { Logger.getLogger(DefaultHeartAttackProcedureImpl.class.getName()).log(Level.SEVERE, null, ex); } setWorkItemHandlers(internalSession); new Thread(new Runnable() { public void run() { internalSession.fireUntilHalt(); } }).start(); parameters.put("concreteProcedureId", this.procedureName); parameters.put("procedure", procedure); ProcessInstance pi = internalSession.startProcess("com.wordpress.salaboy.bpmn2.MultiVehicleProcedure",parameters); internalSession.insert(pi); procedure.setProcessInstanceId(pi.getId()); } public boolean isUseLocalKSession() { return useLocalKSession; } public void setUseLocalKSession(boolean useLocalKSession) { this.useLocalKSession = useLocalKSession; } }