/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* 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.apache.ode.dao.jpa;
import org.apache.ode.bpel.common.CorrelationKey;
import org.apache.ode.bpel.dao.CorrelatorDAO;
import org.apache.ode.bpel.dao.MessageExchangeDAO;
import org.apache.ode.bpel.dao.MessageRouteDAO;
import org.apache.ode.bpel.dao.ProcessInstanceDAO;
import javax.persistence.*;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
@Entity
@Table(name="ODE_CORRELATOR")
@NamedQueries({
@NamedQuery(name="RouteByCKey", query="SELECT route " +
"FROM MessageRouteDAOImpl as route " +
"WHERE route._correlationKey = :ckey " +
"and route._correlator._process._processType = :ptype " +
"and route._correlator._correlatorKey = :corrkey")
})
public class CorrelatorDAOImpl extends OpenJPADAO implements CorrelatorDAO {
@Id @Column(name="CORRELATOR_ID")
@GeneratedValue(strategy=GenerationType.AUTO)
private Long _correlatorId;
@Basic @Column(name="CORRELATOR_KEY")
private String _correlatorKey;
@OneToMany(targetEntity=MessageRouteDAOImpl.class,mappedBy="_correlator",fetch=FetchType.EAGER,cascade={CascadeType.ALL})
private Collection<MessageRouteDAOImpl> _routes = new ArrayList<MessageRouteDAOImpl>();
@OneToMany(targetEntity=MessageExchangeDAOImpl.class,mappedBy="_correlator",fetch=FetchType.LAZY,cascade={CascadeType.ALL})
private Collection<MessageExchangeDAOImpl> _exchanges = new ArrayList<MessageExchangeDAOImpl>();
@ManyToOne(fetch= FetchType.LAZY,cascade={CascadeType.PERSIST}) @Column(name="PROC_ID")
private ProcessDAOImpl _process;
public CorrelatorDAOImpl(){}
public CorrelatorDAOImpl(String correlatorKey, ProcessDAOImpl process) {
_correlatorKey = correlatorKey;
_process = process;
}
public void addRoute(String routeGroupId, ProcessInstanceDAO target, int index, CorrelationKey correlationKey) {
MessageRouteDAOImpl mr = new MessageRouteDAOImpl(correlationKey,
routeGroupId, index, (ProcessInstanceDAOImpl) target, this);
_routes.add(mr);
}
public MessageExchangeDAO dequeueMessage(CorrelationKey correlationKey) {
for (Iterator<MessageExchangeDAOImpl> itr=_exchanges.iterator(); itr.hasNext();){
MessageExchangeDAOImpl mex = itr.next();
if (mex.getCorrelationKeys().contains(correlationKey)) {
itr.remove();
return mex;
}
}
return null;
}
public void enqueueMessage(MessageExchangeDAO mex,
CorrelationKey[] correlationKeys) {
MessageExchangeDAOImpl mexImpl = (MessageExchangeDAOImpl) mex;
for (CorrelationKey key : correlationKeys ) {
mexImpl.addCorrelationKey(key);
}
_exchanges.add(mexImpl);
mexImpl.setCorrelator(this);
}
public MessageRouteDAO findRoute(CorrelationKey correlationKey) {
Query qry = getEM().createNamedQuery("RouteByCKey");
qry.setParameter("ckey", correlationKey.toCanonicalString());
qry.setParameter("ptype", _process.getType().toString());
qry.setParameter("corrkey", _correlatorKey);
List<MessageRouteDAO> routes = (List<MessageRouteDAO>) qry.getResultList();
if (routes.size() > 0) {
return routes.get(0);
} else return null;
}
public String getCorrelatorId() {
return _correlatorKey;
}
public void removeRoutes(String routeGroupId, ProcessInstanceDAO target) {
// remove route across all correlators of the process
((ProcessInstanceDAOImpl)target).removeRoutes(routeGroupId);
}
void removeLocalRoutes(String routeGroupId, ProcessInstanceDAO target) {
for (Iterator<MessageRouteDAOImpl> itr=_routes.iterator(); itr.hasNext(); ) {
MessageRouteDAOImpl mr = itr.next();
if ( mr.getGroupId().equals(routeGroupId) && mr.getTargetInstance().equals(target)) {
itr.remove();
getEM().remove(mr);
}
}
}
}