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

org.apache.axiom.om.ds.custombuilder.CustomBuilder Maven / Gradle / Ivy

There is a newer version: 5.0.22
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.axiom.om.ds.custombuilder;

import org.apache.axiom.om.OMContainer;
import org.apache.axiom.om.OMDataSource;
import org.apache.axiom.om.OMDocument;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMException;
import org.apache.axiom.om.OMSourcedElement;
import org.apache.axiom.om.OMXMLParserWrapper;
import org.apache.axiom.soap.SOAPBody;

import javax.xml.stream.XMLStreamWriter;

/**
 * A Custom Builder is registered on the {@link OMXMLParserWrapper} for a particular set of elements.
 * When a matching element is encountered, the CustomBuilder will build an {@link OMDataSource}
 * for the builder.
 *
 * @see CustomBuilderSupport#registerCustomBuilder(CustomBuilder.Selector, CustomBuilder)
 */
public interface CustomBuilder {
    /**
     * Selects the elements to which a custom builder is applied. Note that this interface may be
     * implemented by the {@link CustomBuilder} itself.
     */
    public interface Selector {
        /**
         * Selects the message payload element. For plain XML documents, that is the document
         * element. For SOAP messages, that is the child element of the SOAP body.
         */
        Selector PAYLOAD = new Selector() {
            @Override
            public boolean accepts(OMContainer parent, int depth, String namespaceURI, String localName) {
                // Note: usage of SOAPBody here may create a package cycle, but that cycle could easily
                // be broken by introducing a marker interface to be extended by SOAPBody.
                return parent instanceof OMDocument || parent instanceof SOAPBody;
            }
        };
        
        /**
         * Check if the custom builder registered with this selector should be applied to the given
         * element. Note that this method will only be invoked for elements that can be represented
         * as {@link OMSourcedElement} instances in the object model. For plain XML documents this
         * means every element, but for SOAP messages this restricts the set of elements. E.g. this
         * method will never be invoked for SOAP faults.
         * 
         * @param parent
         *            the parent of the {@link OMElement} to be built
         * @param depth
         *            the depth of the element (with the root element having depth 1)
         * @param namespaceURI
         *            the namespace URI of the element; never {@code null}
         * @param localName
         *            the local name of the element; never {@code null}
         * @return {@code true} if the element should be built as an {@link OMSourcedElement} using
         *         the custom builder registered with this selector, in which case
         *         {@link CustomBuilder#create(OMElement)} will be called to create the
         *         corresponding {@link OMDataSource}; {@code false} otherwise
         */
        boolean accepts(OMContainer parent, int depth, String namespaceURI, String localName);
    }
    
    /**
     * Create an {@link OMDataSource} from the given {@link OMElement}. The builder will use the
     * returned {@link OMDataSource} to create an {@link OMSourcedElement} replacing the original
     * {@link OMElement}.
     * 
     * @param element
     *            The element to convert into an {@link OMDataSource}. The implementation is
     *            expected to consume the element using methods such as
     *            {@link OMContainer#getXMLStreamReader(boolean)},
     *            {@link OMContainer#getSAXSource(boolean)} or
     *            {@link OMContainer#serialize(XMLStreamWriter, boolean)} with
     *            {@code preserve=true}.
     * @return an {@link OMDataSource} with content that is equivalent to the original element
     */
    public OMDataSource create(OMElement element) throws OMException;
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy