com.sun.xml.ws.security.opt.impl.message.SecurityHeaderWrapper Maven / Gradle / Ivy
Show all versions of webservices-osgi Show documentation
/*
* Copyright (c) 1997, 2022 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Distribution License v. 1.0, which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*/
package com.sun.xml.ws.security.opt.impl.message;
import com.sun.xml.ws.api.addressing.AddressingVersion;
import com.sun.xml.ws.api.addressing.WSEndpointReference;
import com.sun.xml.ws.security.opt.impl.outgoing.SecurityHeader;
import com.sun.xml.ws.spi.db.XMLBridge;
import com.sun.istack.NotNull;
import com.sun.xml.ws.api.SOAPVersion;
import org.xml.sax.ContentHandler;
import org.xml.sax.ErrorHandler;
import jakarta.xml.bind.Unmarshaller;
import javax.xml.namespace.QName;
import jakarta.xml.soap.SOAPException;
import jakarta.xml.soap.SOAPMessage;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import javax.xml.stream.XMLStreamWriter;
import java.util.Set;
/**
*
* @author [email protected]
*/
public class SecurityHeaderWrapper implements com.sun.xml.ws.api.message.Header {
private SecurityHeader sh;
/** Creates a new instance of HeaderWrapper */
public SecurityHeaderWrapper(SecurityHeader sh) {
this.sh = sh;
}
/**
* Checks if this header is ignorable for us (IOW, make sure
* that this header has a problematic "mustUnderstand" header value
* that we have to reject.)
*
*
* This method is used as a part of the
* mustUnderstanx processing.
* At the end of the processing, the JAX-WS identifies a list of {@link Header}s
* that were not understood. This method is invoked on those {@link Header}s,
* to verify that we don't need to report an error for it.
*
*
* specifically, this method has to perform the following tasks:
*
*
* - If this header does not have
mustUnderstand
as "1" nor "true",
* then this method must return true.
* - Otherwise, check the role attribute (for SOAP 1.2) or the actor attribute (for SOAP 1.1).
* When those attributes are absent, the default values have to be assumed.
* See {@link #getRole(SOAPVersion)} for how the values are defaulted.
* Now, see if the {@code roles} set contains the value.
* If so, this method must return false (indicating that an error is in order.)
*
- Otherwise return true (since we don't play the role this header is intended for.)
*
*
* @param soapVersion
* The caller specifies the SOAP version that the pipeline is working against.
* Often each {@link Header} implementation already knows the SOAP version
* anyway, but this allows some {@link Header}s to avoid keeping it.
* That's why this redundant parameter is passed in.
* @param roles
* The set of role values that the current JAX-WS pipeline is assuming.
* Note that SOAP 1.1 and SOAP 1.2 use different strings for the same role,
* and the caller is responsible for supplying a proper value depending on the
* active SOAP version in use.
*
* @return
* true if no error needs to be reported. False if an error needs to be raised.
* See the method javadoc for more discussion.
*/
@Override
public boolean isIgnorable(SOAPVersion soapVersion, Set roles){
throw new UnsupportedOperationException();
}
/**
* Gets the value of the soap:role attribute (or soap:actor for SOAP 1.1).
*
*
* If the attribute is omitted, the value defaults to {@link SOAPVersion#implicitRole}.
*
* @param soapVersion
* The caller specifies the SOAP version that the pipeline is working against.
* Often each {@link Header} implementation already knows the SOAP version
* anyway, but this allows some {@link Header}s to avoid keeping it.
* That's why this redundant parameter is passed in.
* @return
* never null. This string need not be interned.
*/
@Override
public String getRole(SOAPVersion soapVersion){
throw new UnsupportedOperationException();
}
/**
* True if this header is to be relayed if not processed.
* For SOAP 1.1 messages, this method always return false.
*
*
* IOW, this method returns true if there's @soap:relay='true'
* is present.
*
*
Implementation Note
*
* The implementation needs to check for both "true" and "1",
* but because attribute values are normalized, it doesn't have
* to consider " true", " 1 ", and so on.
*
* @return
* false.
*/
@Override
public boolean isRelay(){
throw new UnsupportedOperationException();
}
/**
* Gets the namespace URI of this header element.
*
* @return
* this string must be interned.
*/
@Override
public String getNamespaceURI(){
return sh.getNamespaceURI();
}
/**
* Gets the local name of this header element.
*
* @return
* this string must be interned.
*/
@Override
public String getLocalPart(){
return sh.getLocalPart();
}
/**
* Gets the attribute value on the header element.
*
* @param nsUri
* The namespace URI of the attribute. Can be empty.
* @param localName
* The local name of the attribute.
*
* @return
* if the attribute is found, return the whitespace normalized value.
* (meaning no leading/trailing space, no consequtive whitespaces in-between.)
* Otherwise null. Note that the XML parsers are responsible for
* whitespace-normalizing attributes, so {@link Header} implementation
* doesn't have to do anything.
*/
@Override
public String getAttribute(String nsUri, String localName){
throw new UnsupportedOperationException();
}
/**
* Gets the attribute value on the header element.
*
*
* This is a convenience method that calls into {@link #getAttribute(String, String)}
*
* @param name
* Never null.
*
* @see #getAttribute(String, String)
*/
@Override
public String getAttribute(QName name){
throw new UnsupportedOperationException();
}
/**
* Reads the header as a {@link XMLStreamReader}.
*
*
* The returned parser points at the start element of this header.
* (IOW, {@link XMLStreamReader#getEventType()} would return
* {@link XMLStreamReader#START_ELEMENT}.
*
*
Performance Expectation
*
* For some {@link Header} implementations, this operation
* is a non-trivial operation. Therefore, use of this method
* is discouraged unless the caller is interested in reading
* the whole header.
*
*
* Similarly, if the caller wants to use this method only to do
* the API conversion (such as simply firing SAX events from
* {@link XMLStreamReader}), then the JAX-WS team requests
* that you talk to us.
*
*
* Messages that come from tranport usually provides
* a reasonably efficient implementation of this method.
*
* @return
* must not null.
*/
@Override
public XMLStreamReader readHeader() {
throw new UnsupportedOperationException();
//We should avoid such operations for Security operated headers.
}
/**
* Reads the header as a JAXB object by using the given unmarshaller.
*/
@Override
public T readAsJAXB(Unmarshaller unmarshaller) {
throw new UnsupportedOperationException();
}
/**
* Writes out the header.
*
* @throws XMLStreamException
* if the operation fails for some reason. This leaves the
* writer to an undefined state.
*/
@Override
public void writeTo(XMLStreamWriter w) throws XMLStreamException{
sh.writeTo(w);
}
/**
* Writes out the header to the given SOAPMessage.
*
*
* Sometimes a Message needs to produce itself
* as {@link SOAPMessage}, in which case each header needs
* to turn itself into a header.
*
* @throws SOAPException
* if the operation fails for some reason. This leaves the
* writer to an undefined state.
*/
@Override
public void writeTo(SOAPMessage saaj) throws SOAPException{
throw new UnsupportedOperationException("use writeTo(XMLStreamWriter w) ");
}
/**
* Writes out the header as SAX events.
*
*
* Sometimes a Message needs to produce SAX events,
* and this method is necessary for headers to participate to it.
*
*
* A header is responsible for producing the SAX events for its part,
* including startPrefixMapping
and endPrefixMapping
,
* but not startDocument/endDocument.
*
*
* Note that SAX contract requires that any error that does NOT originate
* from {@link ContentHandler} (meaning any parsing error and etc) must
* be first reported to {@link ErrorHandler}. If the SAX event production
* cannot be continued and the processing needs to abort, the code may
* then throw the same SAXParseException reported to {@link ErrorHandler}.
*
* @param contentHandler
* The {@link ContentHandler} that receives SAX events.
*
* @param errorHandler
* The {@link ErrorHandler} that receives parsing errors.
*/
@Override
public void writeTo(ContentHandler contentHandler, ErrorHandler errorHandler) {
throw new UnsupportedOperationException("use writeTo(XMLStreamWriter w) ");
}
@Override
public String getStringContent(){
throw new UnsupportedOperationException();
}
@Override
public @NotNull WSEndpointReference readAsEPR(AddressingVersion expected) {
throw new UnsupportedOperationException();
}
@Override
public T readAsJAXB(XMLBridge arg0) {
throw new UnsupportedOperationException();
}
}