325N/A/*
325N/A * Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
325N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
325N/A *
325N/A * This code is free software; you can redistribute it and/or modify it
325N/A * under the terms of the GNU General Public License version 2 only, as
325N/A * published by the Free Software Foundation. Oracle designates this
325N/A * particular file as subject to the "Classpath" exception as provided
325N/A * by Oracle in the LICENSE file that accompanied this code.
325N/A *
325N/A * This code is distributed in the hope that it will be useful, but WITHOUT
325N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
325N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
325N/A * version 2 for more details (a copy is included in the LICENSE file that
325N/A * accompanied this code).
325N/A *
325N/A * You should have received a copy of the GNU General Public License version
325N/A * 2 along with this work; if not, write to the Free Software Foundation,
325N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
325N/A *
325N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
325N/A * or visit www.oracle.com if you need additional information or have any
325N/A * questions.
325N/A */
325N/A
325N/Apackage com.sun.xml.internal.ws.api.model;
325N/A
325N/Aimport com.sun.istack.internal.NotNull;
325N/Aimport com.sun.istack.internal.Nullable;
325N/Aimport com.sun.xml.internal.ws.api.model.soap.SOAPBinding;
325N/A
325N/Aimport javax.xml.namespace.QName;
325N/Aimport java.lang.reflect.Method;
325N/A
325N/A/**
325N/A * Abstracts the annotated {@link Method} of a SEI.
325N/A *
325N/A * @author Vivek Pandey
325N/A */
325N/Apublic interface JavaMethod {
325N/A
325N/A /**
325N/A * Gets the root {@link SEIModel} that owns this model.
325N/A */
325N/A SEIModel getOwner();
325N/A
325N/A /**
325N/A * On the server side, it uses this for invocation of the web service
325N/A *
325N/A * <p>
325N/A * {@link @WebService}(endpointInterface="I")
325N/A * class A { }
325N/A *
325N/A * In this case, it retuns A's method
325N/A *
325N/A * <p>
325N/A * {@link @WebService}(endpointInterface="I")
325N/A * class A implements I { }
325N/A * In this case, it returns A's method
325N/A *
325N/A * <p>
325N/A * {@link @WebService}
325N/A * class A { }
325N/A * In this case, it returns A's method
325N/A *
325N/A * @return Returns the java {@link Method}
325N/A */
325N/A @NotNull Method getMethod();
325N/A
325N/A
325N/A /**
325N/A * This should be used if you want to access annotations on WebMethod
325N/A * Returns the SEI method if there is one.
325N/A *
325N/A * <p>
325N/A * {@link @WebService}(endpointInterface="I")
325N/A * class A { }
325N/A * In this case, it retuns I's method
325N/A *
325N/A * <p>
325N/A * {@link @WebService}(endpointInterface="I")
325N/A * class A implements I { }
325N/A * In this case, it returns I's method
325N/A *
325N/A * <p>
325N/A * {@link @WebService}
325N/A * class A { }
325N/A * In this case, it returns A's method
325N/A *
325N/A * @return Returns the java {@link Method}
325N/A */
325N/A @NotNull Method getSEIMethod();
325N/A
325N/A /**
325N/A * @return Returns the {@link MEP}.
325N/A */
325N/A MEP getMEP();
325N/A
325N/A /**
325N/A * Binding object - a {@link SOAPBinding} isntance.
325N/A *
325N/A * @return the Binding object
325N/A */
325N/A SOAPBinding getBinding();
325N/A
325N/A /**
325N/A * Gives the wsdl:operation@name value
325N/A */
325N/A @NotNull String getOperationName();
325N/A
325N/A
325N/A /**
325N/A * Gives the request wsdl:message@name value
325N/A */
325N/A @NotNull String getRequestMessageName();
325N/A
325N/A /**
325N/A * Gives the response wsdl:messageName value
325N/A * @return null if its a oneway operation that is getMEP().isOneWay()==true.
325N/A * @see com.sun.xml.internal.ws.api.model.MEP#isOneWay()
325N/A */
325N/A @Nullable String getResponseMessageName();
325N/A
325N/A /**
325N/A * Gives soap:Body's first child's name for request message.
325N/A *
325N/A * @return
325N/A * null if this operation doesn't have any request parameter bound to the body.
325N/A */
325N/A @Nullable QName getRequestPayloadName();
325N/A
325N/A /**
325N/A * Gives soap:Body's first child's name for response message.
325N/A *
325N/A * @return
325N/A * null if this operation doesn't have any response parameter bound to the body.
325N/A */
325N/A @Nullable QName getResponsePayloadName();
325N/A
325N/A}