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

org.apache.axis2.jaxws.message.impl.XMLPartImpl Maven / Gradle / Ivy

There is a newer version: 1.8.2
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.axis2.jaxws.message.impl;

import org.apache.axiom.attachments.Attachments;
import org.apache.axiom.om.OMElement;
import org.apache.axis2.jaxws.message.Message;
import org.apache.axis2.jaxws.message.Protocol;
import org.apache.axis2.jaxws.message.factory.SAAJConverterFactory;
import org.apache.axis2.jaxws.message.util.SAAJConverter;
import org.apache.axis2.jaxws.registry.FactoryRegistry;

import javax.xml.soap.SOAPEnvelope;
import javax.xml.ws.WebServiceException;

/**
 * XMLPartImpl
 * 

* This class extends the implementation of the XMLPartBase so that it can define the * transformations between OM, SAAJ SOAPEnvelope and XMLSpine. * * @see org.apache.axis2.jaxws.impl.XMLPartBase */ public class XMLPartImpl extends XMLPartBase { SAAJConverter converter = null; /** * XMLPart should be constructed via the XMLPartFactory. This constructor constructs an empty * XMLPart with the specified protocol * * @param protocol * @throws WebServiceException */ XMLPartImpl(Protocol protocol) throws WebServiceException { super(protocol); } /** * XMLPart should be constructed via the XMLPartFactory. This constructor creates an XMLPart from * the specified root. * * @param root * @param protocol (if null, the soap protocol is inferred from the namespace) * @throws WebServiceException */ XMLPartImpl(OMElement root, Protocol protocol) throws WebServiceException { super(root, protocol); } /** * XMLPart should be constructed via the XMLPartFactory. This constructor creates an XMLPart from * the specified root. * * @param root * @throws WebServiceException */ XMLPartImpl(SOAPEnvelope root) throws WebServiceException { super(root); } @Override protected OMElement _convertSE2OM(SOAPEnvelope se) throws WebServiceException { Attachments attachments = (parent == null) ? null : parent.attachments; return getSAAJConverter().toOM(se, attachments); } @Override protected OMElement _convertSpine2OM(XMLSpine spine) throws WebServiceException { OMElement omEnvelope = spine.getAsOMElement(); return omEnvelope; } @Override protected SOAPEnvelope _convertOM2SE(OMElement om) throws WebServiceException { return getSAAJConverter().toSAAJ((org.apache.axiom.soap.SOAPEnvelope)om); } @Override protected SOAPEnvelope _convertSpine2SE(XMLSpine spine) throws WebServiceException { return _convertOM2SE(_convertSpine2OM(spine)); } @Override protected XMLSpine _convertOM2Spine(OMElement om) throws WebServiceException { return new XMLSpineImpl((org.apache.axiom.soap.SOAPEnvelope)om, getStyle(), getIndirection(), getProtocol()); } @Override protected XMLSpine _convertSE2Spine(SOAPEnvelope se) throws WebServiceException { return _convertOM2Spine(_convertSE2OM(se)); } /** * Load the SAAJConverter * @return SAAJConverter */ protected SAAJConverter getSAAJConverter() { if (converter == null) { SAAJConverterFactory factory = ( SAAJConverterFactory)FactoryRegistry.getFactory(SAAJConverterFactory.class); converter = factory.getSAAJConverter(); } return converter; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy