diff options
author | lresende <lresende@13f79535-47bb-0310-9956-ffa450edef68> | 2013-10-07 22:23:21 +0000 |
---|---|---|
committer | lresende <lresende@13f79535-47bb-0310-9956-ffa450edef68> | 2013-10-07 22:23:21 +0000 |
commit | 5963a2d3d6860fe57afc138f095bf2d2eb5a7b80 (patch) | |
tree | 018d3d8c637e265b8292d34e5f7c11ca8ce11b7d /sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java | |
parent | 132aa8a77685ec92bc90c03f987650d275a7b639 (diff) |
Official Tuscany 2.0.1 Release
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1530096 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java')
-rw-r--r-- | sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java | 254 |
1 files changed, 0 insertions, 254 deletions
diff --git a/sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java b/sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java deleted file mode 100644 index ca21599b14..0000000000 --- a/sca-java-2.x/tags/2.0.1-RC1/modules/binding-jsonrpc-runtime/src/main/java/org/apache/tuscany/sca/binding/jsonrpc/provider/JsonRpcInvoker.java +++ /dev/null @@ -1,254 +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.binding.jsonrpc.provider; - -import java.io.IOException; -import java.io.OutputStream; -import java.lang.reflect.Constructor; -import java.lang.reflect.Method; -import java.lang.reflect.Type; -import java.util.List; -import java.util.UUID; - -import org.apache.http.HttpEntity; -import org.apache.http.HttpResponse; -import org.apache.http.HttpStatus; -import org.apache.http.client.HttpClient; -import org.apache.http.client.methods.HttpPost; -import org.apache.http.entity.ContentProducer; -import org.apache.http.entity.EntityTemplate; -import org.apache.http.entity.StringEntity; -import org.apache.http.util.EntityUtils; -import org.apache.tuscany.sca.assembly.EndpointReference; -import org.apache.tuscany.sca.binding.jsonrpc.JSONRPCBinding; -import org.apache.tuscany.sca.binding.jsonrpc.protocol.JsonRpc10Request; -import org.apache.tuscany.sca.binding.jsonrpc.protocol.JsonRpc20Request; -import org.apache.tuscany.sca.binding.jsonrpc.protocol.JsonRpcRequest; -import org.apache.tuscany.sca.databinding.json.JSONDataBinding; -import org.apache.tuscany.sca.databinding.json.jackson.JacksonHelper; -import org.apache.tuscany.sca.interfacedef.DataType; -import org.apache.tuscany.sca.interfacedef.Operation; -import org.apache.tuscany.sca.interfacedef.java.JavaOperation; -import org.apache.tuscany.sca.invocation.DataExchangeSemantics; -import org.apache.tuscany.sca.invocation.Invoker; -import org.apache.tuscany.sca.invocation.Message; -import org.codehaus.jackson.JsonNode; -import org.codehaus.jackson.map.ObjectMapper; -import org.codehaus.jackson.map.type.TypeFactory; -import org.codehaus.jackson.node.NullNode; -import org.codehaus.jackson.node.ObjectNode; -import org.oasisopen.sca.ServiceRuntimeException; - -/** - * Invoker for the JSONRPC Binding - * - * @version $Rev$ $Date$ - */ -public class JsonRpcInvoker implements Invoker, DataExchangeSemantics { - private EndpointReference endpointReference; - private Operation operation; - private String uri; - private HttpClient httpClient; - - public JsonRpcInvoker(EndpointReference endpointReference, Operation operation, HttpClient httpClient) { - this.endpointReference = endpointReference; - this.operation = operation; - this.uri = endpointReference.getDeployedURI(); - this.httpClient = httpClient; - } - - public Message invoke(Message msg) { - HttpPost post = null; - HttpResponse response = null; - try { - String requestId = UUID.randomUUID().toString(); - post = new HttpPost(uri); - HttpEntity entity = null; - Object[] args = msg.getBody(); - final String db = msg.getOperation().getInputWrapper().getDataBinding(); - - if (!db.equals(JSONDataBinding.NAME)) { - Object[] params = new Object[0]; - // Extract the arguments - args = msg.getBody(); - - if (args instanceof Object[]) { - params = (Object[])args; - } - - JsonRpcRequest req = null; - if (JSONRPCBinding.VERSION_20.equals(((JSONRPCBinding)endpointReference.getBinding()).getVersion())) { - req = new JsonRpc20Request(requestId, msg.getOperation().getName(), params); - } else { - req = new JsonRpc10Request(requestId, msg.getOperation().getName(), params); - } - final JsonRpcRequest json = req; - - // Create content producer so that we can stream the json result out - ContentProducer cp = new ContentProducer() { - public void writeTo(OutputStream outstream) throws IOException { - // mapper.writeValue(outstream, req.toJSONObject().toString()); - try { - json.write(outstream); - } catch (Exception e) { - throw new IOException(e); - } - } - }; - entity = new EntityTemplate(cp); - } else { - // Single string argument - entity = new StringEntity((String)args[0], "UTF-8"); - } - - post.setEntity(entity); - - response = httpClient.execute(post); - - if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { - //success - - entity = response.getEntity(); - String entityResponse = EntityUtils.toString(entity); - entity.consumeContent(); - if (!db.equals(JSONDataBinding.NAME)) { - ObjectNode jsonResponse = (ObjectNode)JacksonHelper.MAPPER.readTree(entityResponse); - - if (jsonResponse.has("error") && jsonResponse.get("error") != NullNode.instance) { - processException(jsonResponse); - } - DataType<List<DataType>> outputType = operation.getOutputType(); - DataType returnType = - (outputType != null && !outputType.getLogical().isEmpty()) ? outputType.getLogical().get(0) - : null; - - if (returnType == null) { - msg.setBody(null); - return msg; - } - - //check requestId - if (!requestId.equalsIgnoreCase(jsonResponse.get("id").getTextValue())) { - throw new ServiceRuntimeException("Invalid response id:" + requestId); - } - - JsonNode rawResult = jsonResponse.get("result"); - - Class<?> returnClass = returnType.getPhysical(); - Type genericReturnType = returnType.getGenericType(); - - ObjectMapper mapper = createObjectMapper(returnClass); - String json = mapper.writeValueAsString(rawResult); - - Object body = mapper.readValue(json, TypeFactory.type(genericReturnType)); - - msg.setBody(body); - } else { - msg.setBody(entityResponse); - } - - } else { - // Consume the content so the connection can be released - response.getEntity().consumeContent(); - throw new ServiceRuntimeException("Abnormal HTTP response: " + response.getStatusLine().toString()); - } - } catch (RuntimeException e) { - throw e; - } catch (Error e) { - throw e; - } catch (Exception e) { - // e.printStackTrace(); - msg.setFaultBody(e); - } catch (Throwable e) { - throw new ServiceRuntimeException(e); - } - - return msg; - } - - public static ObjectMapper createObjectMapper(Class<?> cls) { - return JacksonHelper.createObjectMapper(cls); - } - - private String opt(ObjectNode node, String name) { - JsonNode value = node.get(name); - if (value == null) { - return null; - } else { - return value.getValueAsText(); - } - } - - /** - * Generate and throw exception based on the data in the 'responseMessage' - */ - protected void processException(ObjectNode responseMessage) throws Throwable { - // FIXME: We need to find a way to build Java exceptions out of the json-rpc error - JsonNode error = responseMessage.get("error"); - if (error != null) { - Object data = error.get("data"); - if (data instanceof ObjectNode) { - ObjectNode fault = (ObjectNode)data; - String javaClass = opt(fault, "class"); - String message = opt(fault, "message"); - String stackTrace = opt(fault, "stackTrace"); - if (javaClass != null) { - if (stackTrace != null) { - message = message + "\n" + stackTrace; - } - ClassLoader classLoader = Thread.currentThread().getContextClassLoader(); - if (operation instanceof JavaOperation) { - Method method = ((JavaOperation)operation).getJavaMethod(); - classLoader = method.getDeclaringClass().getClassLoader(); - } - Class<? extends Throwable> exceptionClass = - (Class<? extends Throwable>)Class.forName(javaClass, false, classLoader); - Constructor<? extends Throwable> ctor = null; - Throwable ex = null; - try { - ctor = exceptionClass.getConstructor(String.class, Throwable.class); - ex = ctor.newInstance(message, null); - } catch (NoSuchMethodException e1) { - try { - ctor = exceptionClass.getConstructor(String.class); - ex = ctor.newInstance(message); - } catch (NoSuchMethodException e2) { - try { - ctor = exceptionClass.getConstructor(Throwable.class); - ex = ctor.newInstance(null); - } catch (NoSuchMethodException e3) { - ctor = exceptionClass.getConstructor(); - ex = ctor.newInstance(); - } - } - } - throw ex; - } - } - throw new ServiceRuntimeException(error.toString()); - } - } - - @Override - public boolean allowsPassByReference() { - return true; - } - -} |