/** * 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.transport.discovery; import java.io.IOException; import java.net.URI; import java.util.HashMap; import java.util.Map; import org.apache.activemq.transport.CompositeTransport; import org.apache.activemq.transport.Transport; import org.apache.activemq.transport.TransportServer; import org.apache.activemq.transport.failover.FailoverTransport; import org.apache.activemq.transport.failover.FailoverTransportFactory; import org.apache.activemq.util.IntrospectionSupport; import org.apache.activemq.util.URISupport.CompositeData; /** * */ public class DiscoveryTransportFactory extends FailoverTransportFactory { public Transport createTransport(CompositeData compositeData) throws IOException { Map<String, String> parameters = new HashMap<String, String>(compositeData.getParameters()); FailoverTransport failoverTransport = createTransport(parameters); return createTransport(failoverTransport, compositeData, parameters); } /** * Creates a transport that reports discovered brokers to a specific composite transport. * * @param compositeTransport transport to report discovered brokers to * @param compositeData used to apply parameters to this transport * @return a transport that reports discovered brokers to a specific composite transport. * @throws IOException */ public static DiscoveryTransport createTransport(CompositeTransport compositeTransport, CompositeData compositeData, Map<String, String> parameters) throws IOException { DiscoveryTransport transport = new DiscoveryTransport(compositeTransport); IntrospectionSupport.setProperties(transport, parameters); transport.setParameters(parameters); URI discoveryAgentURI = compositeData.getComponents()[0]; DiscoveryAgent discoveryAgent = DiscoveryAgentFactory.createDiscoveryAgent(discoveryAgentURI); transport.setDiscoveryAgent(discoveryAgent); return transport; } public TransportServer doBind(URI location) throws IOException { throw new IOException("Invalid server URI: " + location); // try{ // CompositeData compositData=URISupport.parseComposite(location); // URI[] components=compositData.getComponents(); // if(components.length!=1){ // throw new IOException("Invalid location: "+location // +", the location must have 1 and only 1 composite URI in it - components = " // +components.length); // } // Map parameters=new HashMap(compositData.getParameters()); // DiscoveryTransportServer server=new DiscoveryTransportServer(TransportFactory.bind(value,components[0])); // IntrospectionSupport.setProperties(server,parameters,"discovery"); // DiscoveryAgent discoveryAgent=DiscoveryAgentFactory.createDiscoveryAgent(server.getDiscovery()); // // Use the host name to configure the group of the discovery agent. // if(!parameters.containsKey("discovery.group")){ // if(compositData.getHost()!=null){ // parameters.put("discovery.group",compositData.getHost()); // } // } // if(!parameters.containsKey("discovery.brokerName")){ // parameters.put("discovery.brokerName",value); // } // IntrospectionSupport.setProperties(discoveryAgent,parameters,"discovery."); // server.setDiscoveryAgent(discoveryAgent); // return server; // }catch(URISyntaxException e){ // throw new IOException("Invalid location: "+location); // } } }