AMQ-5662 improve Web Console to support retry from all configured DLQs

This commit is contained in:
Petter Nordlander 2016-03-14 21:26:21 +01:00
parent b39ab7867c
commit 478d28f988
4 changed files with 79 additions and 21 deletions

View File

@ -0,0 +1,62 @@
/**
* 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.activemq.web.controller;
import org.apache.activemq.broker.jmx.QueueViewMBean;
import org.apache.activemq.web.BrokerFacade;
import org.apache.activemq.web.DestinationFacade;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Retry a message on a queue.
*/
public class RetryMessage extends DestinationFacade implements Controller {
private String messageId;
private static final Logger log = LoggerFactory.getLogger(MoveMessage.class);
public RetryMessage(BrokerFacade brokerFacade) {
super(brokerFacade);
}
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
if (messageId != null) {
QueueViewMBean queueView = getQueueView();
if (queueView != null) {
log.info("Retrying message " + getJMSDestination() + "(" + messageId + ")");
queueView.retryMessage(messageId);
} else {
log.warn("No queue named: " + getPhysicalDestinationName());
}
}
return redirectToDestinationView();
}
public String getMessageId() {
return messageId;
}
public void setMessageId(String messageId) {
this.messageId = messageId;
}
}

View File

@ -39,6 +39,7 @@
<bean name="/copyMessage.action" class="org.apache.activemq.web.controller.CopyMessage" autowire="constructor" scope="prototype"/> <bean name="/copyMessage.action" class="org.apache.activemq.web.controller.CopyMessage" autowire="constructor" scope="prototype"/>
<bean name="/moveMessage.action" class="org.apache.activemq.web.controller.MoveMessage" autowire="constructor" scope="prototype"/> <bean name="/moveMessage.action" class="org.apache.activemq.web.controller.MoveMessage" autowire="constructor" scope="prototype"/>
<bean name="/deleteJob.action" class="org.apache.activemq.web.controller.DeleteJob" autowire="constructor" scope="prototype"/> <bean name="/deleteJob.action" class="org.apache.activemq.web.controller.DeleteJob" autowire="constructor" scope="prototype"/>
<bean name="/retryMessage.action" class="org.apache.activemq.web.controller.RetryMessage" autowire="constructor" scope="prototype"/>
<!-- <!--
- This bean resolves specific types of exception to corresponding error views. - This bean resolves specific types of exception to corresponding error views.

View File

@ -134,26 +134,17 @@ No message could be found for ID <c:out value="${requestContext.messageQuery.id}
<tr> <tr>
<td colspan="2"><a href="<c:out value='deleteMessage.action?JMSDestination=${requestContext.messageQuery.JMSDestination}&messageId=${row.JMSMessageID}&secret=${sessionScope["secret"]}' />" onclick="return confirm('Are you sure you want to delete the message?')" >Delete</a></td> <td colspan="2"><a href="<c:out value='deleteMessage.action?JMSDestination=${requestContext.messageQuery.JMSDestination}&messageId=${row.JMSMessageID}&secret=${sessionScope["secret"]}' />" onclick="return confirm('Are you sure you want to delete the message?')" >Delete</a></td>
</tr> </tr>
<c:set var="queueName" value="${requestContext.messageQuery.JMSDestination}"/> <c:if test="${requestContext.messageQuery.isDLQ() || requestContext.messageQuery.JMSDestination eq 'ActiveMQ.DLQ'}">
<c:set var="queueNameSubStr" value="${fn:substring(queueName, 0, 4)}" />
<c:if test="${queueNameSubStr eq 'DLQ.' || queueNameSubStr eq 'DLT.'}">
<c:if test="${queueNameSubStr eq 'DLQ.'}">
<c:set var="moveToQueue" value="${fn:replace(queueName, 'DLQ.', '')}" />
</c:if>
<c:if test="${queueNameSubStr eq 'DLT.'}">
<c:set var="moveToQueue" value="${fn:replace(queueName, 'DLT.', '')}" />
</c:if>
<tr> <tr>
<td colspan="2"> <td>
<a href="<c:url value="moveMessage.action"> <a href="<c:url value="retryMessage.action">
<c:param name="destination" value="${moveToQueue}" />
<c:param name="JMSDestination" value="${requestContext.messageQuery.JMSDestination}" /> <c:param name="JMSDestination" value="${requestContext.messageQuery.JMSDestination}" />
<c:param name="messageId" value="${row.JMSMessageID}" /> <c:param name="messageId" value="${row.JMSMessageID}" />
<c:param name="JMSDestinationType" value="queue" /> <c:param name="JMSDestinationType" value="queue" />
<c:param name="secret" value='${sessionScope["secret"]}' /> <c:param name="secret" value='${sessionScope["secret"]}' />
</c:url>" </c:url>"
onclick="return confirm('Are you sure you want to retry this message on queue://<c:out value="${moveToQueue}"/>?')" onclick="return confirm('Are you sure you want to retry this message?')"
title="Move to <c:out value="$moveToQueue" /> to attempt reprocessing">Retry</a> title="Retry - attempt reprocessing on original destination">Retry</a>
</td> </td>
</tr> </tr>
</c:if> </c:if>

View File

@ -112,6 +112,10 @@ public class MessageQuery extends QueueBrowseQuery {
return null; return null;
} }
public boolean isDLQ() throws Exception {
return getQueueView().isDLQ();
}
public Map<String, Object> getPropertiesMap() throws JMSException { public Map<String, Object> getPropertiesMap() throws JMSException {
Map<String, Object> answer = new HashMap<String, Object>(); Map<String, Object> answer = new HashMap<String, Object>();
Message aMessage = getMessage(); Message aMessage = getMessage();