/** * 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.cxf.transport.http.netty.server; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.HashSet; import java.util.List; import java.util.Set; import org.apache.cxf.Bus; import org.apache.cxf.configuration.Configurer; import org.apache.cxf.service.model.EndpointInfo; import org.apache.cxf.transport.AbstractTransportFactory; import org.apache.cxf.transport.Destination; import org.apache.cxf.transport.DestinationFactory; import org.apache.cxf.transport.http.AbstractHTTPDestination; import org.apache.cxf.transport.http.DestinationRegistry; import org.apache.cxf.transport.http.DestinationRegistryImpl; import org.apache.cxf.transport.http.HttpDestinationFactory; public class NettyHttpTransportFactory extends AbstractTransportFactory implements DestinationFactory { public static final List<String> DEFAULT_NAMESPACES = Arrays .asList("http://cxf.apache.org/transports/http/netty/server"); /** * This constant holds the prefixes served by this factory. */ private static final Set<String> URI_PREFIXES = new HashSet<>(); static { URI_PREFIXES.add("netty://"); } protected final DestinationRegistry registry; protected final HttpDestinationFactory factory = new NettyHttpDestinationFactory(); public NettyHttpTransportFactory() { this(new DestinationRegistryImpl()); } public NettyHttpTransportFactory(DestinationRegistry registry) { super(DEFAULT_NAMESPACES); if (registry == null) { registry = new DestinationRegistryImpl(); } this.registry = registry; } public DestinationRegistry getRegistry() { return registry; } /** * This call is used by CXF ExtensionManager to inject the activationNamespaces * @param ans The transport ids. */ public void setActivationNamespaces(Collection<String> ans) { setTransportIds(new ArrayList<>(ans)); } public Set<String> getUriPrefixes() { return URI_PREFIXES; } /** * This call uses the Configurer from the bus to configure * a bean. * * @param bean */ protected void configure(Bus b, Object bean) { configure(b, bean, null, null); } protected void configure(Bus bus, Object bean, String name, String extraName) { Configurer configurer = bus.getExtension(Configurer.class); if (null != configurer) { configurer.configureBean(name, bean); if (extraName != null) { configurer.configureBean(extraName, bean); } } } protected String getAddress(EndpointInfo endpointInfo) { String address = endpointInfo.getAddress(); if (address.startsWith("netty://")) { address = address.substring(8); } return address; } public Destination getDestination(EndpointInfo endpointInfo, Bus bus) throws IOException { if (endpointInfo == null) { throw new IllegalArgumentException("EndpointInfo cannot be null"); } synchronized (registry) { AbstractHTTPDestination d = registry.getDestinationForPath(endpointInfo.getAddress()); if (d == null) { d = factory.createDestination(endpointInfo, bus, registry); registry.addDestination(d); configure(bus, d); d.finalizeConfig(); } return d; } } }