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

org.apache.axis2.saaj.SOAPFactoryImpl 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.axis2.saaj;

import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axiom.om.dom.DOMMetaFactory;
import org.w3c.dom.Element;

import javax.xml.namespace.QName;
import javax.xml.soap.Detail;
import javax.xml.soap.Name;
import javax.xml.soap.SOAPConstants;
import javax.xml.soap.SOAPElement;
import javax.xml.soap.SOAPException;
import javax.xml.soap.SOAPFactory;
import javax.xml.soap.SOAPFault;
import java.util.Locale;

/**
 * 
 */
public class SOAPFactoryImpl extends SOAPFactory {
    private final DOMMetaFactory metaFactory = (DOMMetaFactory)OMAbstractFactory.getMetaFactory(OMAbstractFactory.FEATURE_DOM);

    protected String soapVersion = SOAPConstants.SOAP_1_1_PROTOCOL;

    /**
     * Create a SOAPElement object initialized with the given Name
     * object.
     *
     * @param name a Name object with the XML name for the new element
     * @return the new SOAPElement object that was created
     * @throws javax.xml.soap.SOAPException if there is an error in creating the SOAPElement
     *                                      object
     */
    public SOAPElement createElement(Name name) throws SOAPException {
        String localName = name.getLocalName();
        String prefix = name.getPrefix();
        String uri = name.getURI();
        OMElement omElement = null;
        if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) {
            omElement = metaFactory.getSOAP12Factory().createOMElement(localName
                    , uri, prefix);
        } else {
            omElement = metaFactory.getSOAP11Factory().createOMElement(localName
                    , uri, prefix);
        }
        metaFactory.getOMFactory().createOMElement(localName, uri, prefix);
        return new SOAPElementImpl(omElement);
    }

    /**
     * Create a SOAPElement object initialized with the given local name.
     *
     * @param localName a String giving the local name for the new element
     * @return the new SOAPElement object that was created
     * @throws javax.xml.soap.SOAPException if there is an error in creating the SOAPElement
     *                                      object
     */
    public SOAPElement createElement(String localName) throws SOAPException {
        OMFactory omFactory = null;
        if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) {
            omFactory = metaFactory.getSOAP12Factory();
        } else {
            omFactory = metaFactory.getSOAP11Factory();
        }
        OMElement omElement = omFactory.createOMElement(new QName(localName));
        return new SOAPElementImpl(omElement);
    }

    /**
     * Create a new SOAPElement object with the given local name, prefix and uri.
     *
     * @param localName a String giving the local name for the new element
     * @param prefix    the prefix for this SOAPElement
     * @param uri       a String giving the URI of the namespace to which the new
     *                  element belongs
     * @return the new SOAPElement object that was created
     * @throws javax.xml.soap.SOAPException if there is an error in creating the SOAPElement
     *                                      object
     */
    public SOAPElement createElement(String localName, String prefix, String uri)
            throws SOAPException {
        OMElement omElement = null;
        if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) {
            omElement = metaFactory.getSOAP12Factory().createOMElement(localName
                    , uri, prefix);
        } else {
            omElement = metaFactory.getSOAP11Factory().createOMElement(localName
                    , uri, prefix);
        }
        return new SOAPElementImpl(omElement);
    }

    /**
     * Creates a new Detail object which serves as a container for
     * DetailEntry objects.
     * 

* This factory method creates Detail objects for use in situations where it is not * practical to use the SOAPFault abstraction. * * @return a Detail object * @throws javax.xml.soap.SOAPException if there is a SOAP error */ public Detail createDetail() throws SOAPException { if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) { return new DetailImpl(metaFactory.getSOAP12Factory().createSOAPFaultDetail()); } else { return new DetailImpl(metaFactory.getSOAP11Factory().createSOAPFaultDetail()); } } /** * Creates a new Name object initialized with the given local name, namespace * prefix, and namespace URI. *

* This factory method creates Name objects for use in situations where it is not * practical to use the SOAPEnvelope abstraction. * * @param localName a String giving the local name * @param prefix a String giving the prefix of the namespace * @param uri a String giving the URI of the namespace * @return a Name object initialized with the given local name, namespace prefix, * and namespace URI * @throws javax.xml.soap.SOAPException if there is a SOAP error */ public Name createName(String localName, String prefix, String uri) throws SOAPException { return new PrefixedQName(uri, localName, prefix); } /** * Creates a new Name object initialized with the given local name. *

* This factory method creates Name objects for use in situations where it is not * practical to use the SOAPEnvelope abstraction. * * @param localName a String giving the local name * @return a Name object initialized with the given local name * @throws javax.xml.soap.SOAPException if there is a SOAP error */ public Name createName(String localName) throws SOAPException { return new PrefixedQName(null, localName, null); } /** * Creates a new default SOAPFault object * * @return a SOAPFault object * @throws SOAPException - if there is a SOAP error */ public SOAPFault createFault() throws SOAPException { org.apache.axiom.soap.SOAPFactory soapFactory; if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) { soapFactory = metaFactory.getSOAP12Factory(); return new SOAPFaultImpl(soapFactory.createSOAPFault()); } else { soapFactory = metaFactory.getSOAP11Factory(); return new SOAPFaultImpl(soapFactory.createSOAPFault()); } } /** * Creates a new SOAPFault object initialized with the given reasonText and faultCode * * @param reasonText - the ReasonText/FaultString for the fault faultCode - the FaultCode for * the fault * @return: a SOAPFault object * @throws: SOAPException - if there is a SOAP error */ public SOAPFault createFault(String reasonText, QName faultCode) throws SOAPException { SOAPFault soapFault; if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) { soapFault = new SOAPFaultImpl(metaFactory.getSOAP12Factory() .createSOAPFault()); } else { soapFault = new SOAPFaultImpl(metaFactory.getSOAP11Factory() .createSOAPFault()); } soapFault.setFaultCode(faultCode); try { soapFault.addFaultReasonText(reasonText, Locale.getDefault()); } catch (UnsupportedOperationException e) { throw new SOAPException(e.getMessage()); } return soapFault; } public void setSOAPVersion(String soapVersion) { this.soapVersion = soapVersion; } public SOAPElement createElement(QName qname) throws SOAPException { String localName = qname.getLocalPart(); String prefix = qname.getPrefix(); String uri = qname.getNamespaceURI(); OMElement omElement = metaFactory.getOMFactory().createOMElement(localName , uri, prefix); return new SOAPElementImpl(omElement); } public SOAPElement createElement(Element element) throws SOAPException { OMFactory omFactory = null; if (soapVersion.equals(SOAPConstants.SOAP_1_2_PROTOCOL)) { omFactory = metaFactory.getSOAP12Factory(); } else { omFactory = metaFactory.getSOAP11Factory(); } String prefix = element.getPrefix(); if (prefix == null) { prefix = ""; } OMNamespace ns = omFactory.createOMNamespace(element.getNamespaceURI(), prefix); OMElement omElement = omFactory.createOMElement(element.getLocalName(), ns); return new SOAPElementImpl(omElement); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy