Package com.google.gwt.user.server.rpc
Class AbstractXsrfProtectedServiceServlet
- java.lang.Object
-
- javax.servlet.GenericServlet
-
- javax.servlet.http.HttpServlet
-
- com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet
-
- com.google.gwt.user.server.rpc.RemoteServiceServlet
-
- com.google.gwt.user.server.rpc.AbstractXsrfProtectedServiceServlet
-
- All Implemented Interfaces:
SerializationPolicyProvider,java.io.Serializable,javax.servlet.Servlet,javax.servlet.ServletConfig
- Direct Known Subclasses:
XsrfProtectedServiceServlet
public abstract class AbstractXsrfProtectedServiceServlet extends RemoteServiceServlet
An abstract class for XSRF protected RPC service implementations, which decides if XSRF protection should be enforced on a method invocation based on the following logic:- RPC interface or method can be annotated with either
XsrfProtectorNoXsrfProtectannotation to enable or disable XSRF protection on all methods of an RPC interface or a single method correspondingly. - RPC interface level annotation can be overridden by a method level annotation.
- If no annotations are present and RPC interface contains method that
returns
RpcTokenor its implementation, then XSRF token validation is performed on all methods of that interface except for the method returningRpcToken.
- See Also:
XsrfProtectedServiceServlet, Serialized Form
-
-
Field Summary
-
Fields inherited from class com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet
perThreadRequest, perThreadResponse
-
-
Constructor Summary
Constructors Constructor Description AbstractXsrfProtectedServiceServlet()The default constructor used by service implementations that extend this class.AbstractXsrfProtectedServiceServlet(java.lang.Object delegate)The wrapping constructor used by service implementations that are separate from this class.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected voidonAfterRequestDeserialized(RPCRequest rpcRequest)Override this method to examine the deserialized version of the request before the call to the servlet method is made.protected booleanshouldValidateXsrfToken(java.lang.reflect.Method method)Override this method to change default XSRF enforcement logic.protected abstract voidvalidateXsrfToken(RpcToken token, java.lang.reflect.Method method)Override this method to perform XSRF token verification.-
Methods inherited from class com.google.gwt.user.server.rpc.RemoteServiceServlet
checkPermutationStrongName, doGetSerializationPolicy, getCodeServerPolicyUrl, getRequestModuleBasePath, getSerializationPolicy, init, loadPolicyFromCodeServer, loadSerializationPolicy, onAfterResponseSerialized, onBeforeRequestDeserialized, processCall, processCall, processPost, shouldCompressResponse
-
Methods inherited from class com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet
doPost, doUnexpectedFailure, getPermutationStrongName, getThreadLocalRequest, getThreadLocalResponse, readContent
-
Methods inherited from class javax.servlet.http.HttpServlet
doDelete, doGet, doHead, doOptions, doPut, doTrace, getLastModified, service, service
-
-
-
-
Constructor Detail
-
AbstractXsrfProtectedServiceServlet
public AbstractXsrfProtectedServiceServlet()
The default constructor used by service implementations that extend this class. The servlet will delegate AJAX requests to the appropriate method in the subclass.
-
AbstractXsrfProtectedServiceServlet
public AbstractXsrfProtectedServiceServlet(java.lang.Object delegate)
The wrapping constructor used by service implementations that are separate from this class. The servlet will delegate AJAX requests to the appropriate method in the given object.
-
-
Method Detail
-
onAfterRequestDeserialized
protected void onAfterRequestDeserialized(RPCRequest rpcRequest)
Description copied from class:AbstractRemoteServiceServletOverride this method to examine the deserialized version of the request before the call to the servlet method is made. The default implementation does nothing and need not be called by subclasses.- Overrides:
onAfterRequestDeserializedin classAbstractRemoteServiceServlet
-
shouldValidateXsrfToken
protected boolean shouldValidateXsrfToken(java.lang.reflect.Method method)
Override this method to change default XSRF enforcement logic.- Parameters:
method- Method being invoked- Returns:
trueif XSRF token should be verified,falseotherwise
-
validateXsrfToken
protected abstract void validateXsrfToken(RpcToken token, java.lang.reflect.Method method) throws RpcTokenException
Override this method to perform XSRF token verification.- Parameters:
token-RpcTokenincluded with an RPC request.method- method being invoked via this RPC call.- Throws:
RpcTokenException- if token verification failed.
-
-