org.apache.camel.component.cxf.jaxws.CxfEndpointUtils Maven / Gradle / Ivy
/*
* 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.camel.component.cxf.jaxws;
import java.lang.annotation.Annotation;
import jakarta.jws.WebService;
import jakarta.xml.ws.WebServiceProvider;
import javax.xml.namespace.QName;
import org.apache.camel.CamelException;
import org.apache.camel.Exchange;
import org.apache.camel.component.cxf.common.message.CxfConstants;
import org.apache.camel.util.ObjectHelper;
import org.apache.cxf.Bus;
import org.apache.cxf.BusFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public final class CxfEndpointUtils {
private static final Logger LOG = LoggerFactory.getLogger(CxfEndpointUtils.class);
private CxfEndpointUtils() {
// not constructed
}
public static QName getQName(final String name) {
QName qName = null;
if (name != null) {
try {
qName = QName.valueOf(name);
} catch (Exception ex) {
LOG.warn("Cannot create QName: {}", ex.getMessage(), ex);
}
}
return qName;
}
public static boolean hasWebServiceAnnotation(Class> cls) {
return hasAnnotation(cls, WebService.class) || hasAnnotation(cls, WebServiceProvider.class);
}
public static boolean hasAnnotation(Class> cls, Class extends Annotation> annotation) {
if (cls == null || cls == Object.class) {
return false;
}
if (null != cls.getAnnotation(annotation)) {
return true;
}
for (Class> interfaceClass : cls.getInterfaces()) {
if (null != interfaceClass.getAnnotation(annotation)) {
return true;
}
}
return hasAnnotation(cls.getSuperclass(), annotation);
}
// only used by test currently
public static void checkServiceClassName(String className) throws CamelException {
if (ObjectHelper.isEmpty(className)) {
throw new CamelException("serviceClass is required for CXF endpoint configuration");
}
}
/**
* Get effective address for a client to invoke a service. It first looks for the
* {@link org.apache.camel.Exchange#DESTINATION_OVERRIDE_URL} in the IN message header. If the header is not found,
* it will return the default address.
*
* @param exchange
* @param defaultAddress
*/
public static String getEffectiveAddress(Exchange exchange, String defaultAddress) {
String retval = exchange.getIn().getHeader(CxfConstants.DESTINATION_OVERRIDE_URL, String.class);
if (retval == null) {
retval = defaultAddress;
} else {
LOG.trace("Client address is overridden by header '{}' to value '{}'",
CxfConstants.DESTINATION_OVERRIDE_URL, retval);
}
return retval;
}
/**
* Create a CXF bus with either BusFactory or SpringBusFactory if Camel Context is SpringCamelContext. In the latter
* case, this method updates the bus configuration with the applicationContext which SpringCamelContext holds
*
*/
public static Bus createBus() {
BusFactory busFactory = BusFactory.newInstance();
return busFactory.createBus();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy