001    /*
002     * Licensed to the Apache Software Foundation (ASF) under one or more
003     * contributor license agreements.  See the NOTICE file distributed with
004     * this work for additional information regarding copyright ownership.
005     * The ASF licenses this file to You under the Apache License, Version 2.0
006     * (the "License"); you may not use this file except in compliance with
007     * the License.  You may obtain a copy of the License at
008     *
009     *      http://www.apache.org/licenses/LICENSE-2.0
010     *
011     * Unless required by applicable law or agreed to in writing, software
012     * distributed under the License is distributed on an "AS IS" BASIS,
013     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014     * See the License for the specific language governing permissions and
015     * limitations under the License.
016     */
017    package javax.jbi.messaging;
018    
019    /**
020     * Supports operations used to process an In Optional Out MEP to completion.
021     *
022     * @author JSR208 Expert Group
023     */
024    public interface InOptionalOut extends MessageExchange {
025    
026        /**
027         * Retrieves the <i>in</i> normalized message from this exchange.
028         *
029         * @return in message
030         */
031        NormalizedMessage getInMessage();
032    
033        /**
034         * Retrieves the <i>out</i> normalized message from this exchange.
035         *
036         * @return out message
037         */
038        NormalizedMessage getOutMessage();
039        /**
040         * Sets the <i>in</i> normalized message for this exchange.
041         *
042         * @param msg in message
043         * @throws MessagingException unable to set in message
044         */
045        void setInMessage(NormalizedMessage msg) throws MessagingException;
046    
047        /**
048         * Sets the <i>out</i> normalized message for this exchange.
049         *
050         * @param msg out message
051         * @throws MessagingException unable to set out message
052         */
053        void setOutMessage(NormalizedMessage msg) throws MessagingException;
054    
055    }