org.fabric3.binding.jms.runtime.JmsSourceWireAttacher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of fabric3-binding-jms Show documentation
Show all versions of fabric3-binding-jms Show documentation
Provides support for JMS-based messaging
/*
* Fabric3
* Copyright (c) 2009-2011 Metaform Systems
*
* Fabric3 is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version, with the
* following exception:
*
* Linking this software statically or dynamically with other
* modules is making a combined work based on this software.
* Thus, the terms and conditions of the GNU General Public
* License cover the whole combination.
*
* As a special exception, the copyright holders of this software
* give you permission to link this software with independent
* modules to produce an executable, regardless of the license
* terms of these independent modules, and to copy and distribute
* the resulting executable under terms of your choice, provided
* that you also meet, for each linked independent module, the
* terms and conditions of the license of that module. An
* independent module is a module which is not derived from or
* based on this software. If you modify this software, you may
* extend this exception to your version of the software, but
* you are not obligated to do so. If you do not wish to do so,
* delete this exception statement from your version.
*
* Fabric3 is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the
* GNU General Public License along with Fabric3.
* If not, see .
*
* ----------------------------------------------------
*
* Portions originally based on Apache Tuscany 2007
* licensed under the Apache 2.0 license.
*
*/
package org.fabric3.binding.jms.runtime;
import java.net.URI;
import java.util.ArrayList;
import java.util.List;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import org.osoa.sca.annotations.Reference;
import org.fabric3.api.annotation.monitor.Monitor;
import org.fabric3.binding.jms.runtime.container.ContainerConfiguration;
import org.fabric3.binding.jms.runtime.container.MessageContainerManager;
import org.fabric3.binding.jms.runtime.resolver.AdministeredObjectResolver;
import org.fabric3.binding.jms.spi.common.CacheLevel;
import org.fabric3.binding.jms.spi.common.ConnectionFactoryDefinition;
import org.fabric3.binding.jms.spi.common.CorrelationScheme;
import org.fabric3.binding.jms.spi.common.DestinationDefinition;
import org.fabric3.binding.jms.spi.common.JmsBindingMetadata;
import org.fabric3.binding.jms.spi.common.TransactionType;
import org.fabric3.binding.jms.spi.provision.JmsSourceDefinition;
import org.fabric3.binding.jms.spi.provision.OperationPayloadTypes;
import org.fabric3.binding.jms.spi.runtime.JmsResolutionException;
import org.fabric3.spi.builder.WiringException;
import org.fabric3.spi.builder.component.SourceWireAttacher;
import org.fabric3.spi.classloader.ClassLoaderRegistry;
import org.fabric3.spi.model.physical.PhysicalOperationDefinition;
import org.fabric3.spi.model.physical.PhysicalTargetDefinition;
import org.fabric3.spi.objectfactory.ObjectFactory;
import org.fabric3.spi.wire.InvocationChain;
import org.fabric3.spi.wire.Wire;
import static org.fabric3.binding.jms.spi.common.CacheLevel.ADMINISTERED_OBJECTS;
import static org.fabric3.binding.jms.spi.runtime.JmsConstants.CACHE_ADMINISTERED_OBJECTS;
import static org.fabric3.binding.jms.spi.runtime.JmsConstants.CACHE_CONNECTION;
import static org.fabric3.binding.jms.spi.runtime.JmsConstants.CACHE_NONE;
/**
* Attaches a channel or consumer to a JMS destination.
*
* @version $Revision: 9763 $ $Date: 2011-01-03 00:48:06 +0000 (Mon, 03 Jan 2011) $
*/
public class JmsSourceWireAttacher implements SourceWireAttacher {
private AdministeredObjectResolver resolver;
private ClassLoaderRegistry classLoaderRegistry;
private MessageContainerManager containerManager;
private ListenerMonitor monitor;
public JmsSourceWireAttacher(@Reference AdministeredObjectResolver resolver,
@Reference ClassLoaderRegistry classLoaderRegistry,
@Reference MessageContainerManager containerManager,
@Monitor ListenerMonitor monitor) {
this.resolver = resolver;
this.classLoaderRegistry = classLoaderRegistry;
this.containerManager = containerManager;
this.monitor = monitor;
}
public void attach(JmsSourceDefinition source, PhysicalTargetDefinition target, Wire wire) throws WiringException {
URI serviceUri = target.getUri();
ClassLoader sourceClassLoader = classLoaderRegistry.getClassLoader(source.getClassLoaderId());
TransactionType trxType = source.getTransactionType();
WireHolder wireHolder = createWireHolder(wire, source, target, trxType);
ResolvedObjects objects = resolveAdministeredObjects(source);
ContainerConfiguration configuration = new ContainerConfiguration();
try {
ConnectionFactory requestFactory = objects.getRequestFactory();
Destination requestDestination = objects.getRequestDestination();
ConnectionFactory responseFactory = objects.getResponseFactory();
Destination responseDestination = objects.getResponseDestination();
ServiceListener listener = new ServiceListener(wireHolder, responseDestination, responseFactory, trxType, sourceClassLoader, monitor);
configuration.setDestination(requestDestination);
configuration.setFactory(requestFactory);
configuration.setMessageListener(listener);
configuration.setUri(serviceUri);
configuration.setType(trxType);
populateConfiguration(configuration, source.getMetadata());
if (containerManager.isRegistered(serviceUri)) {
// the wire has changed and it is being reprovisioned
containerManager.unregister(serviceUri);
}
containerManager.register(configuration);
} catch (JMSException e) {
throw new WiringException(e);
}
}
private void populateConfiguration(ContainerConfiguration configuration, JmsBindingMetadata metadata) {
CacheLevel cacheLevel = metadata.getCacheLevel();
if (CacheLevel.CONNECTION == cacheLevel) {
configuration.setCacheLevel(CACHE_CONNECTION);
} else if (ADMINISTERED_OBJECTS == cacheLevel) {
configuration.setCacheLevel(CACHE_ADMINISTERED_OBJECTS);
} else {
configuration.setCacheLevel(CACHE_NONE);
}
configuration.setIdleLimit(metadata.getIdleLimit());
configuration.setMaxMessagesToProcess(metadata.getMaxMessagesToProcess());
configuration.setMaxReceivers(metadata.getMaxReceivers());
configuration.setMinReceivers(metadata.getMinReceivers());
configuration.setReceiveTimeout(metadata.getReceiveTimeout());
configuration.setTransactionTimeout(metadata.getTransactionTimeout());
// configuration.setDeliveryMode();
// configuration.setDurableSubscriptionName();
// configuration.setExceptionListener();
// configuration.setClientId();
// configuration.setLocalDelivery();
}
public void detach(JmsSourceDefinition source, PhysicalTargetDefinition target) throws WiringException {
try {
containerManager.unregister(target.getUri());
// FABRICTHREE-544: release must be done after unregistering since a container may attempt to receive a message from a closed connection
resolver.release(source.getMetadata().getConnectionFactory());
} catch (JMSException e) {
throw new WiringException(e);
}
}
public void attachObjectFactory(JmsSourceDefinition source, ObjectFactory> objectFactory, PhysicalTargetDefinition definition)
throws WiringException {
throw new UnsupportedOperationException();
}
public void detachObjectFactory(JmsSourceDefinition source, PhysicalTargetDefinition target) throws WiringException {
throw new AssertionError();
}
private ResolvedObjects resolveAdministeredObjects(JmsSourceDefinition source) throws WiringException {
try {
JmsBindingMetadata metadata = source.getMetadata();
ConnectionFactoryDefinition requestDefinition = metadata.getConnectionFactory();
ConnectionFactory requestConnectionFactory = resolver.resolve(requestDefinition);
DestinationDefinition requestDestinationDefinition = metadata.getDestination();
Destination requestDestination = resolver.resolve(requestDestinationDefinition, requestConnectionFactory);
ConnectionFactory responseConnectionFactory = null;
Destination responseDestination = null;
if (metadata.isResponse()) {
ConnectionFactoryDefinition responseDefinition = metadata.getResponseConnectionFactory();
responseConnectionFactory = resolver.resolve(responseDefinition);
DestinationDefinition responseDestinationDefinition = metadata.getResponseDestination();
responseDestination = resolver.resolve(responseDestinationDefinition, responseConnectionFactory);
}
return new ResolvedObjects(requestConnectionFactory, requestDestination, responseConnectionFactory, responseDestination);
} catch (JmsResolutionException e) {
throw new WiringException(e);
}
}
private WireHolder createWireHolder(Wire wire, JmsSourceDefinition source, PhysicalTargetDefinition target, TransactionType trxType)
throws WiringException {
String callbackUri = null;
if (target.getCallbackUri() != null) {
callbackUri = target.getCallbackUri().toString();
}
JmsBindingMetadata metadata = source.getMetadata();
List types = source.getPayloadTypes();
CorrelationScheme correlationScheme = metadata.getCorrelationScheme();
List chainHolders = new ArrayList();
for (InvocationChain chain : wire.getInvocationChains()) {
PhysicalOperationDefinition definition = chain.getPhysicalOperation();
OperationPayloadTypes payloadType = resolveOperation(definition.getName(), types);
if (payloadType == null) {
throw new WiringException("Payload type not found for operation: " + definition.getName());
}
chainHolders.add(new InvocationChainHolder(chain, payloadType));
}
return new WireHolder(chainHolders, callbackUri, correlationScheme, trxType);
}
private OperationPayloadTypes resolveOperation(String operationName, List payloadTypes) {
for (OperationPayloadTypes type : payloadTypes) {
if (type.getName().equals(operationName)) {
return type;
}
}
// programming error
throw new AssertionError("Error resolving operation: " + operationName);
}
private class ResolvedObjects {
private ConnectionFactory requestFactory;
private ConnectionFactory responseFactory;
private Destination requestDestination;
private Destination responseDestination;
private ResolvedObjects(ConnectionFactory requestFactory,
Destination requestDestination,
ConnectionFactory responseFactory,
Destination responseDestination) {
this.requestFactory = requestFactory;
this.requestDestination = requestDestination;
this.responseFactory = responseFactory;
this.responseDestination = responseDestination;
}
public ConnectionFactory getRequestFactory() {
return requestFactory;
}
public ConnectionFactory getResponseFactory() {
return responseFactory;
}
public Destination getRequestDestination() {
return requestDestination;
}
public Destination getResponseDestination() {
return responseDestination;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy