All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.model.dataformat.SoapJaxbDataFormat Maven / Gradle / Ivy

There is a newer version: 4.6.0
Show newest version
/**
 * 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.model.dataformat;

import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlTransient;

import org.apache.camel.CamelContext;
import org.apache.camel.model.DataFormatDefinition;
import org.apache.camel.spi.DataFormat;
import org.apache.camel.spi.Metadata;

/**
 * SOAP data format
 */
@Metadata(firstVersion = "2.3.0", label = "dataformat,transformation,xml", title = "SOAP")
@XmlRootElement(name = "soapjaxb")
@XmlAccessorType(XmlAccessType.FIELD)
public class SoapJaxbDataFormat extends DataFormatDefinition {
    @XmlAttribute(required = true)
    private String contextPath;
    @XmlAttribute
    private String encoding;
    @XmlAttribute
    private String elementNameStrategyRef;
    @XmlTransient
    private Object elementNameStrategy;
    @XmlAttribute @Metadata(defaultValue = "1.1")
    private String version;
    @XmlAttribute
    private String namespacePrefixRef;
    @XmlAttribute
    private String schema;

    public SoapJaxbDataFormat() {
        super("soapjaxb");
    }
    
    public SoapJaxbDataFormat(String contextPath) {
        this();
        setContextPath(contextPath);
    }
    
    public SoapJaxbDataFormat(String contextPath, String elementNameStrategyRef) {
        this();
        setContextPath(contextPath);
        setElementNameStrategyRef(elementNameStrategyRef);
    }
    
    public SoapJaxbDataFormat(String contextPath, Object elementNameStrategy) {
        this();
        setContextPath(contextPath);
        setElementNameStrategy(elementNameStrategy);
    }

    /**
     * Package name where your JAXB classes are located.
     */
    public void setContextPath(String contextPath) {
        this.contextPath = contextPath;
    }

    public String getContextPath() {
        return contextPath;
    }

    /**
     * To overrule and use a specific encoding
     */
    public void setEncoding(String encoding) {
        this.encoding = encoding;
    }

    public String getEncoding() {
        return encoding;
    }

    /**
     * Refers to an element strategy to lookup from the registry.
     * 

* An element name strategy is used for two purposes. The first is to find a xml element name for a given object * and soap action when marshaling the object into a SOAP message. The second is to find an Exception class for a given soap fault name. *

* The following three element strategy class name is provided out of the box. * QNameStrategy - Uses a fixed qName that is configured on instantiation. Exception lookup is not supported * TypeNameStrategy - Uses the name and namespace from the @XMLType annotation of the given type. If no namespace is set then package-info is used. Exception lookup is not supported * ServiceInterfaceStrategy - Uses information from a webservice interface to determine the type name and to find the exception class for a SOAP fault *

* All three classes is located in the package name org.apache.camel.dataformat.soap.name *

* If you have generated the web service stub code with cxf-codegen or a similar tool then you probably * will want to use the ServiceInterfaceStrategy. In the case you have no annotated service interface you should use QNameStrategy or TypeNameStrategy. */ public void setElementNameStrategyRef(String elementNameStrategyRef) { this.elementNameStrategyRef = elementNameStrategyRef; } public String getElementNameStrategyRef() { return elementNameStrategyRef; } public String getVersion() { return version; } /** * SOAP version should either be 1.1 or 1.2. *

* Is by default 1.1 */ public void setVersion(String version) { this.version = version; } /** * Sets an element strategy instance to use. *

* An element name strategy is used for two purposes. The first is to find a xml element name for a given object * and soap action when marshaling the object into a SOAP message. The second is to find an Exception class for a given soap fault name. *

* The following three element strategy class name is provided out of the box. * QNameStrategy - Uses a fixed qName that is configured on instantiation. Exception lookup is not supported * TypeNameStrategy - Uses the name and namespace from the @XMLType annotation of the given type. If no namespace is set then package-info is used. Exception lookup is not supported * ServiceInterfaceStrategy - Uses information from a webservice interface to determine the type name and to find the exception class for a SOAP fault *

* All three classes is located in the package name org.apache.camel.dataformat.soap.name *

* If you have generated the web service stub code with cxf-codegen or a similar tool then you probably * will want to use the ServiceInterfaceStrategy. In the case you have no annotated service interface you should use QNameStrategy or TypeNameStrategy. */ public void setElementNameStrategy(Object elementNameStrategy) { this.elementNameStrategy = elementNameStrategy; } public Object getElementNameStrategy() { return elementNameStrategy; } public String getNamespacePrefixRef() { return namespacePrefixRef; } /** * When marshalling using JAXB or SOAP then the JAXB implementation will automatic assign namespace prefixes, * such as ns2, ns3, ns4 etc. To control this mapping, Camel allows you to refer to a map which contains the desired mapping. */ public void setNamespacePrefixRef(String namespacePrefixRef) { this.namespacePrefixRef = namespacePrefixRef; } public String getSchema() { return schema; } /** * To validate against an existing schema. * Your can use the prefix classpath:, file:* or *http: to specify how the resource should by resolved. * You can separate multiple schema files by using the ',' character. */ public void setSchema(String schema) { this.schema = schema; } @Override protected void configureDataFormat(DataFormat dataFormat, CamelContext camelContext) { if (elementNameStrategy != null) { setProperty(camelContext, dataFormat, "elementNameStrategy", elementNameStrategy); } if (elementNameStrategyRef != null) { setProperty(camelContext, dataFormat, "elementNameStrategyRef", elementNameStrategyRef); } if (encoding != null) { setProperty(camelContext, dataFormat, "encoding", encoding); } if (version != null) { setProperty(camelContext, dataFormat, "version", version); } if (namespacePrefixRef != null) { setProperty(camelContext, dataFormat, "namespacePrefixRef", namespacePrefixRef); } if (schema != null) { setProperty(camelContext, dataFormat, "schema", schema); } setProperty(camelContext, dataFormat, "contextPath", contextPath); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy