| /* |
| * Copyright 2005-2006 Sun Microsystems, Inc. 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. Sun designates this |
| * particular file as subject to the "Classpath" exception as provided |
| * by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, |
| * CA 95054 USA or visit www.sun.com if you need additional information or |
| * have any questions. |
| */ |
| package com.sun.xml.internal.ws.model.wsdl; |
| |
| import com.sun.istack.internal.Nullable; |
| import com.sun.xml.internal.ws.api.model.ParameterBinding; |
| import com.sun.xml.internal.ws.api.model.wsdl.WSDLBoundOperation; |
| import com.sun.xml.internal.ws.api.model.wsdl.WSDLOperation; |
| |
| import javax.jws.WebParam.Mode; |
| import javax.jws.soap.SOAPBinding.Style; |
| import javax.xml.namespace.QName; |
| import javax.xml.stream.XMLStreamReader; |
| import java.util.HashMap; |
| import java.util.Map; |
| |
| /** |
| * Implementation of {@link WSDLBoundOperation} |
| * |
| * @author Vivek Pandey |
| */ |
| public final class WSDLBoundOperationImpl extends AbstractExtensibleImpl implements WSDLBoundOperation { |
| private final QName name; |
| |
| // map of wsdl:part to the binding |
| private final Map<String, ParameterBinding> inputParts; |
| private final Map<String, ParameterBinding> outputParts; |
| private final Map<String, ParameterBinding> faultParts; |
| private final Map<String, String> inputMimeTypes; |
| private final Map<String, String> outputMimeTypes; |
| private final Map<String, String> faultMimeTypes; |
| |
| private boolean explicitInputSOAPBodyParts = false; |
| private boolean explicitOutputSOAPBodyParts = false; |
| private boolean explicitFaultSOAPBodyParts = false; |
| |
| private Boolean emptyInputBody; |
| private Boolean emptyOutputBody; |
| private Boolean emptyFaultBody; |
| |
| private final Map<String, WSDLPartImpl> inParts; |
| private final Map<String, WSDLPartImpl> outParts; |
| private final Map<String, WSDLPartImpl> fltParts; |
| private WSDLOperationImpl operation; |
| private String soapAction; |
| private ANONYMOUS anonymous; |
| |
| private final WSDLBoundPortTypeImpl owner; |
| |
| /** |
| * |
| * @param name wsdl:operation name qualified value |
| */ |
| public WSDLBoundOperationImpl(XMLStreamReader xsr, WSDLBoundPortTypeImpl owner, QName name) { |
| super(xsr); |
| this.name = name; |
| inputParts = new HashMap<String, ParameterBinding>(); |
| outputParts = new HashMap<String, ParameterBinding>(); |
| faultParts = new HashMap<String, ParameterBinding>(); |
| inputMimeTypes = new HashMap<String, String>(); |
| outputMimeTypes = new HashMap<String, String>(); |
| faultMimeTypes = new HashMap<String, String>(); |
| inParts = new HashMap<String, WSDLPartImpl>(); |
| outParts = new HashMap<String, WSDLPartImpl>(); |
| fltParts = new HashMap<String, WSDLPartImpl>(); |
| this.owner = owner; |
| } |
| |
| public QName getName(){ |
| return name; |
| } |
| |
| public String getSOAPAction() { |
| return soapAction; |
| } |
| |
| public void setSoapAction(String soapAction) { |
| this.soapAction = soapAction!=null?soapAction:""; |
| } |
| |
| /** |
| * Gets {@link com.sun.xml.internal.ws.api.model.wsdl.WSDLPart} for the given wsdl:input or wsdl:output part |
| * |
| * @param partName must be non-null |
| * @param mode must be non-null |
| * @return null if no part is found |
| */ |
| public WSDLPartImpl getPart(String partName, Mode mode){ |
| if(mode==Mode.IN){ |
| return inParts.get(partName); |
| }else if(mode==Mode.OUT){ |
| return outParts.get(partName); |
| } |
| return null; |
| } |
| |
| public void addPart(WSDLPartImpl part, Mode mode){ |
| if(mode==Mode.IN) |
| inParts.put(part.getName(), part); |
| else if(mode==Mode.OUT) |
| outParts.put(part.getName(), part); |
| } |
| |
| /** |
| * Map of wsdl:input part name and the binding as {@link ParameterBinding} |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, ParameterBinding> getInputParts() { |
| return inputParts; |
| } |
| |
| /** |
| * Map of wsdl:output part name and the binding as {@link ParameterBinding} |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, ParameterBinding> getOutputParts() { |
| return outputParts; |
| } |
| |
| /** |
| * Map of wsdl:fault part name and the binding as {@link ParameterBinding} |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, ParameterBinding> getFaultParts() { |
| return faultParts; |
| } |
| |
| /** |
| * Map of mime:content@part and the mime type from mime:content@type for wsdl:output |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, String> getInputMimeTypes() { |
| return inputMimeTypes; |
| } |
| |
| /** |
| * Map of mime:content@part and the mime type from mime:content@type for wsdl:output |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, String> getOutputMimeTypes() { |
| return outputMimeTypes; |
| } |
| |
| /** |
| * Map of mime:content@part and the mime type from mime:content@type for wsdl:fault |
| * |
| * @return empty Map if there is no parts |
| */ |
| public Map<String, String> getFaultMimeTypes() { |
| return faultMimeTypes; |
| } |
| |
| /** |
| * Gets {@link ParameterBinding} for a given wsdl part in wsdl:input |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public ParameterBinding getInputBinding(String part){ |
| if(emptyInputBody == null){ |
| if(inputParts.get(" ") != null) |
| emptyInputBody = true; |
| else |
| emptyInputBody = false; |
| } |
| ParameterBinding block = inputParts.get(part); |
| if(block == null){ |
| if(explicitInputSOAPBodyParts || emptyInputBody) |
| return ParameterBinding.UNBOUND; |
| return ParameterBinding.BODY; |
| } |
| |
| return block; |
| } |
| |
| /** |
| * Gets {@link ParameterBinding} for a given wsdl part in wsdl:output |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public ParameterBinding getOutputBinding(String part){ |
| if(emptyOutputBody == null){ |
| if(outputParts.get(" ") != null) |
| emptyOutputBody = true; |
| else |
| emptyOutputBody = false; |
| } |
| ParameterBinding block = outputParts.get(part); |
| if(block == null){ |
| if(explicitOutputSOAPBodyParts || emptyOutputBody) |
| return ParameterBinding.UNBOUND; |
| return ParameterBinding.BODY; |
| } |
| |
| return block; |
| } |
| |
| /** |
| * Gets {@link ParameterBinding} for a given wsdl part in wsdl:fault |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public ParameterBinding getFaultBinding(String part){ |
| if(emptyFaultBody == null){ |
| if(faultParts.get(" ") != null) |
| emptyFaultBody = true; |
| else |
| emptyFaultBody = false; |
| } |
| ParameterBinding block = faultParts.get(part); |
| if(block == null){ |
| if(explicitFaultSOAPBodyParts || emptyFaultBody) |
| return ParameterBinding.UNBOUND; |
| return ParameterBinding.BODY; |
| } |
| |
| return block; |
| } |
| |
| /** |
| * Gets the MIME type for a given wsdl part in wsdl:input |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public String getMimeTypeForInputPart(String part){ |
| return inputMimeTypes.get(part); |
| } |
| |
| /** |
| * Gets the MIME type for a given wsdl part in wsdl:output |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public String getMimeTypeForOutputPart(String part){ |
| return outputMimeTypes.get(part); |
| } |
| |
| /** |
| * Gets the MIME type for a given wsdl part in wsdl:fault |
| * |
| * @param part Name of wsdl:part, must be non-null |
| * @return null if the part is not found. |
| */ |
| public String getMimeTypeForFaultPart(String part){ |
| return faultMimeTypes.get(part); |
| } |
| |
| public WSDLOperationImpl getOperation() { |
| return operation; |
| } |
| |
| public void setInputExplicitBodyParts(boolean b) { |
| explicitInputSOAPBodyParts = b; |
| } |
| |
| public void setOutputExplicitBodyParts(boolean b) { |
| explicitOutputSOAPBodyParts = b; |
| } |
| |
| public void setFaultExplicitBodyParts(boolean b) { |
| explicitFaultSOAPBodyParts = b; |
| } |
| |
| private Style style = Style.DOCUMENT; |
| public void setStyle(Style style){ |
| this.style = style; |
| } |
| |
| public @Nullable QName getPayloadName() { |
| if(style.equals(Style.RPC)){ |
| return name; |
| }else{ |
| if(emptyPayload) |
| return null; |
| |
| if(payloadName != null) |
| return payloadName; |
| |
| QName inMsgName = operation.getInput().getMessage().getName(); |
| WSDLMessageImpl message = messages.get(inMsgName); |
| for(WSDLPartImpl part:message.parts()){ |
| ParameterBinding binding = getInputBinding(part.getName()); |
| if(binding.isBody()){ |
| payloadName = part.getDescriptor().name(); |
| return payloadName; |
| } |
| } |
| |
| //Its empty payload |
| emptyPayload = true; |
| } |
| //empty body |
| return null; |
| } |
| |
| private String reqNamespace; |
| private String respNamespace; |
| |
| /** |
| * For rpclit gives namespace value on soapbinding:body@namespace |
| * |
| * @return non-null for rpclit and null for doclit |
| * @see com.sun.xml.internal.ws.model.RuntimeModeler#processRpcMethod(com.sun.xml.internal.ws.model.JavaMethodImpl, String, javax.jws.WebMethod, String, java.lang.reflect.Method, javax.jws.WebService) |
| */ |
| public String getRequestNamespace(){ |
| return reqNamespace; |
| } |
| |
| public void setRequestNamespace(String ns){ |
| reqNamespace = ns; |
| } |
| |
| |
| /** |
| * For rpclit gives namespace value on soapbinding:body@namespace |
| * |
| * @return non-null for rpclit and null for doclit |
| * * @see com.sun.xml.internal.ws.modeler.RuntimeModeler#processRpcMethod(com.sun.xml.internal.ws.model.JavaMethod, String, javax.jws.WebMethod, String, java.lang.reflect.Method, javax.jws.WebService) |
| */ |
| public String getResponseNamespace(){ |
| return respNamespace; |
| } |
| |
| public void setResponseNamespace(String ns){ |
| respNamespace = ns; |
| } |
| |
| WSDLBoundPortTypeImpl getOwner(){ |
| return owner; |
| } |
| |
| private QName payloadName; |
| private boolean emptyPayload; |
| private Map<QName, WSDLMessageImpl> messages; |
| |
| void freeze(WSDLModelImpl parent) { |
| messages = parent.getMessages(); |
| operation = owner.getPortType().get(name.getLocalPart()); |
| } |
| |
| public void setAnonymous(ANONYMOUS anonymous) { |
| this.anonymous = anonymous; |
| } |
| |
| /** |
| * @inheritDoc |
| */ |
| public ANONYMOUS getAnonymous() { |
| return anonymous; |
| } |
| } |