summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java
diff options
context:
space:
mode:
Diffstat (limited to 'sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java')
-rw-r--r--sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java209
1 files changed, 0 insertions, 209 deletions
diff --git a/sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java b/sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java
deleted file mode 100644
index a9b93ae2e8..0000000000
--- a/sca-java-2.x/tags/2.0-Beta2-RC1/modules/core/src/main/java/org/apache/tuscany/sca/core/invocation/RuntimeInvoker.java
+++ /dev/null
@@ -1,209 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
-package org.apache.tuscany.sca.core.invocation;
-
-import java.lang.reflect.InvocationTargetException;
-import java.util.UUID;
-import java.util.concurrent.ExecutorService;
-
-import org.apache.tuscany.sca.assembly.Endpoint;
-import org.apache.tuscany.sca.assembly.EndpointReference;
-import org.apache.tuscany.sca.context.ThreadMessageContext;
-import org.apache.tuscany.sca.core.ExtensionPointRegistry;
-import org.apache.tuscany.sca.core.FactoryExtensionPoint;
-import org.apache.tuscany.sca.core.UtilityExtensionPoint;
-import org.apache.tuscany.sca.interfacedef.Operation;
-import org.apache.tuscany.sca.invocation.InvocationChain;
-import org.apache.tuscany.sca.invocation.Invoker;
-import org.apache.tuscany.sca.invocation.InvokerAsyncRequest;
-import org.apache.tuscany.sca.invocation.InvokerAsyncResponse;
-import org.apache.tuscany.sca.invocation.Message;
-import org.apache.tuscany.sca.invocation.MessageFactory;
-import org.apache.tuscany.sca.runtime.Invocable;
-import org.apache.tuscany.sca.runtime.RuntimeEndpointReference;
-import org.apache.tuscany.sca.work.WorkScheduler;
-import org.oasisopen.sca.ServiceRuntimeException;
-
-/**
- * Invoker for a endpoint or endpoint reference
- * @version $Rev$ $Date$
- */
-public class RuntimeInvoker implements Invoker, InvokerAsyncRequest {
- protected ExtensionPointRegistry registry;
- protected MessageFactory messageFactory;
- protected Invocable invocable;
-
- // Run async service invocations using a ThreadPoolExecutor
- private ExecutorService theExecutor;
-
- public RuntimeInvoker(ExtensionPointRegistry registry, Invocable invocable) {
- this.registry = registry;
- this.messageFactory = registry.getExtensionPoint(FactoryExtensionPoint.class).getFactory(MessageFactory.class);
- this.invocable = invocable;
-
- UtilityExtensionPoint utilities = registry.getExtensionPoint(UtilityExtensionPoint.class);
- WorkScheduler scheduler = utilities.getUtility(WorkScheduler.class);
- theExecutor = scheduler.getExecutorService();
- }
-
- public Message invokeBinding(Message msg) {
- Message context = ThreadMessageContext.setMessageContext(msg);
- try {
- return invocable.getBindingInvocationChain().getHeadInvoker().invoke(msg);
- } finally {
- ThreadMessageContext.setMessageContext(context);
- }
- } // end method invokeBinding
-
- /**
- * Async Invoke of the Binding Chain
- * @param msg - the message to use in the invocation
- */
- public void invokeBindingAsync(Message msg) {
- Message context = ThreadMessageContext.setMessageContext(msg);
- try {
- ((InvokerAsyncRequest)invocable.getBindingInvocationChain().getHeadInvoker()).invokeAsyncRequest(msg);
- } catch (Throwable t ) {
- // TODO - consider what best to do with exception
- } finally {
- ThreadMessageContext.setMessageContext(context);
- } // end try
- } // end method invokeBindingAsync
-
- public Message invoke(Message msg) {
- return invoke(msg.getOperation(), msg);
- }
-
- public Object invoke(Operation operation, Object[] args) throws InvocationTargetException {
- Message msg = messageFactory.createMessage();
- msg.setBody(args);
- Message resp = invoke(operation, msg);
- Object body = resp.getBody();
- if (resp.isFault()) {
- throw new InvocationTargetException((Throwable)body);
- }
- return body;
- }
-
-
- public Message invoke(Operation operation, Message msg) {
- InvocationChain chain = invocable.getInvocationChain(operation);
- return invoke(chain, msg);
- }
-
- public Message invoke(InvocationChain chain, Message msg) {
-
- if (invocable instanceof Endpoint) {
- msg.setTo((Endpoint)invocable);
- } else if (invocable instanceof EndpointReference) {
- msg.setFrom((EndpointReference)invocable);
- }
-
- Invoker headInvoker = chain.getHeadInvoker();
- Operation operation = chain.getTargetOperation();
- msg.setOperation(operation);
-
- Message msgContext = ThreadMessageContext.setMessageContext(msg);
- try {
- return headInvoker.invoke(msg);
- } finally {
- ThreadMessageContext.setMessageContext(msgContext);
- }
- }
-
- /**
- * Initiate the sending of the forward part of an asynchronous
- * exchange along the request part of the wire.
- *
- * @param msg the request message
- */
- public void invokeAsync(Message msg) {
- if (invocable instanceof Endpoint) {
- Endpoint ep = (Endpoint)invocable;
- msg.setTo(ep);
- if (!ep.isAsyncInvocation()){
- throw new ServiceRuntimeException("Calling invokeAsync on a non-async endpoint - " +
- ep);
- }
- } else if (invocable instanceof EndpointReference) {
- RuntimeEndpointReference epr = (RuntimeEndpointReference)invocable;
- if (!epr.isAsyncInvocation()){
- throw new ServiceRuntimeException("Calling invokeAsync on a non-async endpoint reference - " +
- epr);
- }
- if (epr.isOutOfDate()) {
- epr.rebuild();
- }
- msg.setFrom(epr);
- msg.setTo(epr.getTargetEndpoint());
- }
-
- Operation operation = msg.getOperation();
- InvocationChain chain = invocable.getInvocationChain(operation);
-
- if (chain == null) {
- throw new IllegalArgumentException("No matching operation is found: " + operation.getName());
- }
-
- // create an async message ID if there isn't one there already
- if (!msg.getHeaders().containsKey(Constants.MESSAGE_ID)){
- msg.getHeaders().put(Constants.MESSAGE_ID, UUID.randomUUID().toString());UUID.randomUUID().toString();
- }
-
- // Perform the async invocation
- Invoker headInvoker = chain.getHeadInvoker();
-
- Message msgContext = ThreadMessageContext.setMessageContext(msg);
- try {
- try {
- ((InvokerAsyncRequest)headInvoker).invokeAsyncRequest(msg);
- } catch (ServiceRuntimeException ex) {
- throw ex;
- } catch (Throwable ex) {
- // temporary fix to swallow the dummy exception that's
- // thrown back to get past the response chain processing.
- if (!(ex instanceof AsyncResponseException)){
- throw new ServiceRuntimeException(ex);
- }
- }
- } finally {
- ThreadMessageContext.setMessageContext(msgContext);
- }
-
- return;
- }
-
- /**
- * Initiate the sending of the response part of an asynchronous
- * exchange along the response part of the wire.
- *
- * @param msg the response message
- */
- public void invokeAsyncResponse(Message msg) {
- InvocationChain chain = invocable.getInvocationChain(msg.getOperation());
- Invoker tailInvoker = chain.getTailInvoker();
- ((InvokerAsyncResponse)tailInvoker).invokeAsyncResponse(msg);
- } // end method invokeAsyncResponse
-
- @Override
- public void invokeAsyncRequest(Message msg) throws Throwable {
- invokeAsync(msg);
- } // end method invokeAsyncRequest
-}