mirror of https://github.com/apache/activemq.git
added a helper class and strategy method for people wishing to implement their own custom MessageQuery strategies to be fired as a new subscriber is created
git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/trunk@357712 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
cf3516ec55
commit
7c7cca9dfb
|
@ -0,0 +1,39 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright 2005 LogicBlaze, Inc. http://www.logicblaze.com
|
||||||
|
*
|
||||||
|
* Licensed 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.activemq.broker.region.policy;
|
||||||
|
|
||||||
|
import org.activemq.command.ActiveMQDestination;
|
||||||
|
|
||||||
|
import javax.jms.MessageListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents some kind of query which will load messages from some source.
|
||||||
|
*
|
||||||
|
* @version $Revision$
|
||||||
|
*/
|
||||||
|
public interface MessageQuery {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Executes the query for messages; each message is passed into the listener
|
||||||
|
*
|
||||||
|
* @param destination the destination on which the query is to be performed
|
||||||
|
* @param listener is the listener to notify as each message is created or loaded
|
||||||
|
*/
|
||||||
|
public void execute(ActiveMQDestination destination, MessageListener listener);
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,101 @@
|
||||||
|
/**
|
||||||
|
* <a href="http://activemq.org">ActiveMQ: The Open Source Message Fabric</a>
|
||||||
|
*
|
||||||
|
* Copyright 2005 (C) LogicBlaze, Inc. http://www.logicblaze.com
|
||||||
|
*
|
||||||
|
* Licensed 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.activemq.broker.region.policy;
|
||||||
|
|
||||||
|
import org.activemq.ActiveMQMessageTransformation;
|
||||||
|
import org.activemq.broker.ConnectionContext;
|
||||||
|
import org.activemq.broker.region.MessageReference;
|
||||||
|
import org.activemq.broker.region.Subscription;
|
||||||
|
import org.activemq.command.ActiveMQDestination;
|
||||||
|
import org.activemq.command.ActiveMQMessage;
|
||||||
|
import org.activemq.filter.MessageEvaluationContext;
|
||||||
|
import org.apache.commons.logging.Log;
|
||||||
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
|
||||||
|
import javax.jms.Message;
|
||||||
|
import javax.jms.MessageListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This implementation of {@link SubscriptionRecoveryPolicy} will perform a user
|
||||||
|
* specific query mechanism to load any messages they may have missed.
|
||||||
|
*
|
||||||
|
* @org.xbean.XBean
|
||||||
|
*
|
||||||
|
* @version $Revision$
|
||||||
|
*/
|
||||||
|
public class QueryBasedSubscriptionRecoveryPolicy implements SubscriptionRecoveryPolicy {
|
||||||
|
|
||||||
|
private static final Log log = LogFactory.getLog(QueryBasedSubscriptionRecoveryPolicy.class);
|
||||||
|
|
||||||
|
private MessageQuery query;
|
||||||
|
|
||||||
|
public void add(ConnectionContext context, MessageReference message) throws Throwable {
|
||||||
|
}
|
||||||
|
|
||||||
|
public void recover(ConnectionContext context, final Subscription sub) throws Throwable {
|
||||||
|
if (query != null) {
|
||||||
|
final MessageEvaluationContext msgContext = context.getMessageEvaluationContext();
|
||||||
|
try {
|
||||||
|
ActiveMQDestination destination = sub.getConsumerInfo().getDestination();
|
||||||
|
query.execute(destination, new MessageListener() {
|
||||||
|
public void onMessage(Message message) {
|
||||||
|
dispatchInitialMessage(message, msgContext, sub);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
msgContext.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void start() throws Exception {
|
||||||
|
if (query != null) {
|
||||||
|
throw new IllegalArgumentException("No query property configured");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void stop() throws Exception {
|
||||||
|
}
|
||||||
|
|
||||||
|
public MessageQuery getQuery() {
|
||||||
|
return query;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the query strategy to load initial messages
|
||||||
|
*/
|
||||||
|
public void setQuery(MessageQuery query) {
|
||||||
|
this.query = query;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void dispatchInitialMessage(Message message, MessageEvaluationContext msgContext, Subscription sub) {
|
||||||
|
try {
|
||||||
|
ActiveMQMessage activeMessage = ActiveMQMessageTransformation.transformMessage(message, null);
|
||||||
|
msgContext.setDestination(activeMessage.getDestination());
|
||||||
|
msgContext.setMessageReference(activeMessage);
|
||||||
|
if (sub.matches(activeMessage, msgContext)) {
|
||||||
|
sub.add(activeMessage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Throwable e) {
|
||||||
|
log.warn("Failed to dispatch initial message: " + message + " into subscription. Reason: " + e, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue