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 org.apache.camel.component.cxf;
018    
019    /**
020     * The data format the user expects to see at the Camel CXF components.  It can be
021     * configured as a property (DataFormat) in the Camel CXF endpoint.
022     */
023    public enum DataFormat {
024    
025        /**
026         * PAYLOAD is the message payload of the message after message configured in
027         * the CXF endpoint is applied.  Streaming and non-streaming are both
028         * supported.
029         */
030        PAYLOAD,
031    
032        /**
033         * MESSAGE is the raw message that is received from the transport layer.
034         * Streaming and non-streaming are both supported.
035         */
036        MESSAGE,
037    
038        /**
039         * POJOs (Plain old Java objects) are the Java parameters to the method
040         * it is invoking on the target server.  The "serviceClass" property
041         * must be included in the endpoint.  Streaming is not available for this
042         * data format.
043         */
044        POJO
045        
046    }