src/share/jaxws_classes/com/sun/xml/internal/ws/client/sei/SyncMethodHandler.java

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

author
mkos
date
Fri, 04 Oct 2013 16:21:34 +0100
changeset 408
b0610cd08440
parent 384
8f2986ff0235
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 /*
mkos@384 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.client.sei;
ohair@286 27
alanb@368 28 import com.oracle.webservices.internal.api.databinding.JavaCallInfo;
ohair@286 29 import com.sun.xml.internal.ws.api.message.Message;
ohair@286 30 import com.sun.xml.internal.ws.api.message.Packet;
ohair@286 31 import com.sun.xml.internal.ws.client.RequestContext;
ohair@286 32 import com.sun.xml.internal.ws.client.ResponseContextReceiver;
ohair@286 33 import com.sun.xml.internal.ws.encoding.soap.DeserializationException;
ohair@286 34 import com.sun.xml.internal.ws.message.jaxb.JAXBMessage;
mkos@384 35 import com.sun.xml.internal.ws.model.JavaMethodImpl;
mkos@384 36 import com.sun.xml.internal.ws.resources.DispatchMessages;
ohair@286 37
ohair@286 38 import javax.xml.bind.JAXBException;
ohair@286 39 import javax.xml.stream.XMLStreamException;
ohair@286 40 import javax.xml.ws.Holder;
mkos@384 41 import javax.xml.ws.WebServiceException;
ohair@286 42
ohair@286 43 import java.lang.reflect.Method;
ohair@286 44
ohair@286 45 /**
ohair@286 46 * {@link MethodHandler} that handles synchronous method invocations.
ohair@286 47 *
ohair@286 48 * <p>
ohair@286 49 * This class mainly performs the following two tasks:
ohair@286 50 * <ol>
ohair@286 51 * <li>Accepts Object[] that represents arguments for a Java method,
ohair@286 52 * and creates {@link JAXBMessage} that represents a request message.
ohair@286 53 * <li>Takes a {@link Message] that represents a response,
ohair@286 54 * and extracts the return value (and updates {@link Holder}s.)
ohair@286 55 * </ol>
ohair@286 56 *
ohair@286 57 * <h2>Creating {@link JAXBMessage}</h2>
ohair@286 58 * <p>
ohair@286 59 * At the construction time, we prepare {@link BodyBuilder} and {@link MessageFiller}s
ohair@286 60 * that know how to move arguments into a {@link Message}.
ohair@286 61 * Some arguments go to the payload, some go to headers, still others go to attachments.
ohair@286 62 *
ohair@286 63 * @author Kohsuke Kawaguchi
ohair@286 64 */
ohair@286 65 final class SyncMethodHandler extends MethodHandler {
mkos@384 66 final boolean isVoid;
mkos@384 67 final boolean isOneway;
mkos@384 68 final JavaMethodImpl javaMethod;
mkos@384 69 SyncMethodHandler(SEIStub owner, JavaMethodImpl jm) {
mkos@384 70 super(owner, jm.getMethod());
mkos@384 71 javaMethod = jm;
mkos@384 72 isVoid = void.class.equals(jm.getMethod().getReturnType());
mkos@384 73 isOneway = jm.getMEP().isOneWay();
ohair@286 74 }
ohair@286 75
ohair@286 76 Object invoke(Object proxy, Object[] args) throws Throwable {
ohair@286 77 return invoke(proxy,args,owner.requestContext,owner);
ohair@286 78 }
ohair@286 79
ohair@286 80 /**
ohair@286 81 * Invokes synchronously, but with the given {@link RequestContext}
ohair@286 82 * and {@link ResponseContextReceiver}.
ohair@286 83 *
ohair@286 84 * @param rc
ohair@286 85 * This {@link RequestContext} is used for invoking this method.
ohair@286 86 * We take this as a separate parameter because of the async invocation
ohair@286 87 * handling, which requires a separate copy.
ohair@286 88 */
ohair@286 89 Object invoke(Object proxy, Object[] args, RequestContext rc, ResponseContextReceiver receiver) throws Throwable {
ohair@286 90 JavaCallInfo call = owner.databinding.createJavaCallInfo(method, args);
ohair@286 91 Packet req = (Packet) owner.databinding.serializeRequest(call);
ohair@286 92 // process the message
ohair@286 93 Packet reply = owner.doProcess(req,rc,receiver);
ohair@286 94
ohair@286 95 Message msg = reply.getMessage();
mkos@384 96 if(msg == null) {
mkos@384 97 if (!isOneway || !isVoid) {
mkos@384 98 throw new WebServiceException(DispatchMessages.INVALID_RESPONSE());
mkos@384 99 }
ohair@286 100 return null;
mkos@384 101 }
ohair@286 102
ohair@286 103 try {
ohair@286 104 call = owner.databinding.deserializeResponse(reply, call);
ohair@286 105 if (call.getException() != null) {
ohair@286 106 throw call.getException();
ohair@286 107 } else {
ohair@286 108 return call.getReturnValue();
ohair@286 109 }
ohair@286 110 } catch (JAXBException e) {
mkos@384 111 throw new DeserializationException(DispatchMessages.INVALID_RESPONSE_DESERIALIZATION(), e);
ohair@286 112 } catch (XMLStreamException e) {
mkos@384 113 throw new DeserializationException(DispatchMessages.INVALID_RESPONSE_DESERIALIZATION(),e);
ohair@286 114 } finally {
mkos@384 115 if (reply.transportBackChannel != null)
mkos@384 116 reply.transportBackChannel.close();
ohair@286 117 }
ohair@286 118 }
ohair@286 119
ohair@286 120 ValueGetterFactory getValueGetterFactory() {
ohair@286 121 return ValueGetterFactory.SYNC;
ohair@286 122 }
ohair@286 123
ohair@286 124 }

mercurial