/*
 * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package com.sun.xml.internal.ws.addressing;

import com.oracle.webservices.internal.api.message.BasePropertySet;
import com.sun.istack.internal.NotNull;
import com.sun.xml.internal.ws.api.SOAPVersion;
import com.sun.xml.internal.ws.api.addressing.AddressingVersion;
import com.sun.xml.internal.ws.api.addressing.WSEndpointReference;
import com.sun.xml.internal.ws.api.message.AddressingUtils;
import com.sun.xml.internal.ws.api.message.Header;
import com.sun.xml.internal.ws.api.message.Message;
import com.sun.xml.internal.ws.api.message.Packet;
import com.sun.xml.internal.ws.developer.JAXWSProperties;

import javax.xml.namespace.QName;
import javax.xml.stream.XMLStreamException;


Provides access to the Addressing headers.
Author:Kohsuke Kawaguchi, Rama Pulavarthi
Since:2.1.3
/** * Provides access to the Addressing headers. * * @author Kohsuke Kawaguchi * @author Rama Pulavarthi * @since 2.1.3 */
public class WsaPropertyBag extends BasePropertySet { public static final String WSA_REPLYTO_FROM_REQUEST = "com.sun.xml.internal.ws.addressing.WsaPropertyBag.ReplyToFromRequest"; public static final String WSA_FAULTTO_FROM_REQUEST = "com.sun.xml.internal.ws.addressing.WsaPropertyBag.FaultToFromRequest"; public static final String WSA_MSGID_FROM_REQUEST = "com.sun.xml.internal.ws.addressing.WsaPropertyBag.MessageIdFromRequest"; public static final String WSA_TO = "com.sun.xml.internal.ws.addressing.WsaPropertyBag.To"; private final @NotNull AddressingVersion addressingVersion; private final @NotNull SOAPVersion soapVersion;
We can't store Message here as those may get replaced as the packet travels through the pipeline.
/** * We can't store {@link Message} here as those may get replaced as * the packet travels through the pipeline. */
private final @NotNull Packet packet; public WsaPropertyBag(AddressingVersion addressingVersion, SOAPVersion soapVersion, Packet packet) { this.addressingVersion = addressingVersion; this.soapVersion = soapVersion; this.packet = packet; }
Gets the wsa:To header.
Returns: null if the incoming SOAP message didn't have the header.
/** * Gets the {@code wsa:To} header. * * @return * null if the incoming SOAP message didn't have the header. */
@Property(JAXWSProperties.ADDRESSING_TO) public String getTo() throws XMLStreamException { if (packet.getMessage() == null) { return null; } Header h = packet.getMessage().getHeaders().get(addressingVersion.toTag, false); if(h==null) return null; return h.getStringContent(); }
Gets the wsa:To header.
Returns: null if the incoming SOAP message didn't have the header.
/** * Gets the {@code wsa:To} header. * * @return * null if the incoming SOAP message didn't have the header. */
@Property(WSA_TO) public WSEndpointReference getToAsReference() throws XMLStreamException { if (packet.getMessage() == null) { return null; } Header h = packet.getMessage().getHeaders().get(addressingVersion.toTag, false); if(h==null) return null; return new WSEndpointReference(h.getStringContent(),addressingVersion); }
Gets the wsa:From header.
Returns: null if the incoming SOAP message didn't have the header.
/** * Gets the {@code wsa:From} header. * * @return * null if the incoming SOAP message didn't have the header. */
@Property(JAXWSProperties.ADDRESSING_FROM) public WSEndpointReference getFrom() throws XMLStreamException { return getEPR(addressingVersion.fromTag); }
Gets the wsa:Action header content as String.
Returns: null if the incoming SOAP message didn't have the header.
/** * Gets the {@code wsa:Action} header content as String. * * @return * null if the incoming SOAP message didn't have the header. */
@Property(JAXWSProperties.ADDRESSING_ACTION) public String getAction() { if (packet.getMessage() == null) { return null; } Header h = packet.getMessage().getHeaders().get(addressingVersion.actionTag, false); if(h==null) return null; return h.getStringContent(); }
Gets the wsa:MessageID header content as String.
Returns: null if the incoming SOAP message didn't have the header.
/** * Gets the {@code wsa:MessageID} header content as String. * * @return * null if the incoming SOAP message didn't have the header. */
// WsaServerTube.REQUEST_MESSAGE_ID is exposed for backward compatibility with 2.1 @Property({JAXWSProperties.ADDRESSING_MESSAGEID,WsaServerTube.REQUEST_MESSAGE_ID}) public String getMessageID() { if (packet.getMessage() == null) { return null; } return AddressingUtils.getMessageID(packet.getMessage().getHeaders(), addressingVersion,soapVersion); } private WSEndpointReference getEPR(QName tag) throws XMLStreamException { if (packet.getMessage() == null) { return null; } Header h = packet.getMessage().getHeaders().get(tag, false); if(h==null) return null; return h.readAsEPR(addressingVersion); } protected PropertyMap getPropertyMap() { return model; } private static final PropertyMap model; static { model = parse(WsaPropertyBag.class); } private WSEndpointReference _replyToFromRequest = null; @Property(WSA_REPLYTO_FROM_REQUEST) public WSEndpointReference getReplyToFromRequest() { return _replyToFromRequest; } public void setReplyToFromRequest(WSEndpointReference ref) { _replyToFromRequest = ref; } private WSEndpointReference _faultToFromRequest = null; @Property(WSA_FAULTTO_FROM_REQUEST) public WSEndpointReference getFaultToFromRequest() { return _faultToFromRequest; } public void setFaultToFromRequest(WSEndpointReference ref) { _faultToFromRequest = ref; } private String _msgIdFromRequest = null; @Property(WSA_MSGID_FROM_REQUEST) public String getMessageIdFromRequest() { return _msgIdFromRequest; } public void setMessageIdFromRequest(String id) { _msgIdFromRequest = id; } }