org.apache.axis2.jaxws.message.impl.XMLPartImpl 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.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