org.apache.camel.component.spring.ws.SpringWebserviceConfiguration 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.spring.ws;
import java.net.URI;
import java.net.URISyntaxException;
import org.apache.camel.component.spring.ws.bean.CamelEndpointDispatcher;
import org.apache.camel.component.spring.ws.bean.CamelSpringWSEndpointMapping;
import org.apache.camel.component.spring.ws.filter.MessageFilter;
import org.apache.camel.component.spring.ws.type.EndpointMappingKey;
import org.apache.camel.component.spring.ws.type.EndpointMappingType;
import org.apache.camel.spi.UriParam;
import org.apache.camel.spi.UriParams;
import org.apache.camel.spi.UriPath;
import org.apache.camel.support.jsse.SSLContextParameters;
import org.springframework.util.StringUtils;
import org.springframework.ws.WebServiceMessageFactory;
import org.springframework.ws.client.core.WebServiceTemplate;
import org.springframework.ws.soap.addressing.messageid.MessageIdStrategy;
import org.springframework.ws.transport.WebServiceMessageSender;
import org.springframework.xml.xpath.XPathExpression;
@UriParams
public class SpringWebserviceConfiguration {
@UriPath(label = "producer")
private String webServiceEndpointUri;
/* Common configuration */
@UriParam
private MessageFilter messageFilter;
@UriParam(label = "security")
private SSLContextParameters sslContextParameters;
@UriParam(label = "common")
private MessageIdStrategy messageIdStrategy;
/* Producer configuration */
@UriParam(label = "producer")
private WebServiceTemplate webServiceTemplate;
@UriParam(label = "producer")
private WebServiceMessageSender messageSender;
@UriParam(label = "producer")
private WebServiceMessageFactory messageFactory;
@UriParam(label = "producer")
private String soapAction;
@UriParam(label = "producer")
private URI wsAddressingAction;
@UriParam(label = "producer")
private URI outputAction;
@UriParam(label = "producer")
private URI faultAction;
@UriParam(label = "producer")
private URI faultTo;
@UriParam(label = "producer")
private URI replyTo;
@UriParam(label = "producer")
private int timeout = -1;
@UriParam(label = "producer")
private boolean allowResponseHeaderOverride;
@UriParam(label = "producer")
private boolean allowResponseAttachmentOverride;
/* Consumer configuration */
@UriPath(label = "consumer", name = "type")
private EndpointMappingType endpointMappingType;
@UriPath(label = "consumer", name = "lookupKey")
private String endpointMappingLookupKey;
@UriParam(label = "consumer")
private String expression;
private transient XPathExpression xPathExpression;
@UriParam(label = "consumer")
private CamelSpringWSEndpointMapping endpointMapping;
@UriParam(label = "consumer")
private CamelEndpointDispatcher endpointDispatcher;
public WebServiceTemplate getWebServiceTemplate() {
return webServiceTemplate;
}
/**
* Option to provide a custom WebServiceTemplate. This allows for full control over client-side web services
* handling; like adding a custom interceptor or specifying a fault resolver, message sender or message factory.
*/
public void setWebServiceTemplate(WebServiceTemplate webServiceTemplate) {
this.webServiceTemplate = webServiceTemplate;
}
public WebServiceMessageFactory getMessageFactory() {
return messageFactory;
}
/**
* Option to provide a custom WebServiceMessageFactory. For example when you want Apache Axiom to handle web service
* messages instead of SAAJ.
*/
public void setMessageFactory(WebServiceMessageFactory messageFactory) {
this.messageFactory = messageFactory;
}
public String getWebServiceEndpointUri() {
return webServiceEndpointUri;
}
/**
* The default Web Service endpoint uri to use for the producer.
*/
public void setWebServiceEndpointUri(String webServiceEndpointUri) {
this.webServiceEndpointUri = webServiceEndpointUri;
}
public String getSoapAction() {
return soapAction;
}
/**
* SOAP action to include inside a SOAP request when accessing remote web services
*/
public void setSoapAction(String soapAction) {
this.soapAction = soapAction;
}
public String getEndpointUri() {
if (getEndpointMappingKey() != null) {
// only for consumers, use lookup key as endpoint uri/key
return encode(getEndpointMappingKey().getLookupKey());
} else if (webServiceTemplate != null) {
return webServiceTemplate.getDefaultUri();
}
return null;
}
public URI getWsAddressingAction() {
return wsAddressingAction;
}
/**
* WS-Addressing 1.0 action header to include when accessing web services. The To header is set to the address of
* the web service as specified in the endpoint URI (default Spring-WS behavior).
*/
public void setWsAddressingAction(URI wsAddressingAction) {
this.wsAddressingAction = wsAddressingAction;
}
public void setWsAddressingAction(String wsAddressingAction) throws URISyntaxException {
if (StringUtils.hasText(wsAddressingAction)) {
setWsAddressingAction(new URI(wsAddressingAction));
}
}
public int getTimeout() {
return timeout;
}
/**
* Sets the socket read timeout (in milliseconds) while invoking a webservice using the producer, see
* URLConnection.setReadTimeout() and CommonsHttpMessageSender.setReadTimeout(). This option works when using the
* built-in message sender implementations: CommonsHttpMessageSender and HttpUrlConnectionMessageSender. One of
* these implementations will be used by default for HTTP based services unless you customize the Spring WS
* configuration options supplied to the component. If you are using a non-standard sender, it is assumed that you
* will handle your own timeout configuration. The built-in message sender HttpComponentsMessageSender is considered
* instead of CommonsHttpMessageSender which has been deprecated, see HttpComponentsMessageSender.setReadTimeout().
*/
public void setTimeout(int timeout) {
this.timeout = timeout;
}
public CamelSpringWSEndpointMapping getEndpointMapping() {
return endpointMapping;
}
/**
* Reference to an instance of org.apache.camel.component.spring.ws.bean.CamelEndpointMapping in the
* Registry/ApplicationContext. Only one bean is required in the registry to serve all Camel/Spring-WS endpoints.
* This bean is auto-discovered by the MessageDispatcher and used to map requests to Camel endpoints based on
* characteristics specified on the endpoint (like root QName, SOAP action, etc)
*/
public void setEndpointMapping(CamelSpringWSEndpointMapping endpointMapping) {
this.endpointMapping = endpointMapping;
}
public EndpointMappingKey getEndpointMappingKey() {
if (endpointMappingType != null && endpointMappingLookupKey != null) {
return new EndpointMappingKey(endpointMappingType, endpointMappingLookupKey, xPathExpression);
} else {
return null;
}
}
public EndpointMappingType getEndpointMappingType() {
return endpointMappingType;
}
/**
* Endpoint mapping type if endpoint mapping is used.
*
* - rootqname - Offers the option to map web service requests based on the qualified name of the root element
* contained in the message.
* - soapaction - Used to map web service requests based on the SOAP action specified in the header of the
* message.
* - uri - In order to map web service requests that target a specific URI.
* - xpathresult - Used to map web service requests based on the evaluation of an XPath expression against the
* incoming message. The result of the evaluation should match the XPath result specified in the endpoint URI.
* - beanname - Allows you to reference an org.apache.camel.component.spring.ws.bean.CamelEndpointDispatcher
* object in order to integrate with existing (legacy) endpoint mappings like PayloadRootQNameEndpointMapping,
* SoapActionEndpointMapping, etc
*
*/
public void setEndpointMappingType(EndpointMappingType endpointMappingType) {
this.endpointMappingType = endpointMappingType;
}
public String getEndpointMappingLookupKey() {
return endpointMappingLookupKey;
}
/**
* Endpoint mapping key if endpoint mapping is used
*/
public void setEndpointMappingLookupKey(String endpointMappingLookupKey) {
this.endpointMappingLookupKey = endpointMappingLookupKey;
}
public String getExpression() {
return expression;
}
/**
* The XPath expression to use when option type=xpathresult. Then this option is required to be configured.
*/
public void setExpression(String expression) {
this.expression = expression;
}
public XPathExpression getxPathExpression() {
return xPathExpression;
}
public void setxPathExpression(XPathExpression xPathExpression) {
this.xPathExpression = xPathExpression;
}
public SSLContextParameters getSslContextParameters() {
return sslContextParameters;
}
/**
* To configure security using SSLContextParameters
*/
public void setSslContextParameters(SSLContextParameters sslContextParameters) {
this.sslContextParameters = sslContextParameters;
}
public CamelEndpointDispatcher getEndpointDispatcher() {
return endpointDispatcher;
}
/**
* Spring {@link org.springframework.ws.server.endpoint.MessageEndpoint} for dispatching messages received by
* Spring-WS to a Camel endpoint, to integrate with existing (legacy) endpoint mappings like
* PayloadRootQNameEndpointMapping, SoapActionEndpointMapping, etc.
*/
public void setEndpointDispatcher(CamelEndpointDispatcher endpointDispatcher) {
this.endpointDispatcher = endpointDispatcher;
}
public static String encode(String uri) {
int i = uri.lastIndexOf('}');
return i == -1 ? uri : (uri.subSequence(0, i) + ")" + uri.substring(i + 1)).replaceFirst("\\{", "(");
}
public static String decode(String uri) {
int i = uri.lastIndexOf(')');
return i == -1 ? uri : (uri.subSequence(0, i) + "}" + uri.substring(i + 1)).replaceFirst("\\(", "{");
}
/**
* Option to provide a custom MessageFilter. For example when you want to process your headers or attachments by
* your own.
*/
public void setMessageFilter(MessageFilter messageFilter) {
this.messageFilter = messageFilter;
}
public MessageFilter getMessageFilter() {
return messageFilter;
}
public URI getOutputAction() {
return outputAction;
}
/**
* Signifies the value for the response WS-Addressing Action
header that is provided by the method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setOutputAction(URI outputAction) {
this.outputAction = outputAction;
}
public void setOutputAction(String output) throws URISyntaxException {
if (StringUtils.hasText(output)) {
setOutputAction(new URI(output));
}
}
public URI getFaultAction() {
return faultAction;
}
/**
* Signifies the value for the faultAction response WS-Addressing Fault Action
header that is provided
* by the method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setFaultAction(String fault) throws URISyntaxException {
if (StringUtils.hasText(fault)) {
setFaultAction(new URI(fault));
}
}
/**
* Signifies the value for the faultAction response WS-Addressing Fault Action
header that is provided
* by the method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setFaultAction(URI fault) {
this.faultAction = fault;
}
public URI getFaultTo() {
return faultTo;
}
/**
* Signifies the value for the faultAction response WS-Addressing FaultTo
header that is provided by
* the method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setFaultTo(String faultTo) throws URISyntaxException {
if (StringUtils.hasText(faultTo)) {
setFaultTo(new URI(faultTo));
}
}
/**
* Signifies the value for the faultAction response WS-Addressing FaultTo
header that is provided by
* the method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setFaultTo(URI faultTo) {
this.faultTo = faultTo;
}
public URI getReplyTo() {
return replyTo;
}
/**
* Signifies the value for the replyTo response WS-Addressing ReplyTo
header that is provided by the
* method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setReplyTo(String replyToAction) throws URISyntaxException {
if (StringUtils.hasText(replyToAction)) {
setReplyTo(new URI(replyToAction));
}
}
/**
* Signifies the value for the replyTo response WS-Addressing ReplyTo
header that is provided by the
* method.
*
* See org.springframework.ws.soap.addressing.server.annotation.Action annotation for more details.
*/
public void setReplyTo(URI replyToAction) {
this.replyTo = replyToAction;
}
public WebServiceMessageSender getMessageSender() {
return messageSender;
}
/**
* Option to provide a custom WebServiceMessageSender. For example to perform authentication or use alternative
* transports
*/
public void setMessageSender(WebServiceMessageSender messageSender) {
this.messageSender = messageSender;
}
public MessageIdStrategy getMessageIdStrategy() {
return messageIdStrategy;
}
/**
* Option to provide a custom MessageIdStrategy to control generation of WS-Addressing unique message ids.
*/
public void setMessageIdStrategy(MessageIdStrategy messageIdStrategy) {
this.messageIdStrategy = messageIdStrategy;
}
public boolean isAllowResponseHeaderOverride() {
return allowResponseHeaderOverride;
}
/**
* Option to override soap response header in in/out exchange with header info from the actual service layer. If the
* invoked service appends or rewrites the soap header this option when set to true, allows the modified soap header
* to be overwritten in in/out message headers
*/
public void setAllowResponseHeaderOverride(boolean allowResponseHeaderOverride) {
this.allowResponseHeaderOverride = allowResponseHeaderOverride;
}
public boolean isAllowResponseAttachmentOverride() {
return allowResponseAttachmentOverride;
}
/**
* Option to override soap response attachments in in/out exchange with attachments from the actual service layer.
* If the invoked service appends or rewrites the soap attachments this option when set to true, allows the modified
* soap attachments to be overwritten in in/out message attachments
*/
public void setAllowResponseAttachmentOverride(boolean allowResponseAttachmentOverride) {
this.allowResponseAttachmentOverride = allowResponseAttachmentOverride;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy