org.apache.axis.soap.MessageFactoryImpl Maven / Gradle / Ivy
/*
 * Copyright 2002-2004 The Apache Software Foundation.
 * 
 * Licensed 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.axis.soap;
import org.apache.axis.Message;
import org.apache.axis.message.SOAPEnvelope;
import javax.xml.soap.MimeHeaders;
import javax.xml.soap.SOAPException;
import javax.xml.soap.SOAPMessage;
import java.io.IOException;
import java.io.InputStream;
/**
 * Message Factory implementation
 *
 * @author Davanum Srinivas ([email protected])
 */
public class MessageFactoryImpl extends javax.xml.soap.MessageFactory {
    /**
     * Creates a new SOAPMessage object with the
     *   default SOAPPart, SOAPEnvelope,
     *   SOAPBody, and SOAPHeader objects.
     *   Profile-specific message factories can choose to
     *   prepopulate the SOAPMessage object with
     *   profile-specific headers.
     *
     *   Content can be added to this message's 
     *   SOAPPart object, and the message can be sent "as is"
     *   when a message containing only a SOAP part is sufficient.
     *   Otherwise, the SOAPMessage object needs to
     *   create one or more AttachmentPart objects and
     *   add them to itself. Any content that is not in XML format
     *   must be in an AttachmentPart object.
     * @return  a new SOAPMessage object
     * @throws  SOAPException if a SOAP error occurs
     */
    public SOAPMessage createMessage() throws SOAPException {
        SOAPEnvelope env = new SOAPEnvelope();
        env.setSAAJEncodingCompliance(true);
        Message message = new Message(env);
        message.setMessageType(Message.REQUEST);
        return message;
    }
    /**
     * Internalizes the contents of the given 
     * InputStream object into a new SOAPMessage
     * object and returns the SOAPMessage object.
     * @param   mimeheaders    the transport-specific headers
     *     passed to the message in a transport-independent fashion
     *     for creation of the message
     * @param   inputstream    the InputStream object
     *     that contains the data for a message
     * @return a new SOAPMessage object containing the
     *     data from the given InputStream object
     * @throws  IOException    if there is a
     *     problem in reading data from the input stream
     * @throws  SOAPException  if the message is invalid
     */
    public SOAPMessage createMessage(
            MimeHeaders mimeheaders, InputStream inputstream)
            throws IOException, SOAPException {
        Message message = new Message(inputstream, false, mimeheaders);
        message.setMessageType(Message.REQUEST);
        return message;
    }
}
    © 2015 - 2025 Weber Informatics LLC | Privacy Policy