From f5a70a8943ef8d4489d7435f71fcefbd5da49d2d Mon Sep 17 00:00:00 2001 From: Leif Åstrand Date: Thu, 22 Nov 2012 14:16:22 +0200 Subject: Remove server-side RpcManager interface (#10302) Change-Id: Id693f49d68d4daa6bd8cbe6b1b1a6553fc988c75 --- .../com/vaadin/server/AbstractClientConnector.java | 6 ++- .../server/AbstractCommunicationManager.java | 9 ++-- server/src/com/vaadin/server/ClientConnector.java | 4 +- .../src/com/vaadin/server/DragAndDropService.java | 2 +- server/src/com/vaadin/server/RpcManager.java | 59 ---------------------- server/src/com/vaadin/server/ServerRpcManager.java | 35 +++++++++++-- .../vaadin/tests/errorhandler/ErrorHandlers.java | 2 +- 7 files changed, 43 insertions(+), 74 deletions(-) delete mode 100644 server/src/com/vaadin/server/RpcManager.java diff --git a/server/src/com/vaadin/server/AbstractClientConnector.java b/server/src/com/vaadin/server/AbstractClientConnector.java index da4142ef96..70a4c342cc 100644 --- a/server/src/com/vaadin/server/AbstractClientConnector.java +++ b/server/src/com/vaadin/server/AbstractClientConnector.java @@ -58,7 +58,7 @@ public abstract class AbstractClientConnector implements ClientConnector, * A map from client to server RPC interface class name to the RPC call * manager that handles incoming RPC calls for that interface. */ - private Map rpcManagerMap = new HashMap(); + private Map> rpcManagerMap = new HashMap>(); /** * A map from server to client RPC interface class to the RPC proxy that @@ -388,7 +388,7 @@ public abstract class AbstractClientConnector implements ClientConnector, } @Override - public RpcManager getRpcManager(String rpcInterfaceName) { + public ServerRpcManager getRpcManager(String rpcInterfaceName) { return rpcManagerMap.get(rpcInterfaceName); } @@ -984,6 +984,7 @@ public abstract class AbstractClientConnector implements ClientConnector, * * @see com.vaadin.server.ClientConnector#getErrorHandler() */ + @Override public ErrorHandler getErrorHandler() { return errorHandler; } @@ -994,6 +995,7 @@ public abstract class AbstractClientConnector implements ClientConnector, * @see com.vaadin.server.ClientConnector#setErrorHandler(com.vaadin.server. * ErrorHandler) */ + @Override public void setErrorHandler(ErrorHandler errorHandler) { this.errorHandler = errorHandler; } diff --git a/server/src/com/vaadin/server/AbstractCommunicationManager.java b/server/src/com/vaadin/server/AbstractCommunicationManager.java index 4c5122c338..e514524545 100644 --- a/server/src/com/vaadin/server/AbstractCommunicationManager.java +++ b/server/src/com/vaadin/server/AbstractCommunicationManager.java @@ -65,7 +65,7 @@ import com.vaadin.annotations.PreserveOnRefresh; import com.vaadin.annotations.StyleSheet; import com.vaadin.server.ClientConnector.ConnectorErrorEvent; import com.vaadin.server.ComponentSizeValidator.InvalidLayout; -import com.vaadin.server.RpcManager.RpcInvocationException; +import com.vaadin.server.ServerRpcManager.RpcInvocationException; import com.vaadin.server.StreamVariable.StreamingEndEvent; import com.vaadin.server.StreamVariable.StreamingErrorEvent; import com.vaadin.shared.ApplicationConstants; @@ -1862,8 +1862,8 @@ public abstract class AbstractCommunicationManager implements Serializable { throws JSONException { ClientConnector connector = connectorTracker.getConnector(connectorId); - RpcManager rpcManager = connector.getRpcManager(interfaceName); - if (!(rpcManager instanceof ServerRpcManager)) { + ServerRpcManager rpcManager = connector.getRpcManager(interfaceName); + if (rpcManager == null) { /* * Security: Don't even decode the json parameters if no RpcManager * corresponding to the received method invocation has been @@ -1879,8 +1879,7 @@ public abstract class AbstractCommunicationManager implements Serializable { // Use interface from RpcManager instead of loading the class based on // the string name to avoid problems with OSGi - Class rpcInterface = ((ServerRpcManager) rpcManager) - .getRpcInterface(); + Class rpcInterface = rpcManager.getRpcInterface(); ServerRpcMethodInvocation invocation = new ServerRpcMethodInvocation( connectorId, rpcInterface, methodName, parametersJson.length()); diff --git a/server/src/com/vaadin/server/ClientConnector.java b/server/src/com/vaadin/server/ClientConnector.java index b51a1d6eec..a6821a4269 100644 --- a/server/src/com/vaadin/server/ClientConnector.java +++ b/server/src/com/vaadin/server/ClientConnector.java @@ -352,9 +352,9 @@ public interface ClientConnector extends Connector { * * @param rpcInterfaceName * name of the interface for which the call was made - * @return RpcManager or null if none found for the interface + * @return ServerRpcManager or null if none found for the interface */ - public RpcManager getRpcManager(String rpcInterfaceName); + public ServerRpcManager getRpcManager(String rpcInterfaceName); /** * Gets the error handler for the connector. diff --git a/server/src/com/vaadin/server/DragAndDropService.java b/server/src/com/vaadin/server/DragAndDropService.java index 529cce670e..3eecd7448e 100644 --- a/server/src/com/vaadin/server/DragAndDropService.java +++ b/server/src/com/vaadin/server/DragAndDropService.java @@ -254,7 +254,7 @@ public class DragAndDropService implements VariableOwner, ClientConnector { } @Override - public RpcManager getRpcManager(String interfaceName) { + public ServerRpcManager getRpcManager(String interfaceName) { // TODO Use rpc for drag'n'drop return null; } diff --git a/server/src/com/vaadin/server/RpcManager.java b/server/src/com/vaadin/server/RpcManager.java deleted file mode 100644 index bb1c116388..0000000000 --- a/server/src/com/vaadin/server/RpcManager.java +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright 2011 Vaadin Ltd. - * - * Licensed 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 com.vaadin.server; - -import java.io.Serializable; - -/** - * Server side RPC manager that can invoke methods based on RPC calls received - * from the client. - * - * @since 7.0 - */ -public interface RpcManager extends Serializable { - public void applyInvocation(ServerRpcMethodInvocation invocation) - throws RpcInvocationException; - - /** - * Wrapper exception for exceptions which occur during invocation of an RPC - * call - * - * @author Vaadin Ltd - * @since 7.0 - * - */ - public static class RpcInvocationException extends Exception { - - public RpcInvocationException() { - super(); - } - - public RpcInvocationException(String message, Throwable cause) { - super(message, cause); - } - - public RpcInvocationException(String message) { - super(message); - } - - public RpcInvocationException(Throwable cause) { - super(cause); - } - - } - -} diff --git a/server/src/com/vaadin/server/ServerRpcManager.java b/server/src/com/vaadin/server/ServerRpcManager.java index c063761c7f..a3962ed949 100644 --- a/server/src/com/vaadin/server/ServerRpcManager.java +++ b/server/src/com/vaadin/server/ServerRpcManager.java @@ -35,11 +35,39 @@ import com.vaadin.shared.communication.ServerRpc; * * @since 7.0 */ -public class ServerRpcManager implements RpcManager { +public class ServerRpcManager { private final T implementation; private final Class rpcInterface; + /** + * Wrapper exception for exceptions which occur during invocation of an RPC + * call + * + * @author Vaadin Ltd + * @since 7.0 + * + */ + public static class RpcInvocationException extends Exception { + + public RpcInvocationException() { + super(); + } + + public RpcInvocationException(String message, Throwable cause) { + super(message, cause); + } + + public RpcInvocationException(String message) { + super(message); + } + + public RpcInvocationException(Throwable cause) { + super(cause); + } + + } + private static final Map, Class> boxedTypes = new HashMap, Class>(); static { try { @@ -83,8 +111,8 @@ public class ServerRpcManager implements RpcManager { */ public static void applyInvocation(ClientConnector target, ServerRpcMethodInvocation invocation) throws RpcInvocationException { - RpcManager manager = target - .getRpcManager(invocation.getInterfaceName()); + ServerRpcManager manager = target.getRpcManager(invocation + .getInterfaceName()); if (manager != null) { manager.applyInvocation(invocation); } else { @@ -123,7 +151,6 @@ public class ServerRpcManager implements RpcManager { * @param invocation * method invocation to perform */ - @Override public void applyInvocation(ServerRpcMethodInvocation invocation) throws RpcInvocationException { Method method = invocation.getMethod(); diff --git a/uitest/src/com/vaadin/tests/errorhandler/ErrorHandlers.java b/uitest/src/com/vaadin/tests/errorhandler/ErrorHandlers.java index c5ff1be1ed..2a15dc02c8 100644 --- a/uitest/src/com/vaadin/tests/errorhandler/ErrorHandlers.java +++ b/uitest/src/com/vaadin/tests/errorhandler/ErrorHandlers.java @@ -5,7 +5,7 @@ import java.lang.reflect.InvocationTargetException; import com.vaadin.event.ListenerMethod.MethodException; import com.vaadin.server.DefaultErrorHandler; import com.vaadin.server.ErrorHandler; -import com.vaadin.server.RpcManager.RpcInvocationException; +import com.vaadin.server.ServerRpcManager.RpcInvocationException; import com.vaadin.server.VaadinRequest; import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.ui.Button; -- cgit v1.2.3