src/share/jaxws_classes/com/sun/xml/internal/ws/wsdl/OperationDispatcher.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, 2012, 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.wsdl;
ohair@286 27
ohair@286 28 import com.sun.istack.internal.NotNull;
ohair@286 29 import com.sun.istack.internal.Nullable;
ohair@286 30 import com.sun.xml.internal.ws.api.model.wsdl.WSDLPort;
ohair@286 31 import com.sun.xml.internal.ws.api.model.SEIModel;
alanb@368 32 import com.sun.xml.internal.ws.api.model.WSDLOperationMapping;
ohair@286 33 import com.sun.xml.internal.ws.api.WSBinding;
ohair@286 34 import com.sun.xml.internal.ws.api.message.Packet;
ohair@286 35 import com.sun.xml.internal.ws.api.message.Message;
ohair@286 36 import com.sun.xml.internal.ws.resources.ServerMessages;
ohair@286 37 import com.sun.xml.internal.ws.fault.SOAPFaultBuilder;
ohair@286 38
ohair@286 39 import javax.xml.namespace.QName;
ohair@286 40 import java.util.List;
ohair@286 41 import java.util.ArrayList;
ohair@286 42 import java.text.MessageFormat;
ohair@286 43
ohair@286 44 /**
ohair@286 45 * This class abstracts the process of identifying the wsdl operation from a SOAP Message request.
ohair@286 46 * This is primarily for dispatching the request messages to an endpoint method.
ohair@286 47 *
ohair@286 48 * Different implementations of {@link WSDLOperationFinder} are used underneath to identify the wsdl operation based on
ohair@286 49 * if AddressingFeature is enabled or not.
ohair@286 50 *
ohair@286 51 * @author Rama Pulavarthi
ohair@286 52 */
ohair@286 53 public class OperationDispatcher {
ohair@286 54 private List<WSDLOperationFinder> opFinders;
ohair@286 55 private WSBinding binding;
ohair@286 56
ohair@286 57 public OperationDispatcher(@NotNull WSDLPort wsdlModel, @NotNull WSBinding binding, @Nullable SEIModel seiModel) {
ohair@286 58 this.binding = binding;
ohair@286 59 opFinders = new ArrayList<WSDLOperationFinder>();
ohair@286 60 if (binding.getAddressingVersion() != null) {
ohair@286 61 opFinders.add(new ActionBasedOperationFinder(wsdlModel, binding, seiModel));
ohair@286 62 }
ohair@286 63 opFinders.add(new PayloadQNameBasedOperationFinder(wsdlModel, binding, seiModel));
ohair@286 64 opFinders.add(new SOAPActionBasedOperationFinder(wsdlModel, binding, seiModel));
ohair@286 65
ohair@286 66 }
ohair@286 67
ohair@286 68 /**
alanb@368 69 * @deprecated use getWSDLOperationMapping(Packet request)
ohair@286 70 * @param request Packet
ohair@286 71 * @return QName of the wsdl operation.
ohair@286 72 * @throws DispatchException if a unique operartion cannot be associated with this packet.
ohair@286 73 */
ohair@286 74 public @NotNull QName getWSDLOperationQName(Packet request) throws DispatchException {
alanb@368 75 WSDLOperationMapping m = getWSDLOperationMapping(request);
alanb@368 76 return m != null ? m.getOperationName() : null;
alanb@368 77 }
alanb@368 78
alanb@368 79 public @NotNull WSDLOperationMapping getWSDLOperationMapping(Packet request) throws DispatchException {
alanb@368 80 WSDLOperationMapping opName;
ohair@286 81 for(WSDLOperationFinder finder: opFinders) {
alanb@368 82 opName = finder.getWSDLOperationMapping(request);
ohair@286 83 if(opName != null)
ohair@286 84 return opName;
ohair@286 85 }
ohair@286 86 //No way to dispatch this request
ohair@286 87 String err = MessageFormat.format("Request=[SOAPAction={0},Payload='{'{1}'}'{2}]",
ohair@286 88 request.soapAction, request.getMessage().getPayloadNamespaceURI(),
ohair@286 89 request.getMessage().getPayloadLocalPart());
ohair@286 90 String faultString = ServerMessages.DISPATCH_CANNOT_FIND_METHOD(err);
ohair@286 91 Message faultMsg = SOAPFaultBuilder.createSOAPFaultMessage(
ohair@286 92 binding.getSOAPVersion(), faultString, binding.getSOAPVersion().faultCodeClient);
ohair@286 93 throw new DispatchException(faultMsg);
ohair@286 94 }
ohair@286 95 }

mercurial