src/share/jaxws_classes/com/sun/xml/internal/ws/binding/SOAPBindingImpl.java

Fri, 04 Oct 2013 16:21:34 +0100

author
mkos
date
Fri, 04 Oct 2013 16:21:34 +0100
changeset 408
b0610cd08440
parent 368
0989ad8c0860
child 637
9c07ef4934dd
permissions
-rw-r--r--

8025054: Update JAX-WS RI integration to 2.2.9-b130926.1035
Reviewed-by: chegar

ohair@286 1 /*
alanb@368 2 * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
ohair@286 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
ohair@286 4 *
ohair@286 5 * This code is free software; you can redistribute it and/or modify it
ohair@286 6 * under the terms of the GNU General Public License version 2 only, as
ohair@286 7 * published by the Free Software Foundation. Oracle designates this
ohair@286 8 * particular file as subject to the "Classpath" exception as provided
ohair@286 9 * by Oracle in the LICENSE file that accompanied this code.
ohair@286 10 *
ohair@286 11 * This code is distributed in the hope that it will be useful, but WITHOUT
ohair@286 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
ohair@286 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
ohair@286 14 * version 2 for more details (a copy is included in the LICENSE file that
ohair@286 15 * accompanied this code).
ohair@286 16 *
ohair@286 17 * You should have received a copy of the GNU General Public License version
ohair@286 18 * 2 along with this work; if not, write to the Free Software Foundation,
ohair@286 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
ohair@286 20 *
ohair@286 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
ohair@286 22 * or visit www.oracle.com if you need additional information or have any
ohair@286 23 * questions.
ohair@286 24 */
ohair@286 25
ohair@286 26 package com.sun.xml.internal.ws.binding;
ohair@286 27
ohair@286 28 import com.sun.istack.internal.NotNull;
ohair@286 29 import com.sun.xml.internal.ws.api.BindingID;
ohair@286 30 import com.sun.xml.internal.ws.api.SOAPVersion;
ohair@286 31 import com.sun.xml.internal.ws.client.HandlerConfiguration;
ohair@286 32 import com.sun.xml.internal.ws.encoding.soap.streaming.SOAP12NamespaceConstants;
ohair@286 33 import com.sun.xml.internal.ws.resources.ClientMessages;
ohair@286 34
ohair@286 35 import javax.xml.namespace.QName;
ohair@286 36 import javax.xml.soap.MessageFactory;
ohair@286 37 import javax.xml.soap.SOAPFactory;
ohair@286 38
ohair@286 39 import javax.xml.ws.WebServiceException;
ohair@286 40 import javax.xml.ws.WebServiceFeature;
ohair@286 41 import javax.xml.ws.handler.Handler;
ohair@286 42 import javax.xml.ws.soap.MTOMFeature;
ohair@286 43 import javax.xml.ws.soap.SOAPBinding;
ohair@286 44 import java.util.*;
ohair@286 45
ohair@286 46 /**
ohair@286 47 * @author WS Development Team
ohair@286 48 */
ohair@286 49 public final class SOAPBindingImpl extends BindingImpl implements SOAPBinding {
ohair@286 50
ohair@286 51 public static final String X_SOAP12HTTP_BINDING =
ohair@286 52 "http://java.sun.com/xml/ns/jaxws/2003/05/soap/bindings/HTTP/";
ohair@286 53
ohair@286 54 private static final String ROLE_NONE = SOAP12NamespaceConstants.ROLE_NONE;
ohair@286 55 //protected boolean enableMtom;
ohair@286 56 protected final SOAPVersion soapVersion;
ohair@286 57
ohair@286 58 private Set<QName> portKnownHeaders = Collections.emptySet();
ohair@286 59 private Set<QName> bindingUnderstoodHeaders = new HashSet<QName>();
ohair@286 60
ohair@286 61 /**
ohair@286 62 * Use {@link BindingImpl#create(BindingID)} to create this.
ohair@286 63 *
ohair@286 64 * @param bindingId SOAP binding ID
ohair@286 65 */
ohair@286 66 SOAPBindingImpl(BindingID bindingId) {
ohair@286 67 this(bindingId,EMPTY_FEATURES);
ohair@286 68 }
ohair@286 69
ohair@286 70 /**
ohair@286 71 * Use {@link BindingImpl#create(BindingID)} to create this.
ohair@286 72 *
ohair@286 73 * @param bindingId binding id
ohair@286 74 * @param features
ohair@286 75 * These features have a precedence over
ohair@286 76 * {@link BindingID#createBuiltinFeatureList() the implicit features}
ohair@286 77 * associated with the {@link BindingID}.
ohair@286 78 */
ohair@286 79 SOAPBindingImpl(BindingID bindingId, WebServiceFeature... features) {
ohair@286 80 super(bindingId, features);
ohair@286 81 this.soapVersion = bindingId.getSOAPVersion();
ohair@286 82 //populates with required roles and updates handlerConfig
ohair@286 83 setRoles(new HashSet<String>());
ohair@286 84 //Is this still required? comment out for now
ohair@286 85 //setupSystemHandlerDelegate(serviceName);
ohair@286 86
ohair@286 87 this.features.addAll(bindingId.createBuiltinFeatureList());
ohair@286 88 }
ohair@286 89
ohair@286 90 /**
ohair@286 91 * This method should be called if the binding has SOAPSEIModel
ohair@286 92 * The Headers understood by the Port are set, so that they can be used for MU
ohair@286 93 * processing.
ohair@286 94 *
ohair@286 95 * @param headers SOAP header names
ohair@286 96 */
ohair@286 97 public void setPortKnownHeaders(@NotNull Set<QName> headers) {
ohair@286 98 this.portKnownHeaders = headers;
ohair@286 99 }
ohair@286 100
ohair@286 101 /**
ohair@286 102 * TODO A feature should be created to configure processing of MU headers.
ohair@286 103 * @param header
ohair@286 104 * @return
ohair@286 105 */
ohair@286 106 public boolean understandsHeader(QName header) {
ohair@286 107 return serviceMode == javax.xml.ws.Service.Mode.MESSAGE
ohair@286 108 || portKnownHeaders.contains(header)
ohair@286 109 || bindingUnderstoodHeaders.contains(header);
ohair@286 110
ohair@286 111 }
ohair@286 112
ohair@286 113 /**
ohair@286 114 * Sets the handlers on the binding and then sorts the handlers in to logical and protocol handlers.
ohair@286 115 * Creates a new HandlerConfiguration object and sets it on the BindingImpl. Also parses Headers understood by
ohair@286 116 * Protocol Handlers and sets the HandlerConfiguration.
ohair@286 117 */
ohair@286 118 public void setHandlerChain(List<Handler> chain) {
alanb@368 119 setHandlerConfig(new HandlerConfiguration(getHandlerConfig().getRoles(), chain));
ohair@286 120 }
ohair@286 121
ohair@286 122 protected void addRequiredRoles(Set<String> roles) {
ohair@286 123 roles.addAll(soapVersion.requiredRoles);
ohair@286 124 }
ohair@286 125
ohair@286 126 public Set<String> getRoles() {
alanb@368 127 return getHandlerConfig().getRoles();
ohair@286 128 }
ohair@286 129
ohair@286 130 /**
ohair@286 131 * Adds the next and other roles in case this has
ohair@286 132 * been called by a user without them.
ohair@286 133 * Creates a new HandlerConfiguration object and sets it on the BindingImpl.
ohair@286 134 */
ohair@286 135 public void setRoles(Set<String> roles) {
ohair@286 136 if (roles == null) {
ohair@286 137 roles = new HashSet<String>();
ohair@286 138 }
ohair@286 139 if (roles.contains(ROLE_NONE)) {
ohair@286 140 throw new WebServiceException(ClientMessages.INVALID_SOAP_ROLE_NONE());
ohair@286 141 }
ohair@286 142 addRequiredRoles(roles);
alanb@368 143 setHandlerConfig(new HandlerConfiguration(roles, getHandlerConfig()));
ohair@286 144 }
ohair@286 145
ohair@286 146
ohair@286 147 /**
ohair@286 148 * Used typically by the runtime to enable/disable Mtom optimization
ohair@286 149 */
ohair@286 150 public boolean isMTOMEnabled() {
ohair@286 151 return isFeatureEnabled(MTOMFeature.class);
ohair@286 152 }
ohair@286 153
ohair@286 154 /**
ohair@286 155 * Client application can override if the MTOM optimization should be enabled
ohair@286 156 */
ohair@286 157 public void setMTOMEnabled(boolean b) {
ohair@286 158 features.setMTOMEnabled(b);
ohair@286 159 }
ohair@286 160
ohair@286 161 public SOAPFactory getSOAPFactory() {
ohair@286 162 return soapVersion.getSOAPFactory();
ohair@286 163 }
ohair@286 164
ohair@286 165 public MessageFactory getMessageFactory() {
ohair@286 166 return soapVersion.getMessageFactory();
ohair@286 167 }
ohair@286 168
ohair@286 169 }

mercurial