/*
* Copyright 2005-2010 the original author or authors.
*
* 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.springframework.ws.soap;
import java.util.Iterator;
import javax.xml.namespace.QName;
import javax.xml.transform.Source;
/**
* The base interface for all elements that are contained in a SOAP message.
*
* @author Arjen Poutsma
* @see SoapMessage
* @since 1.0.0
*/
public interface SoapElement {
/**
* Returns the qualified name of this element.
*
* @return the qualified name of this element
*/
QName getName();
/**
* Returns the {@code Source} of this element. This includes the element itself, i.e.
* {@code SoapEnvelope.getSource()} will include the {@code Envelope} tag.
*
* @return the {@code Source} of this element
*/
Source getSource();
/**
* Adds an attribute with the specified qualified name and value to this element.
*
* @param name the qualified name of the attribute
* @param value the value of the attribute
*/
void addAttribute(QName name, String value);
/**
* Removes the attribute with the specified name.
*
* @param name the qualified name of the attribute to remove
*/
void removeAttribute(QName name);
/**
* Returns the value of the attribute with the specified qualified name.
*
* @param name the qualified name
* @return the value, or {@code null} if there is no such attribute
*/
String getAttributeValue(QName name);
/**
* Returns an {@code Iterator} over all of the attributes in element as {@link QName qualified names}.
*
* @return an iterator over all the attribute names
*/
Iterator<QName> getAllAttributes();
/**
* Adds a namespace declaration with the specified prefix and URI to this element.
*
* @param prefix the namespace prefix. Can be empty or null to declare the default namespace
* @param namespaceUri the namespace uri
* @throws SoapElementException in case of errors
*/
void addNamespaceDeclaration(String prefix, String namespaceUri);
}