use of org.jaffa.modules.messaging.services.configdomain.DisplayParam in project jaffa-framework by jaffa-projects.
the class MessageViewerTx method buildDto.
/**
* Obtains the Message based on the messageMode and creates the output.
*/
private MessageViewerOutDto buildDto(MessageViewerInDto input) throws FrameworkException, ApplicationExceptions {
try {
Message message = findMessage(input);
MessageViewerOutDto output = new MessageViewerOutDto();
output.setJMSMessageID(input.getJMSMessageID());
output.setError(message.getStringProperty(JmsBrowser.HEADER_ERROR_DETAILS));
output.setPriority(new Long(message.getJMSPriority()));
output.setHasPriorityAccess(JmsBrowser.hasChangePriorityAccess(message.getStringProperty(JmsBrowser.HEADER_ORIGINAL_QUEUE_NAME)));
output.setJMSDestination(message.getJMSDestination());
output.setJMSDeliveryMode(message.getJMSDeliveryMode());
output.setJMSTimestamp(message.getJMSTimestamp() != 0 ? new DateTime(message.getJMSTimestamp()) : null);
output.setJMSCorrelationID(message.getJMSCorrelationID());
output.setJMSReplyTo(message.getJMSReplyTo());
try {
output.setJMSRedelivered(message.getJMSRedelivered());
} catch (Exception e) {
// JBossMessaging throws "java.lang.IllegalStateException: This should never be called directly". Do nothing
}
output.setJMSType(message.getJMSType());
output.setJMSExpiration(message.getJMSExpiration());
if (message instanceof TextMessage)
output.setPayLoad(((TextMessage) message).getText());
// Generate a Map of header elements, keyed by the name of each header element
// Ignore Error Details as we are showing it in a separate section
Map<String, HeaderElementDto> headerElements = new LinkedHashMap<String, HeaderElementDto>();
for (Enumeration e = message.getPropertyNames(); e.hasMoreElements(); ) {
String name = (String) e.nextElement();
if (!JmsBrowser.HEADER_ERROR_DETAILS.equals(name)) {
String value = Formatter.format(message.getObjectProperty(name));
HeaderElementDto headerElement = headerElements.get(name);
if (headerElement == null) {
headerElement = new HeaderElementDto();
headerElement.setName(name);
headerElements.put(name, headerElement);
}
headerElement.setValue(value);
}
}
// Add labels to the header-elements based on the QueueInfo
// It is possible that a display-param points to a property on the Message (eg. JMSMessageID, JMSPriority etc.)
// Use bean intropsection to extract the value of that property
QueueInfo queueInfo = ConfigurationService.getInstance().getQueueInfo(message.getStringProperty(JmsBrowser.HEADER_ORIGINAL_QUEUE_NAME));
if (queueInfo != null && queueInfo.getDisplayParam() != null) {
for (DisplayParam displayParam : queueInfo.getDisplayParam()) {
HeaderElementDto headerElement = headerElements.get(displayParam.getName());
if (headerElement == null) {
try {
headerElement = new HeaderElementDto();
headerElement.setName(displayParam.getName());
headerElement.setLabel(displayParam.getLabel());
headerElements.put(displayParam.getName(), headerElement);
if (displayParam.getName().equals("JMSTimestamp")) {
String value = message.getJMSTimestamp() != 0 ? Formatter.format(new DateTime(message.getJMSTimestamp())) : null;
headerElement.setValue(value);
} else {
String value = Formatter.format(BeanHelper.getField(message, displayParam.getName()));
headerElement.setValue(value);
}
} catch (Exception e) {
// do nothing
}
} else {
headerElement.setLabel(displayParam.getLabel());
}
}
}
output.setHeaderElements(headerElements.values().toArray(new HeaderElementDto[headerElements.values().size()]));
buildBusinessEventLogDto(input, output, message);
return output;
} catch (JMSException e) {
throw new JaffaMessagingFrameworkException(JaffaMessagingFrameworkException.MESSAGE_INFO_MISSING, null, e);
}
}
use of org.jaffa.modules.messaging.services.configdomain.DisplayParam in project jaffa-framework by jaffa-projects.
the class JmsQueueAdmin method createMessageGraph.
/**
* Molds the input JMS Message into a MessageGraph.
*/
private static MessageGraph createMessageGraph(Message message, String queueName, PropertyFilter pf) throws JMSException, IntrospectionException {
MessageGraph graph = new MessageGraph();
graph.setQueueMetaData(createQueueMetaData(queueName, pf));
if (pf.isFieldIncluded("type"))
graph.setType(queueName);
if (pf.isFieldIncluded("messageId"))
graph.setMessageId(message.getJMSMessageID());
if (pf.isFieldIncluded("priority"))
graph.setPriority(new Long(message.getJMSPriority()));
if (pf.isFieldIncluded("createdOn"))
graph.setCreatedOn(message.getJMSTimestamp() != 0 ? new DateTime(message.getJMSTimestamp()) : null);
if (pf.isFieldIncluded("createdBy"))
graph.setCreatedBy(message.getStringProperty(JmsBrowser.HEADER_USER_ID));
if (pf.isFieldIncluded("errorMessage"))
graph.setErrorMessage(message.getStringProperty(JmsBrowser.HEADER_ERROR_DETAILS));
if (pf.isFieldIncluded("payload") && message instanceof TextMessage)
graph.setPayload(((TextMessage) message).getText());
if (pf.isFieldIncluded("hasAdminAccess"))
graph.setHasAdminAccess(JmsBrowser.hasAdminMessageAccess(queueName));
if (pf.isFieldIncluded("applicationFields") || pf.isFieldIncluded("technicalFields")) {
// Generate a Map of header elements, keyed by the name of each header element
// Names beginning with JMS and jaffa_ will be treated as techincal, while the rest will be assumed to be application-specific
Map<String, MessageField> applicationFields = new LinkedHashMap<String, MessageField>();
Map<String, MessageField> technicalFields = new TreeMap<String, MessageField>();
for (Enumeration e = message.getPropertyNames(); e.hasMoreElements(); ) {
String name = (String) e.nextElement();
String value = Formatter.format(message.getObjectProperty(name));
MessageField messageField = new MessageField();
messageField.setName(name);
messageField.setValue(value);
if (name.startsWith("JMS") || name.startsWith("jaffa_"))
technicalFields.put(name, messageField);
else
applicationFields.put(name, messageField);
}
// Treat all the JMS* properties of the Message as technical
if (pf.isFieldIncluded("technicalFields")) {
BeanInfo beanInfo = Introspector.getBeanInfo(Message.class);
if (beanInfo != null) {
PropertyDescriptor[] pds = beanInfo.getPropertyDescriptors();
if (pds != null) {
for (PropertyDescriptor pd : pds) {
if (pd.getReadMethod() != null && !pd.getPropertyType().isArray()) {
String name = pd.getName();
try {
Object value = pd.getReadMethod().invoke(message);
MessageField messageField = new MessageField();
messageField.setName(name);
messageField.setValue(Formatter.format(value));
technicalFields.put(name, messageField);
} catch (Exception e) {
if (log.isDebugEnabled())
log.debug("Exception thrown while reading Message property: " + name, e);
}
}
}
}
}
if (!technicalFields.isEmpty())
graph.setTechnicalFields(technicalFields.values().toArray(new MessageField[technicalFields.size()]));
}
// Add labels to the application-fields from the configuration-file
if (pf.isFieldIncluded("applicationFields")) {
QueueInfo queueInfo = ConfigurationService.getInstance().getQueueInfo(queueName);
if (queueInfo != null && queueInfo.getDisplayParam() != null) {
for (DisplayParam displayParam : queueInfo.getDisplayParam()) {
if (displayParam.getLabel() != null && applicationFields.containsKey(displayParam.getName()))
applicationFields.get(displayParam.getName()).setLabel(MessageHelper.replaceTokens(displayParam.getLabel()));
}
}
if (!applicationFields.isEmpty())
graph.setApplicationFields(applicationFields.values().toArray(new MessageField[applicationFields.size()]));
}
}
return graph;
}
use of org.jaffa.modules.messaging.services.configdomain.DisplayParam in project jaffa-framework by jaffa-projects.
the class JmsQueueAdmin method createQueueMetaData.
/**
* Creates MetaData for the input Queue, based on the available fields in the PropertyFilter.
*/
private static QueueMetaData createQueueMetaData(String queueName, PropertyFilter pf) {
QueueMetaData qmd = null;
if (pf.isFieldIncluded("queueMetaData")) {
qmd = new QueueMetaData();
if (pf.isFieldIncluded("queueMetaData.queueSystemId"))
qmd.setQueueSystemId(QUEUE_SYSTEM_ID);
if (pf.isFieldIncluded("queueMetaData.type"))
qmd.setType(queueName);
if (pf.isFieldIncluded("queueMetaData.supportedMessageStatus"))
qmd.setSupportedMessageStatus(SUPPORTED_MESSAGE_STATUS);
if (pf.isFieldIncluded("queueMetaData.supportedApplicationFields")) {
QueueInfo queueInfo = ConfigurationService.getInstance().getQueueInfo(queueName);
if (queueInfo != null && queueInfo.getDisplayParam() != null) {
Collection<MessageFieldMetaData> supportedApplicationFields = new LinkedList<MessageFieldMetaData>();
for (DisplayParam displayParam : queueInfo.getDisplayParam()) {
// Ignore fields that are included in the main graph or are part of the technical-details
if (displayParam.getName().startsWith("JMS") || displayParam.getName().startsWith("jaffa_"))
continue;
MessageFieldMetaData supportedApplicationField = new MessageFieldMetaData();
if (pf.isFieldIncluded("queueMetaData.supportedApplicationFields.name"))
supportedApplicationField.setName(displayParam.getName());
if (pf.isFieldIncluded("queueMetaData.supportedApplicationFields.label"))
supportedApplicationField.setLabel(MessageHelper.replaceTokens(displayParam.getLabel()));
supportedApplicationFields.add(supportedApplicationField);
}
if (!supportedApplicationFields.isEmpty())
qmd.setSupportedApplicationFields(supportedApplicationFields.toArray(new MessageFieldMetaData[supportedApplicationFields.size()]));
}
}
if (pf.isFieldIncluded("queueMetaData.supportsTechnicalFields"))
qmd.setSupportsTechnicalFields(SUPPORTS_TECHNICAL_FIELDS);
if (pf.isFieldIncluded("queueMetaData.supportsBusinessEventLogs"))
qmd.setSupportsBusinessEventLogs(SUPPORTS_BUSINESS_EVENT_LOGS);
if (pf.isFieldIncluded("queueMetaData.supportsDependencies"))
qmd.setSupportsDependencies(SUPPORTS_DEPENDENCIES);
}
return qmd;
}
Aggregations